0

問題があり、非常に混乱しています。ボタンを含むダイアログがあります。このコードを使用して、メインのアクティビティにダイアログを表示します。とても簡単です。

InfoDialog id=new InfoDialog(this);
id.show();

ボタンをクリックすると、2番目のアクティビティが開始されます。とても簡単です。私は次のコードを使用します。

public class InfoDialog extends Dialog implements android.view.View.OnClickListener{

    Context context;

    public InfoDialog(Context context) {
        super(context);
        setContentView(R.layout.infodialog);
        this.context=context;
        setupViews();
    }

    private void setupViews() {
        Button button=(Button)findViewById(R.id.button1);
        button.setOnClickListener(this);    
    } 

    @Override
    public void onClick(View v) {

        switch (v.getId()){
        case R.id.button1:
            Intent newintent= new Intent(context,DestActivity.class);
            context.startActivity(newintent);
            break;  
    }
}

マニフェストでも destAct を宣言します。Gingerbread Android で古い SDK バージョンを実行すると、正常に動作します。しかし、このコードをアイス クリーム サンドイッチ (sdk 11) 以降で実行すると、強制的に閉じられます!!!

これは私の丸太猫です:

08-27 09:38:54.540: W/dalvikvm(10945): threadid=1: thread exiting with uncaught exception (group=0x40a3d1f8)
08-27 09:38:54.544: E/AndroidRuntime(10945): FATAL EXCEPTION: main
08-27 09:38:54.544: E/AndroidRuntime(10945): java.lang.NullPointerException
08-27 09:38:54.544: E/AndroidRuntime(10945):    at my.app.InfoDialog.onClick(InfoDialog.java:131)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.view.View.performClick(View.java:3511)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.view.View$PerformClick.run(View.java:14105)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.os.Handler.handleCallback(Handler.java:605)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.os.Handler.dispatchMessage(Handler.java:92)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.os.Looper.loop(Looper.java:137)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at android.app.ActivityThread.main(ActivityThread.java:4575)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at java.lang.reflect.Method.invokeNative(Native Method)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at java.lang.reflect.Method.invoke(Method.java:511)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
08-27 09:38:54.544: E/AndroidRuntime(10945):    at dalvik.system.NativeStart.main(Native Method)

これはなに?みんな助けてください

4

3 に答える 3

0

これがもう1つの簡単なソルで​​す:

そして、私はcontext.startActivity()を使用しませんでした;)

public class MainActivity extends Activity {

final Context context = this;
private Button button;

public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    button = (Button) findViewById(R.id.buttonShowCustomDialog);

    // add button listener
    button.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View arg0) {

            // custom dialog
            final Dialog dialog = new Dialog(context);
            dialog.setContentView(R.layout.custom);
            dialog.setTitle("Some Title");

            // set the custom dialog components - text, image and button
            TextView text = (TextView) dialog.findViewById(R.id.text);
            text.setText("custom dialog");
            ImageView image = (ImageView) dialog.findViewById(R.id.image);
            image.setImageResource(R.drawable.ic_launcher);

            Button dialogButton = (Button) dialog.findViewById(R.id.dialogButtonOK);
            // if button is clicked, close the custom dialog
            dialogButton.setOnClickListener(new OnClickListener() {
                @Override
                public void onClick(View v) {
                    switch (v.getId()){
                    case R.id.dialogButtonOK:
                        Intent newintent= new Intent(context,OtherActivity.class);
                        startActivity(newintent);
                        break; 
                    }
                }
            });

            dialog.show();
        }

    });

}

}

これが私のxmlです:

  <?xml version="1.0" encoding="utf-8"?>
  <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent" >

   <ImageView
      android:id="@+id/image"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginRight="5dp" />

  <TextView
    android:id="@+id/text"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:textColor="#FFF" 
    android:layout_toRightOf="@+id/image"/>

 <Button
    android:id="@+id/dialogButtonOK"
    android:layout_width="100px"
    android:layout_height="wrap_content"
    android:text=" Ok "
    android:layout_marginTop="5dp"
    android:layout_marginRight="5dp"
    android:layout_below="@+id/image"
    />

  </RelativeLayout>

そしてOtherActivityで私はちょうど乾杯を示しましたすなわち:

   protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    Toast.makeText(this, "ok working fine", Toast.LENGTH_LONG).show();

}

これを試してみてください、その非常にきちんとした、きれいで自明のコード。できる限りシンプルにしてください...

デッドロック...

于 2012-08-27T06:35:11.837 に答える
0

最後に私はそれを修正します。ハンドラーを使用し、ハンドラー メッセージの受信時に startActivity コードを記述しました。ボタンの onClick メソッドで、ハンドラーにメッセージを送信しました。SDK>11で正常に動作します。しかし、なぜ私の古いコードが機能しなかったのか、今でもわかりません;)

于 2012-09-16T04:50:46.613 に答える
0

主な問題は、ダイアログのボタンにメモリを与える方法ではなく、宣言することにありますButton。最初に親の参照を取得する必要があります(つまり、ここのダイアログ)。その後、ビューを見つける必要があります

理解を深めるために、次の方法でクラスを再作成しました。これを試して、お知らせください

     Context context;
View parentView; // THIS IS ADDED

public InfoDialog(Context context) {
    super(context);
    parentView=setContentView(R.layout.infodialog); //UPDATED
    this.context=context;
    setupViews();
}


private void setupViews() {
    Button button=(Button)parentView.findViewById(R.id.button1); //UPDATED
    button.setOnClickListener(this);    
}
于 2012-08-27T06:05:23.110 に答える