10

基本的に私がやりたいことは、インテントを介してカスタムのパーセル可能なオブジェクトを RemoteViewsService に、したがって私の RemoteViewsFactory に渡すことです。何らかの理由で、これは単に機能しません:S これを実行しようとすると、ウィジェットは代わりに「ウィジェットの読み込みの問題」というテキストを表示してしまいます。

同じことを試してみると、RemoteViewsService に渡す代わりに、通常のアクティビティに渡すだけで、期待どおりに動作します。

私は自分の答えをオンラインで見つけようとしましたが、うまくいかなかったので、助けになることを期待してここに投稿します.

私はしばらくの間、これをメインプログラムで機能させようとしています。しかし、私はそれを理解できませんでした。だから私はそれを煮詰めようとしました。私は問題を再現することに成功しました。私が問題を再現したベースは、CommonsGuy の LoremWidget ( https://github.com/commonsguy/cw-advandroid/tree/master/AppWidget/LoremWidget ) とランダムに分割可能な例 ( http ://prasanta-paul.blogspot.dk/2010/06/android-parcelable-example.htm l) 私の問題を示すために動作するように修正しました。(これら2つのリンクのコードを使用して、トラブルに巻き込まれないことを願っています)

誰かが私が話していることをテスト実行したい場合に備えて、ランダムなファイルホストにアップロードされた完全なコードを次に示します: http://www.filedropper.com/remoteviewserviceparcelerrorexample

だから私の質問を要約すると:

パーセル化可能なオブジェクト (単独で、または ArrayList にラップされたもの) を RemoteViewsService に渡すことができないのはなぜですか? (同じコードがアクティビティで問題なく動作する場合)

誰かが私を助けてくれることを本当に願っています。現在、私のメイン プログラムでは、内部ストレージにシリアライズしてから、すぐに RemoteViewsService から再度デシリアライズしています。

編集:私のメインプログラムで何らかの理由で、カスタムオブジェクトの1つを渡し、ArrayListとStringsをnullに設定し、ブール値をすべてfalseにすると(基本的にオブジェクトが作成時にどのように見えるか)、ウィジェットは正常に見えます (つまり、「ウィジェットの読み込みに問題があります」というメッセージは表示されません)。

編集:外観を見た後(私が実行していたアプリにフィルタリングされていません)、いくつかのエラーが表示されます(何もファイルされていない場合は、フィルタリングされていないすべてを見ることを学ぶほうがよいと思います:)):

     11-13 17:14:27.268: D/AndroidRuntime(8840): >>>>>> AndroidRuntime START com.android.internal.os.RuntimeInit <<<<<<
    11-13 17:14:27.268: D/AndroidRuntime(8840): CheckJNI is ON
    11-13 17:14:27.340: D/AndroidRuntime(8840): Calling main entry com.android.commands.pm.Pm
    11-13 17:14:27.348: W/ActivityManager(90): No content provider found for permission revoke: file:///data/local/tmp/com.commonsware.android.appwidget.lorem.LoremActivity.apk
    11-13 17:14:27.348: W/ActivityManager(90): No content provider found for permission revoke: file:///data/local/tmp/com.commonsware.android.appwidget.lorem.LoremActivity.apk
    11-13 17:14:27.356: I/PackageManager(90): Removing non-system package:com.commonsware.android.appwidget.lorem
    11-13 17:14:27.360: I/ActivityManager(90): Force stopping package com.commonsware.android.appwidget.lorem uid=10034
    11-13 17:14:27.360: I/ActivityManager(90): Killing proc 8798:com.commonsware.android.appwidget.lorem/10034: force stop
    11-13 17:14:27.400: D/dalvikvm(90): GC_CONCURRENT freed 511K, 17% free 8611K/10311K, paused 0ms+0ms
    11-13 17:14:27.400: I/PackageManager(90): Package com.commonsware.android.appwidget.lorem codePath changed from /data/app/com.commonsware.android.appwidget.lorem-2.apk to /data/app/com.commonsware.android.appwidget.lorem-1.apk; Retaining data and using new
    11-13 17:14:27.404: I/PackageManager(90): Running dexopt on: com.commonsware.android.appwidget.lorem
    11-13 17:14:27.440: D/dalvikvm(8850): DexOpt: load 12ms, verify+opt 4ms
    11-13 17:14:27.448: W/PackageManager(90): Code path for pkg : com.commonsware.android.appwidget.lorem changing from /data/app/com.commonsware.android.appwidget.lorem-2.apk to /data/app/com.commonsware.android.appwidget.lorem-1.apk
    11-13 17:14:27.448: W/PackageManager(90): Resource path for pkg : com.commonsware.android.appwidget.lorem changing from /data/app/com.commonsware.android.appwidget.lorem-2.apk to /data/app/com.commonsware.android.appwidget.lorem-1.apk
    11-13 17:14:27.452: I/ActivityManager(90): Force stopping package com.commonsware.android.appwidget.lorem uid=10034
    11-13 17:14:27.460: D/PackageManager(90): New package installed in /data/app/com.commonsware.android.appwidget.lorem-1.apk
    11-13 17:14:27.472: I/ActivityManager(90): Force stopping package com.commonsware.android.appwidget.lorem uid=10034
    11-13 17:14:27.496: D/dalvikvm(266): GC_EXPLICIT freed 127K, 9% free 6766K/7367K, paused 0ms+0ms
    11-13 17:14:27.512: D/dalvikvm(221): GC_EXPLICIT freed 878K, 57% free 15010K/34119K, paused 0ms+0ms
    11-13 17:14:27.584: D/dalvikvm(90): GC_EXPLICIT freed 385K, 18% free 8558K/10311K, paused 0ms+0ms
    11-13 17:14:27.588: D/PackageManager(90): generateServicesMap(android.accounts.AccountAuthenticator): 2 services unchanged
    11-13 17:14:27.620: D/PackageManager(90): generateServicesMap(android.content.SyncAdapter): 4 services unchanged
    11-13 17:14:27.620: D/BackupManagerService(90): Received broadcast Intent { act=android.intent.action.PACKAGE_REMOVED dat=package:com.commonsware.android.appwidget.lorem flg=0x10000010 (has extras) }
    11-13 17:14:27.620: D/PackageManager(90): generateServicesMap(android.accounts.AccountAuthenticator): 2 services unchanged
    11-13 17:14:27.620: D/PackageManager(90): generateServicesMap(android.content.SyncAdapter): 4 services unchanged
    11-13 17:14:27.628: W/ResourceType(90): Failure getting entry for 0x7f060000 (t=5 e=0) in package 0 (error -75)
    11-13 17:14:27.632: D/BackupManagerService(90): Received broadcast Intent { act=android.intent.action.PACKAGE_ADDED dat=package:com.commonsware.android.appwidget.lorem flg=0x10000010 (has extras) }
    11-13 17:14:27.636: V/BackupManagerService(90): updatePackageParticipantsLocked: #1
    11-13 17:14:27.640: W/RecognitionManagerService(90): no available voice recognition services found
    11-13 17:14:27.652: D/dalvikvm(8854): Not late-enabling CheckJNI (already on)
    11-13 17:14:27.684: I/ActivityManager(90): Start proc com.commonsware.android.appwidget.lorem for broadcast com.commonsware.android.appwidget.lorem/.WidgetProvider: pid=8854 uid=10034 gids={}
    11-13 17:14:27.688: D/BackupManagerService(90): Received broadcast Intent { act=android.intent.action.PACKAGE_REPLACED dat=package:com.commonsware.android.appwidget.lorem flg=0x10000010 (has extras) }
    11-13 17:14:27.688: V/BackupManagerService(90): updatePackageParticipantsLocked: #1
    11-13 17:14:27.740: I/dalvikvm(8854): Turning on JNI app bug workarounds for target SDK version 11...
    11-13 17:14:27.756: D/dalvikvm(90): GC_EXPLICIT freed 409K, 16% free 8687K/10311K, paused 0ms+4ms
    11-13 17:14:27.792: D/AndroidRuntime(8840): Shutting down VM
    11-13 17:14:27.796: D/dalvikvm(8840): GC_CONCURRENT freed 99K, 79% free 447K/2048K, paused 0ms+0ms
    11-13 17:14:27.796: D/dalvikvm(8840): Debugger has detached; object registry had 1 entries
    11-13 17:14:27.812: I/AndroidRuntime(8840): NOTE: attach of thread 'Binder Thread #3' failed
    11-13 17:14:27.820: D/WidgetProvider(8854): ParcelData=ParcelData [id=0, name=null, desc=null, cities=[suwon, delhi]]
    11-13 17:14:27.820: D/WidgetProvider(8854): ArrayList<ParcelData>=[ParcelData [id=0, name=null, desc=null, cities=[suwon, delhi]]]
    11-13 17:14:27.824: V/ParcelData(8854): writeToParcel...0
    11-13 17:14:27.824: V/ParcelData(8854): writeToParcel...0
    11-13 17:14:27.828: V/ParcelData(8854): writeToParcel...0
    11-13 17:14:27.828: V/ParcelData(8854): writeToParcel...0
    11-13 17:14:27.828: E/Parcel(221): Class not found when unmarshalling: com.commonsware.android.appwidget.lorem.ParcelData, e: java.lang.ClassNotFoundException: com.commonsware.android.appwidget.lorem.ParcelData
    11-13 17:14:27.832: W/AppWidgetHostView(221): updateAppWidget couldn't find any view, using error view
    11-13 17:14:27.832: W/AppWidgetHostView(221): android.os.BadParcelableException: ClassNotFoundException when unmarshalling: com.commonsware.android.appwidget.lorem.ParcelData
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readParcelable(Parcel.java:1966)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readValue(Parcel.java:1854)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readListInternal(Parcel.java:2103)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readArrayList(Parcel.java:1544)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readValue(Parcel.java:1875)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Parcel.readMapInternal(Parcel.java:2094)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Bundle.unparcel(Bundle.java:223)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Bundle.putInt(Bundle.java:436)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.content.Intent.putExtra(Intent.java:4695)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.widget.RemoteViews$SetRemoteViewsAdapterIntent.apply(RemoteViews.java:401)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.widget.RemoteViews.performApply(RemoteViews.java:1606)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.widget.RemoteViews.apply(RemoteViews.java:1583)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.appwidget.AppWidgetHostView.updateAppWidget(AppWidgetHostView.java:289)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.appwidget.AppWidgetHost.updateAppWidgetView(AppWidgetHost.java:283)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.appwidget.AppWidgetHost$UpdateHandler.handleMessage(AppWidgetHost.java:84)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Handler.dispatchMessage(Handler.java:99)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.os.Looper.loop(Looper.java:137)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at android.app.ActivityThread.main(ActivityThread.java:4424)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at java.lang.reflect.Method.invokeNative(Native Method)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at java.lang.reflect.Method.invoke(Method.java:511)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
    11-13 17:14:27.832: W/AppWidgetHostView(221):   at dalvik.system.NativeStart.main(Native Method)
    11-13 17:14:28.116: D/AndroidRuntime(8872): >>>>>> AndroidRuntime START com.android.internal.os.RuntimeInit <<<<<<
    11-13 17:14:28.116: D/AndroidRuntime(8872): CheckJNI is ON
    11-13 17:14:28.200: D/AndroidRuntime(8872): Calling main entry com.android.commands.am.Am
    11-13 17:14:28.204: I/ActivityManager(90): START {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 cmp=com.commonsware.android.appwidget.lorem/.LoremActivity} from pid 8872
    11-13 17:14:28.208: W/WindowManager(90): Failure taking screenshot for (192x135) to layer 21020
    11-13 17:14:28.220: W/NetworkManagementSocketTagger(90): setKernelCountSet(10034, 1) failed with errno -2
    11-13 17:14:28.240: D/AndroidRuntime(8872): Shutting down VM
    11-13 17:14:28.244: D/dalvikvm(8872): GC_CONCURRENT freed 100K, 77% free 475K/2048K, paused 4ms+0ms
    11-13 17:14:28.244: D/dalvikvm(8872): Debugger has detached; object registry had 1 entries
    11-13 17:14:28.244: I/AndroidRuntime(8872): NOTE: attach of thread 'Binder Thread #1' failed
    11-13 17:14:28.252: W/InputManagerService(90): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@b38c3ef0
    11-13 17:14:28.504: W/NetworkManagementSocketTagger(90): setKernelCountSet(10034, 0) failed with errno -2
