之前有一篇是初探 Android App Widget 的文章,今天继续对上一例子进行扩展,并完成了一个小项目,直接可以拿来使用。上篇文章地址:Android 桌面组件【widget】初探 ,未接触过app Widget 的朋友可以去看一下,有助于理解本篇代码讲解。
本篇完成项目名称为:【心情记录器】
可将你的心情讯录并用桌面组件的形式展示于桌面上,并有丰富的表情可供选择并加载在桌面上,此功能类似于QQ上的各性签名,虽然手机是自己的但我们用的是Android 手机,难免会有朋友拿来把玩,此时可以看到手机主人的心情状况不是很好吗?或许可以自己把一些不满的想法偷偷用心情记录下来也可以。注:此功能并不提供多个心情保存,只能保存一个,如果需要的朋友可以在后文为我提建议,当然我觉得多个心情保存个人不想要这个功能。。如果要的话请留言。
好了,废话了好多,先让大家看下图:
Tip:这个小东西完全 是App widget 桌面组件,所以必须通过长按桌面或者点击menu调出来。
上篇app Widget 的DEMO 只是为TextView 添加点击事件,本篇将换另外的做法。通过点击布局弹出一个Activity 的操作界面,之后在这个操作界面进行表情的选择和心情的保存,那么如何通过点击打开一个Activity 界面呢?
- 方法一:
在我们组件的updateAppWidget 中注册一个广播,为 TextView 添加 一个点击的广播,之后在onReceive 接收广播 中如下代码:
Intent intn
=
new
Intent(context, update.
class
);
intn.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intn);
通过为Intent 重新设置一个新的任务来打开Activity 此法即可启动一个Activity ,当然这种做法我是不建议的,因为重复了一个动作,具体怎么重复下文会具体告知大家。为TextView 注册广播可参考上面给出的链接,上文有介绍,在此就不多做介绍。
- 方法二:
此方法正是想告知大家如何重复的,即然我们可以为其注册广播那我们为什么不索性就为其做广播点击跳转?参考代码如下:
Intent intentClick
=
new
Intent(context, update.
class
);
PendingIntent pendingIntent
=
PendingIntent.getActivity(context,
0
,
intentClick,
0
);
rv.setOnClickPendingIntent(R.id.layout, pendingIntent);
通过这里的设置,上文将不用再去接收广播也可以达到想要的效果。
下面是通过点击打开 Activity 操作界面的效果图,在这里有点不好意思啦,因为即兴画的很丑,大家就将就着看吧,主要是理解App widget 的写法
如何通过点击保存的与app Widget 做动态交互呢?来看下面这段代码
RemoteViews views
=
new
RemoteViews(update.
this
.getPackageName(), R.layout.main);
views.setTextViewText(R.id.TextView01, text);
views.setImageViewResource(R.id.ImageView01, util.image[index]);
ComponentName widget
=
new
ComponentName(update.
this
,
widgetProvider.
class
);
AppWidgetManager manager
=
AppWidgetManager
.getInstance(update.
this
);
manager.updateAppWidget(widget, views);
这里同样还是用到发RemoteViews 来接收值的变化,然后通过AppWidgetManager 这个桌面组件管理器去改新RemoteViews 。由于我们要时时刻保存用户记录的数据,这里只是用到了键值对保存。
下面贴出代码:
package
com.terry;
import
android.app.Activity;
import
android.appwidget.AppWidgetManager;
import
android.content.ComponentName;
import
android.content.SharedPreferences;
import
android.os.Bundle;
import
android.view.View;
import
android.view.View.OnClickListener;
import
android.widget.AdapterView;
import
android.widget.ArrayAdapter;
import
android.widget.Button;
import
android.widget.EditText;
import
android.widget.ImageView;
import
android.widget.RemoteViews;
import
android.widget.Spinner;
import
android.widget.AdapterView.OnItemSelectedListener;
public
class
update
extends
Activity {
private
EditText mEditText;
private
Button mButton;
private
Spinner mSpinner;
private
int
index
=
0
;
@Override
protected
void
onCreate(Bundle savedInstanceState) {
//
TODO Auto-generated method stub
super
.onCreate(savedInstanceState);
setContentView(R.layout.update);
mEditText
=
(EditText) findViewById(R.id.EditText01);
mButton
=
(Button) findViewById(R.id.Button01);
mSpinner
=
(Spinner) findViewById(R.id.Spinner01);
final
ImageView iv
=
(ImageView) findViewById(R.id.ImageView01);
ArrayAdapter
<
String
>
adpter
=
new
ArrayAdapter
<
String
>
(
this
,
android.R.layout.simple_spinner_dropdown_item, util.text);
adpter
.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
mSpinner.setAdapter(adpter);
SharedPreferences settings
=
getSharedPreferences(
"
settinginfo
"
,
Activity.MODE_PRIVATE);
index
=
settings.getInt(
"
imageState
"
,
0
);
mEditText.setText(settings.getString(
"
heart
"
,
""
));
iv.setImageResource(util.image[index]);
mSpinner.setSelection(index);
mSpinner.setOnItemSelectedListener(
new
OnItemSelectedListener() {
@Override
public
void
onItemSelected(AdapterView
<?>
arg0, View arg1,
int
arg2,
long
arg3) {
//
TODO Auto-generated method stub
index
=
arg2;
iv.setImageResource(util.image[index]);
}
@Override
public
void
onNothingSelected(AdapterView
<?>
arg0) {
//
TODO Auto-generated method stub
}
});
mButton.setOnClickListener(
new
OnClickListener() {
@Override
public
void
onClick(View v) {
//
TODO Auto-generated method stub
String text
=
mEditText.getText().toString();
if
(text.equals(
""
)) {
return
;
}
SharedPreferences shared
=
getSharedPreferences(
"
settinginfo
"
,
Activity.MODE_PRIVATE);
SharedPreferences.Editor editor
=
shared.edit();
editor.putInt(
"
imageState
"
, index);
editor.putString(
"
heart
"
, text);
editor.commit();
RemoteViews views
=
new
RemoteViews(update.
this
.getPackageName(), R.layout.main);
views.setTextViewText(R.id.TextView01, text);
views.setImageViewResource(R.id.ImageView01, util.image[index]);
ComponentName widget
=
new
ComponentName(update.
this
,
widgetProvider.
class
);
AppWidgetManager manager
=
AppWidgetManager
.getInstance(update.
this
);
manager.updateAppWidget(widget, views);
update.
this
.finish();
}
});
}
}
由于组件每创建一次都调用了一次updateAppWidget 这个方法,故此方法也必须去获取键值对
package
com.terry;
import
android.app.Activity;
import
android.app.PendingIntent;
import
android.appwidget.AppWidgetManager;
import
android.appwidget.AppWidgetProvider;
import
android.content.ComponentName;
import
android.content.Context;
import
android.content.Intent;
import
android.content.SharedPreferences;
import
android.widget.RemoteViews;
import
android.widget.Toast;
public
class
widgetProvider
extends
AppWidgetProvider {
private
static
RemoteViews rv;
@Override
public
void
onUpdate(Context context, AppWidgetManager appWidgetManager,
int
[] appWidgetIds) {
//
TODO Auto-generated method stub
final
int
N
=
appWidgetIds.length;
for
(
int
i
=
0
; i
<
N; i
++
) {
int
appWidgetId
=
appWidgetIds[i];
updateAppWidget(context, appWidgetManager, appWidgetId);
}
}
@Override
public
void
onReceive(Context context, Intent intent) {
//
TODO Auto-generated method stub
super
.onReceive(context, intent);
}
public
static
void
updateAppWidget(Context context,
AppWidgetManager appWidgeManger,
int
appWidgetId) {
rv
=
new
RemoteViews(context.getPackageName(), R.layout.main);
SharedPreferences shared
=
context.getSharedPreferences(
"
settinginfo
"
,
Activity.MODE_PRIVATE);
//
util.index = settings.getInt("imageState", 0);
//
mEditText.setText(settings.getString("heart", ""));
rv.setTextViewText(R.id.TextView01, shared.getString(
"
heart
"
, context
.getResources().getString(R.string.load)));
rv.setImageViewResource(R.id.ImageView01, util.image[shared.getInt(
"
imageState
"
,
0
)]);
Intent intentClick
=
new
Intent(context, update.
class
);
PendingIntent pendingIntent
=
PendingIntent.getActivity(context,
0
,
intentClick,
0
);
rv.setOnClickPendingIntent(R.id.layout, pendingIntent);
appWidgeManger.updateAppWidget(appWidgetId, rv);
}
}
Tip:上面所有知识点,之前所有文章都有提到,有不懂的地方可以自行做参考。