아래 XML을 호출하여 XML을 설정하는 활동이 있습니다. 이 xml 레이아웃 inturn은 두 개의 단추와 edittext를 설정하는 사용자 지정 복합 구성 요소를 호출합니다. 내 주요 활동은 사용자 지정 복합 구성 요소에 정의 된 편집 텍스트에서 값을 가져 오려고합니다. 나는 아래 logcat 보고서를 가지고 있지만, 나는 그것이 정확하지 않다는 것을 알 수 없다.java.lang.ClassCastException : 사용자 지정 복합 구성 요소에서
XML 레이아웃 파일
<com.android.control.MinutePicker
android:id="@+id/MinPick"
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
</com.android.control.MinutePicker>
com.android.control.MinutePicker 다음 편집 텍스트의 가치를 할려고
but1 = new Button(context);
but1.setTextSize(TEXT_SIZE);
but1.setText("-");
but2 = new Button(context);
but2.setTextSize(TEXT_SIZE);
but2.setText("-");
valueText = new EditText(context);
valueText.setTextSize(TEXT_SIZE);
valueText.setGravity(Gravity.CENTER_VERTICAL | Gravity.CENTER_HORIZONTAL);
valueText.setText(0);
this.setLayoutParams(new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
LayoutParams elementParams = new LinearLayout.LayoutParams(ELEMENT_WIDTH, ELEMENT_HEIGHT);
addView(but1, elementParams);
addView(valueText, elementParams);
addView(but2, elementParams);
주요 활동.
EditText Identifier = (EditText)findViewById(R.id.MinPick);
String value = Identifier.getText().toString();
Toast toast = Toast.makeText(PerfectSleepActivity.this, value, Toast.LENGTH_SHORT);
toast.setGravity(Gravity.CENTER, 0, 0);
toast.show();
로그 캣 보고서는이 코드 줄에 글고 치기에 유형 MinutePicker (com.android.control.MinutePicker)의 클래스를 캐스팅하려고하는 것 같습니다
05-08 19:03:56.141: E/AndroidRuntime(200): Uncaught handler: thread main exiting due to uncaught exception
05-08 19:03:57.730: E/AndroidRuntime(200): java.lang.ClassCastException: com.android.control.MinutePicker
05-08 19:03:57.730: E/AndroidRuntime(200): at com.ap.df.DFActivity$2.onClick(PerfectSleepActivity.java:37)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.View.performClick(View.java:2344)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.View.onTouchEvent(View.java:4133)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.widget.TextView.onTouchEvent(TextView.java:6510)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.View.dispatchTouchEvent(View.java:3672)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:882)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:882)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:882)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:882)
05-08 19:03:57.730: E/AndroidRuntime(200): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1712)
05-08 19:03:57.730: E/AndroidRuntime(200): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1202)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.app.Activity.dispatchTouchEvent(Activity.java:1987)
05-08 19:03:57.730: E/AndroidRuntime(200): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1696)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.view.ViewRoot.handleMessage(ViewRoot.java:1658)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.os.Handler.dispatchMessage(Handler.java:99)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.os.Looper.loop(Looper.java:123)
05-08 19:03:57.730: E/AndroidRuntime(200): at android.app.ActivityThread.main(ActivityThread.java:4203)
05-08 19:03:57.730: E/AndroidRuntime(200): at java.lang.reflect.Method.invokeNative(Native Method)
05-08 19:03:57.730: E/AndroidRuntime(200): at java.lang.reflect.Method.invoke(Method.java:521)
05-08 19:03:57.730: E/AndroidRuntime(200): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
05-08 19:03:57.730: E/AndroidRuntime(200): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:549)
05-08 19:03:57.730: E/AndroidRuntime(200): at dalvik.system.NativeStart.main(Native Method)