2010-05-23 5 views
0

Android 개발을 처음 사용합니다.Android - 인 텐트를 실행하기 위해 위젯을 클릭 할 수 없습니다.

ImageButton을 통해 사용자와 상호 작용할 수있는 매우 간단한 위젯을 개발했습니다.

내가 지금하려는 것은 다음과 같습니다. 사용자가 위젯을 홈 화면에 추가 한 후 단추를 누르면 특정 전화 번호로 전화를 걸기를 원합니다. 홈 화면의 일종의 단축 다이얼입니다.

불행히도 버튼을 탭하면 아무 일도 일어나지 않습니다.

Log.d("", "beginning of onUpdate"); 

final int N = appWidgetIds.length; 

    for (int i=0; i<N; i++) { 
     int appWidgetId = appWidgetIds[i]; 

     Log.d("", "dealing with appWidgetId: " + appWidgetId); 

     // Create an Intent to launch ExampleActivity 
     Intent dialIntent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:1234567")); 
     PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, dialIntent, 0); 


     Log.d("", "pendingIntent classname " + pendingIntent.getClass().getName()); 

     // Get the layout for the App Widget and attach an on-click listener to the button 
     RemoteViews remoteViews = new RemoteViews(context.getPackageName(), R.layout.speed_dial_appwidget); 
     remoteViews.setOnClickPendingIntent(R.id.dial_icon, pendingIntent); 

     Log.d("", "remoteViews classname " + remoteViews.getClass().getName()); 

     // Tell the AppWidgetManager to perform an update on the current App Widget 
     appWidgetManager.updateAppWidget(appWidgetId, remoteViews); 

     Log.d("", "end of onUpdate"); 

내가 메서드를 호출 해 로그의 결과가 의미가있다 볼 수 있습니다

내 SpeedDialAppWidgetProvider.onUpdate 방법의 기관이다.

speed_dial_appwidget.xml 파일은 다음과 같다 :

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

<ImageButton id="@+id/dial_icon" 
android:src="@drawable/speed_dial" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content"/> 
</LinearLayout> 

이 좀 도와 주시겠습니까? 사전에

감사합니다, 댄 답변에 대한


감사합니다.

귀하의 포인트가 유효합니다. 그런 다음 내 매니페스트에 추가했습니다.

<uses-permission android:name="android.permission.CALL_PHONE" /> 

하지만 도움이되지 않았습니다. 내가 할

유일한 오류는 다음과 같습니다

05-23 18:41:08.932: ERROR/ActivityThread(655): Failed to find provider info for android.server.checkin 
05-23 18:41:11.761: ERROR/ActivityThread(655): Failed to find provider info for android.server.checkin 
05-23 18:41:14.372: ERROR/ActivityThread(655): Failed to find provider info for android.server.checkin 
05-23 18:41:14.781: ERROR/ActivityThread(655): Failed to find provider info for android.server.checkin 
05-23 18:41:43.892: ERROR/ActivityThread(676): Performing pause of activity that is not resumed: {com.android.launcher/com.android.launcher.Launcher} 
05-23 18:41:43.892: ERROR/ActivityThread(676): java.lang.RuntimeException: Performing pause of activity that is not resumed: {com.android.launcher/com.android.launcher.Launcher} 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2809) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2797) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:2780) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread.access$2000(ActivityThread.java:112) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1699) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.os.Handler.dispatchMessage(Handler.java:99) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.os.Looper.loop(Looper.java:123) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at android.app.ActivityThread.main(ActivityThread.java:3948) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at java.lang.reflect.Method.invokeNative(Native Method) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at java.lang.reflect.Method.invoke(Method.java:521) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:782) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:540) 
05-23 18:41:43.892: ERROR/ActivityThread(676):  at dalvik.system.NativeStart.main(Native Method) 

이상한 것은입니다 : 심지어 사용-권한 태그를 추가하기 전에, 나는 충분한 권한을 가지고 있지에 대한 오류 메시지가 표시되지 않았다.

나는 이해할 수 없다.

+0

Daniele과 행운이 있었나요? 오늘도 같은 오류가납니다. –

답변

0

ACTION_CALL에는 권한이 필요하지 않을 수 있습니다. LogCat에 이것에 대한 경고가 있어야합니다 - adb logcat, DDMS 또는이 경고가 표시되는지 확인하기 위해 Eclipse의 DDMS 퍼스펙티브를 사용하십시오.

ACTION_DIAL으로 전환하는 것이 좋습니다. 특별한 허가가 필요하지 않지만 실제로 전화를 걸기보다는 전화 번호를 걸기 만하면됩니다.

관련 문제