1

Playストアでアプリを更新したところ、人々からクラッシュレポートを受け取り始めました.1人は私が知っている人だったので、彼はこの問題を解決するのを手伝ってくれました.変更。

コードは次のようになります問題を引き起こしている部分はbulb.onClickListenerです

    public class Bulb extends Activity {

    public boolean isAwake = false;
    boolean timerActivated = false;
    static ImageView glow;
    public static boolean bulbActIsRunning = false;

      public void startWake() {
        Intent wS=new Intent(getBaseContext(), WakeService.class);
        startService(wS);
      }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ImageButton bulb = (ImageButton) findViewById(R.id.bulb);
        ImageButton ghl = (ImageButton) findViewById(R.id.ghl);
        glow = (ImageView) findViewById(R.id.glow);

        if (WakeService.isAwake) {
            glow.setVisibility(View.VISIBLE);
        }
        else {
            glow.setVisibility(View.INVISIBLE);
        }

        bulb.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                startWake();

                if (WakeService.isAwake) {
                    glow.setVisibility(View.INVISIBLE);
                }
                else {
                    glow.setVisibility(View.VISIBLE);
                }        
           }
        });

        ghl.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent browserIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.geekshavelanded.com/"));
                startActivity(browserIntent);
           }
        });
    }

    @Override
    protected void onResume() {
        // TODO Auto-generated method stub
        super.onResume();

        glow = (ImageView) findViewById(R.id.glow);

        if (WakeService.isAwake) {
            glow.setVisibility(View.VISIBLE);
        }
        else {
            glow.setVisibility(View.INVISIBLE);
        }
    }

    @Override
    public void onStart() {
       super.onStart();
       bulbActIsRunning = true;
    } 

    @Override
    public void onStop() {
       super.onStop();
       bulbActIsRunning = false;
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
}

友達が電球ボタンをクリックした後、理由もなくアプリがクラッシュしました。クラッシュする前に表示されるかどうかを確認するために、onClickListener の先頭にトースト通知を配置しましたが、表示されませんでした

クラッシュレポートは次のようになります

    java.lang.RuntimeException: Unable to start service com.doublep.wakey.WakeService@41740bb8 with Intent { cmp=com.doublep.wakey/.WakeService }: java.lang.NullPointerException
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2933)
at android.app.ActivityThread.access$1900(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1438)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:155)
at android.app.ActivityThread.main(ActivityThread.java:5454)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1029)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at android.os.Parcel.readException(Parcel.java:1436)
at android.os.Parcel.readException(Parcel.java:1384)
at com.android.internal.appwidget.IAppWidgetService$Stub$Proxy.updateAppWidgetIds(IAppWidgetService.java:513)
at android.appwidget.AppWidgetManager.updateAppWidget(AppWidgetManager.java:333)
at android.appwidget.AppWidgetManager.updateAppWidget(AppWidgetManager.java:400)
at com.doublep.wakey.WakeService.keepAwake(WakeService.java:86)
at com.doublep.wakey.WakeService.onStartCommand(WakeService.java:48)
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2912)
... 10 more

不審なものが見える人はいますか?アプリを更新していたときにこのアクティビティのコードに触れていませんでしたが、ウィジェットからもサービスを呼び出すことができるため、他のすべてが正常に機能します。だから問題はここにあるに違いない

また、最小 SDK を 8 から 7 に変更しました (ただし、動作するかどうかを確認するために、8 に戻しました)。また、スペースを節約するために、一部のグラフィックをもう少し圧縮しました。

編集ああ、言い忘れましたが、これは少数のデバイスでのみ発生し、ほとんどのデバイスでは正常に動作しているようです

UPDATE 2これは、これらの問題を引き起こしたコードです

    AppWidgetManager mgr=AppWidgetManager.getInstance(this);
 mgr.updateAppWidget(ToggleWidget.appWidgetId, ToggleWidget.remoteViews);
4

1 に答える 1

0

updateAppWidget()のパラメータを確認してください。Ether リモート ビューが null であるか、null ビットマップを設定しています。

于 2013-01-05T00:02:52.857 に答える