37

私はすでに人の名前と電話番号で日付を保存する1つのAndroidアプリケーションを実行しました。

次に、このアプリケーション用に1つのウィジェットを開発して、今日(日付、人名、電話番号)をボタンで表示する必要があります。

要件:

  1. アプリとウィジェットを備えた単一のアプリケーション。
  2. ウィジェットにあるボタンをクリックすると、アプリケーションが起動します。
  3. ウィジェットデータは常に私のアプリと同期する必要があります-今日の日(人5とアプリケーションはさらに5人を追加し、ウィジェットは10人のデータを表示します)
  4. このウィジェットを設計するにはどうすればよいですか?ガイドラインはありますか?水平ScrollViewを使用する必要があります。

簡単なウィジェットのデモを行いましたが、アプリケーションと同期する方法がわかりません。

あなたの経験を共有し、私のウィジェットとアプリケーションについていくつかのアイデアを教えてください。

4

2 に答える 2

36

ウィジェットの作成と構成

ウィジェットを登録するには、android.appwidget.action.APPWIDGET_UPDATE アクションのインテント フィルターを使用して BroadcastReceiver を作成します。

<receiver
       android:icon="@drawable/icon"
       android:label="Example Widget"
       android:name="MyWidgetProvider" >
       <intent-filter >
            <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
       </intent-filter>

       <meta-data
          android:name="android.appwidget.provider"
          android:resource="@xml/widget_info" />
</receiver> 

You also specify the meta-data for the widget via the android:name="android.appwidget.provider attribute. このメタデータによって参照される構成ファイルには、ウィジェットの構成設定が含まれています。たとえば、更新インターフェイスが含まれている場合、ウィジェットのサイズと初期レイアウト。

/res/drawable ディレクトリに新しいファイル myshape.xml を作成します。このファイルは、ウィジェットで使用する背景を定義します。

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
           android:shape="rectangle" >

    <stroke
        android:width="2dp"
        android:color="#FFFFFFFF" />

    <gradient
        android:angle="225"
        android:endColor="#DD2ECCFA"
        android:startColor="#DD000000" />

    <corners
        android:bottomLeftRadius="7dp"
        android:bottomRightRadius="7dp"
        android:topLeftRadius="7dp"
        android:topRightRadius="7dp" />

</shape> 

widget_layout.xmlres/layout フォルダ配下に以下のファイルを定義します。

<?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
          android:id="@+id/layout"
          android:layout_width="match_parent"
          android:layout_height="match_parent"
          android:layout_margin="8dip"
          android:background="@drawable/myshape" >

        <TextView
            android:id="@+id/update"
            style="@android:style/TextAppearance.Medium"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_gravity="center"
            android:gravity="center_horizontal|center_vertical"
            android:layout_margin="4dip"
            android:text="Static Text" >
        </TextView>

    </LinearLayout> 

今すぐクラスを作ります。

public class MyWidgetProvider extends AppWidgetProvider {

  private static final String ACTION_CLICK = "ACTION_CLICK";  

     @Override
  public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {

    // Get all ids
    ComponentName thisWidget = new ComponentName(context,
        MyWidgetProvider.class);
    int[] allWidgetIds = appWidgetManager.getAppWidgetIds(thisWidget);
    for (int widgetId : allWidgetIds) {
      // Create some random data
      int number = (new Random().nextInt(100));

      RemoteViews remoteViews = new RemoteViews(context.getPackageName(),
          R.layout.widget_layout);
      Log.w("WidgetExample", String.valueOf(number));
      // Set the text
      remoteViews.setTextViewText(R.id.update, String.valueOf(number));

      // Register an onClickListener
      Intent intent = new Intent(context, MyWidgetProvider.class);

      intent.setAction(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
      intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, appWidgetIds);

      PendingIntent pendingIntent = PendingIntent.getBroadcast(context,
          0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
      remoteViews.setOnClickPendingIntent(R.id.update, pendingIntent);
      appWidgetManager.updateAppWidget(widgetId, remoteViews);
    }
  }
于 2013-03-05T10:25:22.897 に答える
8

私は何とか解決策を得た数日を見つけています。だから私は私の考えを共有しています。

このサイトは私にとって非常に役に立ちました。

http://kasperholtze.com/android/how-to-make-a-simple-android-widget/

私はいくつかの変更を加え、自分の仕事をしました。

要件ソリューション:

1. Receiver を作成し、このようにマニフェスト許可に入れます。

<receiver
        android:name=".WatchWidget"
        android:label="WatchWidget" >
        <intent-filter>
            <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
        </intent-filter>
        <meta-data
            android:name="android.appwidget.provider"
            android:resource="@xml/watch_widget_provider" />
    </receiver>

2.私の側では、TextViewのトップクリックが必要なので、TextView IDを使用して作成できますonUpdate()

    remoteViews = new RemoteViews(context.getPackageName(),R.layout.widget_lay);

    Intent intent = new Intent(context, TestActivity.class);
    intent.setAction("callActivity");
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);
    remoteViews.setOnClickPendingIntent(R.id.widget_textview, pendingIntent); 
    appWidgetManager.updateAppWidget(new ComponentName(context,WatchWidget.class), remoteViews);

3.データベースを呼び出してレコードを取得し、表示したい。さて、更新について質問しますか?

そのため、タイマー クラスを使用し、1000 秒ごとに実行しました。これは、ウィジェットが常に 30 分更新されるためです (可能性があります)。

@Override
public void onUpdate( final Context context, final AppWidgetManager appWidgetManager, final int[] appWidgetIds )
{

    this.appWidgetManager = appWidgetManager;
    try {
        Timer timer = new Timer();
        timer.scheduleAtFixedRate(new MyTime(context, appWidgetManager,appWidgetIds), 1, 1000);

    } catch (Exception e) {
        System.out.println("Exception:");
    }
    updateSwitch1(context, appWidgetManager, appWidgetIds[0]);

}

クエリがある場合は、コメントを入力してください。この回答を役立つように完全にサポートしてくれたすべての人に感謝します。

于 2013-02-26T13:24:37.147 に答える