Media query from a specific folder

Posted by sensei on Stack Overflow See other posts from Stack Overflow or by sensei
Published on 2012-09-10T15:36:03Z Indexed on 2012/09/10 15:38 UTC
Read the original article Hit count: 431

I would like to understand how I can use a cursor to jpg files in a folder specified in the sdcard. I'm trying to select with a cursor the jpg files in a specific folder, and I tried this:

This is the code:

public static Uri getRandomImage(ContentResolver resolver) {

    String[] projection = new String[] {
        BaseColumns._ID,     
    };

    String folder = "/sdcard/DCIM/Wallpaper/";
    folder = folder + "%";
    Uri uri = Media.EXTERNAL_CONTENT_URI;
    String[] whereArgs = new String[]{folder};

    Cursor cursor = resolver.query(uri, projection, null, whereArgs, MediaColumns._ID);

    if (cursor == null || cursor.getCount() <= 0) {
            return null;
    }

    cursor.moveToPosition(new Random().nextInt(cursor.getCount()));

    return Uri.withAppendedPath(uri, cursor.getString(0));
}

but this code gives me error here is the logcat:

E/AndroidRuntime(11986): FATAL EXCEPTION: main
E/AndroidRuntime(11986): android.database.sqlite.SQLiteException: bind or column index out of range: handle 0x26a490
E/AndroidRuntime(11986):    at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:158)
E/AndroidRuntime(11986):    at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:114)
E/AndroidRuntime(11986):    at android.content.ContentProviderProxy.bulkQueryInternal(ContentProviderNative.java:330)
E/AndroidRuntime(11986):    at android.content.ContentProviderProxy.query(ContentProviderNative.java:366)
E/AndroidRuntime(11986):    at android.content.ContentResolver.query(ContentResolver.java:245)
E/AndroidRuntime(11986):    at it.bisemanuDEV.slidepuzzle.SelectImagePreference.getRandomImage(SelectImagePreference.java:126)
E/AndroidRuntime(11986):    at it.bisemanuDEV.slidepuzzle.TileView.newGame(TileView.java:156)
E/AndroidRuntime(11986):    at it.bisemanuDEV.slidepuzzle.SlidePuzzleActivity.onOptionsItemSelected(SlidePuzzleActivity.java:377)
E/AndroidRuntime(11986):    at android.app.Activity.onMenuItemSelected(Activity.java:2762)
E/AndroidRuntime(11986):    at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:730)
E/AndroidRuntime(11986):    at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:143)
E/AndroidRuntime(11986):    at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:855)
E/AndroidRuntime(11986):    at com.android.internal.view.menu.IconMenuView.invokeItem(IconMenuView.java:532)
E/AndroidRuntime(11986):    at com.android.internal.view.menu.IconMenuItemView.performClick(IconMenuItemView.java:122)
E/AndroidRuntime(11986):    at android.view.View$PerformClick.run(View.java:8819)
E/AndroidRuntime(11986):    at android.os.Handler.handleCallback(Handler.java:603)
E/AndroidRuntime(11986):    at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime(11986):    at android.os.Looper.loop(Looper.java:123)
E/AndroidRuntime(11986):    at android.app.ActivityThread.main(ActivityThread.java:4627)
E/AndroidRuntime(11986):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(11986):    at java.lang.reflect.Method.invoke(Method.java:521)
E/AndroidRuntime(11986):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
E/AndroidRuntime(11986):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
E/AndroidRuntime(11986):    at dalvik.system.NativeStart.main(Native Method)

© Stack Overflow or respective owner

Related posts about android

Related posts about android-layout