4

5 に答える 5

3

私はTreKingがここで話していることをやった: https://groups.google.com/d/msg/android-developers/KX0BUAbOTKY/jqW_ZokCH3gJ

私がやったことは、基本的にParcelableが意図していることを行う「Bundleable」インターフェースを作成することです。このインターフェースを拡張するオブジェクトは、自分自身を置き、バンドル オブジェクトから再作成することができます。これは、それ自体が Parcelable であるため、オブジェクトと同じように送信できます。ただし、システムは常にバンドル タイプをロードする方法を知っているため、このエラーが発生することはありません。

そして彼のコード例に従ってください:

public interface Bundleable
{
 public Bundle toBundle();

 public void fromBundle(Bundle b);
}

public class MyClass implements Bundleable
{
 public Bundle toBundle()
 { 
  Bundle b = new Bundle();
  // Fill b with data
  return b;
 }

 public void from Bundle(Bundle b)
 {
  // set properties from data in b
 }
}

// ...

MyClass m = new MyClass();
Intent i = new Intent();
i.putBundleExtra("MyClass", m.toBundle());

// ... Elsewhere

Bundle b = intent.getBundleExtra("MyClass");
MyClass m = new MyClass(b); // Constructor calls fromBundle(b);

パーセルの取引全体が最初から期待していたように機能しました! :)

于 2012-11-14T18:55:43.043 に答える
0

を使用してこれを機能させることができない場合Parcelableは、自分で実行してください。代わりにParcelDataとして渡してください。あなたのメソッドとメソッドを次のようなものにString変換するだけです(貧乏人の「シリアル化」):writeToParcel()ParcelData(Parcel source)

public String serializeToString() {
    StringBuilder sb = new StringBuilder();
    sb.append(Integer.toString(id)).append('|').append(name).append('|').append(desc)
        .append('|');
    for (String c : cities) {
        sb.append(c).append(';');
    }
    sb.append('|');
    return sb.toString();
}

ParcelData(String source) {
    String[] parts = source.split("|");
    id = Integer.parseInt(parts[0]);
    name = parts[1];
    desc = parts[2];
    cc = parts[3].split(";");
    if (cc.length == 0) {
        cities = new String[0]; // No cities
    } else {
        cities = new String[cc.length - 1]; // Last element is empty
        for (int i = 0; i < cc.length - 1; i++) {
            cities[i] = cc[i];
        }
    }
}

私はこれをコンパイラーで実行しなかったので、ばかげた構文ミスがあるかもしれません。あなたはその考えを理解するべきです。

于 2012-11-13T18:16:16.870 に答える