如何在单个应用程序中使用应用程序小部件创建 android 应用程序
Posted
技术标签:
【中文标题】如何在单个应用程序中使用应用程序小部件创建 android 应用程序【英文标题】:How to create android app with app widget in single application 【发布时间】:2013-02-08 21:49:31 【问题描述】:我已经做了一个 android 应用程序,它用人名和电话号码存储日期。
现在我必须为这个应用程序开发一个小部件,用按钮显示今天的(日期、人名和电话号码)。
要求:
-
带有应用程序和小部件的单一应用程序。
当我单击小部件中的按钮时,它将启动我的
申请。
小部件数据应始终与我的应用程序同步 - 当今天的
天(第 5 个人和应用程序再添加 5 个人,然后小部件显示
10 人数据)
如何设计这个小部件?有什么指导方针吗?我必须使用
水平滚动视图。
我做了一个简单的小部件演示,但我不知道如何将它与我的应用程序同步。
请分享您的经验,并提供一些关于我的小部件和应用程序的想法。
【问题讨论】:
我花了一整天的时间来解决第一个和第二个要求,然后就完成了。 vogella.com/articles/androidWidgets/article.html 看到这个链接 【参考方案1】:创建和配置小部件
要注册一个小部件,您需要为 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>
您还可以通过 android:name="android.appwidget.provider 属性为小部件指定元数据。此元数据引用的配置文件包含小部件的配置设置。如果包含例如更新界面,小部件的大小和初始布局。
在 /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:
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>
在res/layout文件夹下定义如下widget_layout.xml
文件。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/layout"
android:layout_
android:layout_
android:layout_margin="8dip"
android:background="@drawable/myshape" >
<TextView
android:id="@+id/update"
style="@android:style/TextAppearance.Medium"
android:layout_
android:layout_
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);
【讨论】:
你忘记了 xml/widget_info 文件,例如:<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:initialLayout="@layout/widget_layout" android:minHeight="146dp" android:minWidth="146dp" android:updatePeriodMillis="1000000"/>
【参考方案2】:
我发现几天我以某种方式找到了解决方案。所以我分享我的想法。
这个网站对我很有用。
http://kasperholtze.com/android/how-to-make-a-simple-android-widget/
我做了一些改变并完成了我的工作。
需求解决方案:
1.像这样制作Receiver并放入manifest权限。
<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点击所以可以使用onUpdate()
中的TextView id。
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]);
如果有任何疑问,请发表评论,并感谢所有给予我全力支持以使此答案有用的人。
【讨论】:
嘿,我为此链接发布了一个问题,请帮助我***.com/questions/18376263/… 教程链接给出 500 Internal Server Error。以上是关于如何在单个应用程序中使用应用程序小部件创建 android 应用程序的主要内容,如果未能解决你的问题,请参考以下文章