Поставщик контента, не работающий на устройствах семейства Nexus

Я разрабатываю приложение с ContentProvider, чтобы предлагать некоторые внутренние файлы (двоичные файлы). Когда я развертываю его на Samsung Galaxy S, SII или любом другом, он отлично работает, покупайте, когда я пытаюсь использовать его на Galaxy Nexus или Nexus S, это не сработает!

Сценарий:

Доступ к моему ContentProvider можно получить с помощью двух URI. В зависимости от этого URI поставщик создает DataCursor (расширяя CrossProcessCursor) или ModelCursor (также расширяя CrossProcessCursos). Дело в том, что в семействе Nexus я обращаюсь к первому курсору (DataCursor), чтобы получить идентификатор, и он работает отлично, но при доступе к второму он всегда выбрасывает "OutOfBoundsException" при попытке

getBlob()

метод.

Provider

@Override
    public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
        Cursor cursor = null;

        // If the third app requieres DATA (phrase id, phrase string and phrase name)
        if(uri.toString().equalsIgnoreCase(ProviderConstants.DATA_URI.toString())) {
            // Build the DataHelper and the customized cursor
            DataHelper dataHelper = new DataHelper(getContext());
            cursor = new DataCursor(dataHelper);
        } else if(uri.toString().equalsIgnoreCase(ProviderConstants.MODEL_URI.toString())) {            
            // Let take the model id from the selectionArgs...
            if (selectionArgs != null && selectionArgs.length > 0) {
                String modelId = selectionArgs[0];

                // Get an instance to the persistent storage service...
                File file = FileManager.getDirectory(getContext(), modelId);
                FileSystemPersistentStorageService clientPersistentStorageService = new FileSystemPersistentStorageService(file);

                cursor = new ModelCursor(clientPersistentStorageService);
            } else {
                Log.e("ContentProvider", "Query without model id on selectionArgs");
            }
        }

        return cursor;
    }

Если вам нужен какой-то код или что-то еще, просто попросите его, пожалуйста!

Большое спасибо.

Ответ 1

Наконец, я получил ответ. Это произошло не из-за устройств, а из-за версии ОС Android.

В более ранних версиях 4.0.3 был применен метод fillWindow() AbstarctCursor, который не является обязательным для установки позиции курсора на 0 для первого элемента. После 4.0.3 (как показано здесь), этот метод был изменен, в результате чего позиция курсора не установлена ​​на 0.

Исключение выбрано:

07-31 11:35:09.938: W/System.err(2760): android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
07-31 11:35:09.985: W/System.err(2760):     at android.database.AbstractCursor.checkPosition(AbstractCursor.java:418)
07-31 11:35:09.989: W/System.err(2760):     at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
07-31 11:35:09.989: W/System.err(2760):     at android.database.AbstractWindowedCursor.getBlob(AbstractWindowedCursor.java:44)
07-31 11:35:09.993: W/System.err(2760):     at android.database.CursorWrapper.getBlob(CursorWrapper.java:122)
07-31 11:35:09.993: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.ModelImporterAndroidImpl.importModelPackage(ModelImporterAndroidImpl.java:44)
07-31 11:35:09.993: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.KivoxMobileBasicCode.importModel(KivoxMobileBasicCode.java:159)
07-31 11:35:09.997: W/System.err(2760):     at es.agnitio.kivox.mobile.internal.KivoxMobileBasicImpl.importModel(KivoxMobileBasicImpl.java:47)
07-31 11:35:09.997: W/System.err(2760):     at es.agnitio.kivoxmobile.testing.KivoxMobileBasicTrial.onCreate(KivoxMobileBasicTrial.java:63)
07-31 11:35:09.997: W/System.err(2760):     at android.app.Activity.performCreate(Activity.java:5008)
07-31 11:35:10.001: W/System.err(2760):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
07-31 11:35:10.001: W/System.err(2760):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
07-31 11:35:10.001: W/System.err(2760):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
07-31 11:35:10.004: W/System.err(2760):     at android.app.ActivityThread.access$600(ActivityThread.java:130)
07-31 11:35:10.004: W/System.err(2760):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
07-31 11:35:10.004: W/System.err(2760):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-31 11:35:10.008: W/System.err(2760):     at android.os.Looper.loop(Looper.java:137)
07-31 11:35:10.008: W/System.err(2760):     at android.app.ActivityThread.main(ActivityThread.java:4745)
07-31 11:35:10.008: W/System.err(2760):     at java.lang.reflect.Method.invokeNative(Native Method)
07-31 11:35:10.012: W/System.err(2760):     at java.lang.reflect.Method.invoke(Method.java:511)
07-31 11:35:10.012: W/System.err(2760):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-31 11:35:10.012: W/System.err(2760):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
07-31 11:35:10.016: W/System.err(2760):     at dalvik.system.NativeStart.main(Native Method)

Что показывает (после глубоких исследований), что индекс курсора не устанавливается на fillWindow().

Решение

Чтобы решить эту проблему "фрагментации", просто добавьте moveToPosition (0) в методы типа moveToFirst() или move() (с некоторым приложением логики) вашего пользовательского курсора. Это приведет к тому, что индекс курсора будет установлен на 0, избегая "-1" запроса запроса индекса.

Надеюсь, что это поможет кому угодно =)

Ответ 2

Я немного нуждаюсь в хрустальном шаре для этого, но... вы могли бы попробовать две вещи:

  • Переместите курсор на первую запись, как предложено SteveR.

  • Во-вторых, я столкнулся с подобной проблемой, работая на планшете Dell Streak 7. Это, предположительно, было частью списка устройств с особым исключением в отношении доступа к его внутреннему хранилищу. Было сложно найти, но был отсортирован с выражением if.Это может быть что-то похожее, хотя я в этом сомневаюсь, тем более, что Nexus должен быть разработчиком.

Возможно, вам стоит попробовать запустить простейшее тестовое приложение ContentProvider и посмотреть, как он работает на этих устройствах.