Я новичок в разработке для 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)
Странно то, что даже до добавления тега использования-разрешения я не видел ни одного сообщения об ошибке из-за недостаточного разрешения.
Я не понимаю.