开发者

Android RatingBar on AlertDialog

I hit the following error when i run the code segment below which is showing a RatingBar on an AlertDialog. The error is

java.lang.IllegalStateException: Could not execute method of the activity 

I try comment out "rB.setOnRatingBarChangeListener(new OnRatingBarChangeListener()...." portion and my rating bar can display out nicely at alertdialog. Any help is really appreciated. Many many thanks

            AlertDialog.Builder builder; 
            AlertDialog alertDialog; 

            Context mContext = getApplicationContext(); 

            LayoutInflater inflater = (LayoutInflater) 

            mContext.getSystemService(LAYOUT_INFLATER_SERVICE); 

            View layout = inflater.inflate(R.layout.review_app, (ViewGroup) findViewById(R.id.layout_root)); 

            builder = new AlertDialog.Builder(this); 
            builder.setView(layout); 

            final RatingBar rB = (RatingBar)findViewById(R.id.Rating01); 
            final TextView ratingdefinition = (TextView) findViewById(R.id.ratingdefinition);


            rB.setOnRatingBarChangeListener(new OnRatingBarChangeListener() { 

                public void onRatingChanged(RatingBar ratingBar, float rating,  boolean fromUser) { 

                     final int numStars = ratingBar.getNumStars();
                     Log.v("number of stars", " " + numStars);
                     switch(numStars) 
                     开发者_开发技巧{
                        case(1):
                        {
                            ratingdefinition.setText("Poor");
                            break;
                        }
                        case(2):
                        {
                            ratingdefinition.setText("Below average");
                            break;
                        }
                        case(3):
                        {
                            ratingdefinition.setText("Average");
                            break;
                        }
                        case(4):
                        {
                            ratingdefinition.setText("Above average");
                            break;
                        }
                        case(5):
                        {
                            ratingdefinition.setText("Excellent!");
                            break;
                        }                                                    
                     }

                } 
                }); 

            alertDialog = builder.create();
            alertDialog.show(); 
        }

The logcat error is:

08-15 09:49:02.789: WARN/dalvikvm(747): threadid=1: thread exiting with uncaught exception (group=0x4001d800)
08-15 09:49:02.859: ERROR/AndroidRuntime(747): FATAL EXCEPTION: main
08-15 09:49:02.859: ERROR/AndroidRuntime(747): java.lang.IllegalStateException: Could not execute method of the activity
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.view.View$1.onClick(View.java:2072)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.view.View.performClick(View.java:2408)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.view.View$PerformClick.run(View.java:8816)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.os.Handler.handleCallback(Handler.java:587)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.os.Handler.dispatchMessage(Handler.java:92)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.os.Looper.loop(Looper.java:123)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.app.ActivityThread.main(ActivityThread.java:4627)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at java.lang.reflect.Method.invokeNative(Native Method)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at java.lang.reflect.Method.invoke(Method.java:521)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at dalvik.system.NativeStart.main(Native Method)
08-15 09:49:02.859: ERROR/AndroidRuntime(747): Caused by: java.lang.reflect.InvocationTargetException
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at com.Maxis.Mplanet.IndividualApp.clickHandler(IndividualApp.java:293)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at java.lang.reflect.Method.invokeNative(Native Method)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at java.lang.reflect.Method.invoke(Method.java:521)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.view.View$1.onClick(View.java:2067)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     ... 11 more
08-15 09:49:02.859: ERROR/AndroidRuntime(747): Caused by: java.lang.NullPointerException: println needs a message
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.util.Log.println_native(Native Method)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     at android.util.Log.v(Log.java:101)
08-15 09:49:02.859: ERROR/AndroidRuntime(747):     ... 15 more


Don't set the RatingBarChangeListener. Set the OndismissListener or Override the OnDismiss(Dialog) where you access the rating bar's current value.

Sample code:

alertDialog.setOnDismissListener(new OnDismissListener(..) {
    void onDismiss(DialogInterface dlg) {
        // find the rating bar and get its value.
        // hold the alert dlg view in activity class and use it here.
        // The one you set using alertDialog.setView
        mAlertDialogView.findViewbyid(R.id.ratingbar);
    }
});
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