Android - я не могу сделать виджет кликабельным для запуска намерения - PullRequest
0 голосов
/ 24 мая 2010

Я новичок в разработке для Android.

Я разработал очень простой виджет, который должен был взаимодействовать с пользователем через ImageButton.

Сейчас я пытаюсь сделать следующее. Когда пользователь нажимает кнопку (после добавления виджета на главный экран), я хочу, чтобы телефон набрал определенный номер телефона. Этакий скоростной набор для домашнего экрана.

К сожалению, когда я нажимаю кнопку, ничего не происходит.

Это тело моего метода SpeedDialAppWidgetProvider.onUpdate:

 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");

Я вижу, что метод вызывается, и результат логирования имеет смысл.

Файл 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>

Не могли бы вы помочь мне с этим?

Заранее спасибо, Dan


Спасибо за ваш ответ.

Ваша точка зрения верна. Затем я добавил это в свой манифест:

<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)

Странно то, что даже до добавления тега использования-разрешения я не видел ни одного сообщения об ошибке из-за недостаточного разрешения.

Я не понимаю.

1 Ответ

0 голосов
/ 24 мая 2010

ACTION_CALL требуется специальное разрешение, которого у вас может не быть. В LogCat должно быть предупреждение об этом - используйте adb logcat, DDMS или перспективу DDMS в Eclipse, чтобы увидеть, появляется ли это предупреждение.

Вы можете вместо этого переключиться на ACTION_DIAL, для чего не требуется специального разрешения, хотя он просто вводит номер телефона в номеронабиратель, а не фактически выполняет звонок.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...