|
|
|
@ -37,15 +37,13 @@ public abstract class NoteWidgetProvider extends AppWidgetProvider {
|
|
|
|
|
NoteColumns.ID,
|
|
|
|
|
NoteColumns.BG_COLOR_ID,
|
|
|
|
|
NoteColumns.SNIPPET
|
|
|
|
|
};/*一个抽象类 NoteWidgetProvider,它继承自 AppWidgetProvider 类。
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
在这个抽象类中定义了一个公共静态常量数组 PROJECTION,该数组包含三个字符串元素,这些字符串元素对应着笔记应用中的一些数据库列名,包括笔记的 ID、背景颜色 ID 和摘录内容。*/
|
|
|
|
|
public static final int COLUMN_ID = 0;
|
|
|
|
|
public static final int COLUMN_BG_COLOR_ID = 1;
|
|
|
|
|
public static final int COLUMN_SNIPPET = 2;
|
|
|
|
|
|
|
|
|
|
public static final int COLUMN_ID = 0;// 笔记 ID 列在 PROJECTION 数组中的索引
|
|
|
|
|
public static final int COLUMN_BG_COLOR_ID = 1;// 笔记背景颜色 ID 列在 PROJECTION 数组中的索引
|
|
|
|
|
public static final int COLUMN_SNIPPET = 2;// 笔记摘录内容列在 PROJECTION 数组中的索引
|
|
|
|
|
|
|
|
|
|
private static final String TAG = "NoteWidgetProvider";// 日志输出标识符
|
|
|
|
|
private static final String TAG = "NoteWidgetProvider";
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onDeleted(Context context, int[] appWidgetIds) {
|
|
|
|
@ -57,28 +55,19 @@ public abstract class NoteWidgetProvider extends AppWidgetProvider {
|
|
|
|
|
NoteColumns.WIDGET_ID + "=?",
|
|
|
|
|
new String[] { String.valueOf(appWidgetIds[i])});
|
|
|
|
|
}
|
|
|
|
|
}/*这是 NoteWidgetProvider 抽象类中的一个公共方法 onDeleted(),它重写了父类 AppWidgetProvider 中的方法,用于处理小部件被删除的事件。
|
|
|
|
|
|
|
|
|
|
在该方法中,首先创建了一个 ContentValues 对象 values,并将 NoteColumns.WIDGET_ID 的值设为 AppWidgetManager.INVALID_APPWIDGET_ID,表示小部件已被删除。
|
|
|
|
|
|
|
|
|
|
然后遍历传入的 appWidgetIds 数组,将每个小部件的 NoteColumns.WIDGET_ID 列更新为 AppWidgetManager.INVALID_APPWIDGET_ID,以便将小部件与笔记数据库中的记录解除绑定。
|
|
|
|
|
|
|
|
|
|
具体地,使用 getContentResolver() 获取一个 ContentResolver 对象,调用 update() 方法对笔记数据库中的记录进行更新。更新的条件为 NoteColumns.WIDGET_ID + "=?",即 NoteColumns.WIDGET_ID 等于当前小部件 ID,更新的数据为 values 对象,其中 NoteColumns.WIDGET_ID 的值已经被设置为 AppWidgetManager.INVALID_APPWIDGET_ID。*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private Cursor getNoteWidgetInfo(Context context, int widgetId) {// 使用 getContentResolver() 方法获取 ContentResolver 对象,通过该对象进行对笔记数据库的查询操作
|
|
|
|
|
return context.getContentResolver().query(Notes.CONTENT_NOTE_URI, // 使用 query() 方法查询笔记数据库,返回一个 Cursor 对象
|
|
|
|
|
return context.getContentResolver().query(// 查询的 URI,笔记数据库中笔记的内容保存在该 URI 下
|
|
|
|
|
PROJECTION,
|
|
|
|
|
Notes.CONTENT_NOTE_URI,
|
|
|
|
|
private Cursor getNoteWidgetInfo(Context context, int widgetId) {
|
|
|
|
|
return context.getContentResolver().query(Notes.CONTENT_NOTE_URI,
|
|
|
|
|
PROJECTION,
|
|
|
|
|
NoteColumns.WIDGET_ID + "=? AND " + NoteColumns.PARENT_ID + "<>?",// 查询的列,即笔记 ID、笔记背景颜色 ID 和笔记摘录内容
|
|
|
|
|
new String[] { String.valueOf(widgetId), String.valueOf(Notes.ID_TRASH_FOLER) },//查询的条件,即笔记关联的小部件 ID 以及笔记的父 ID 不为回收站的笔记
|
|
|
|
|
null);// 排序方式,这里为 null 表示不排序
|
|
|
|
|
NoteColumns.WIDGET_ID + "=? AND " + NoteColumns.PARENT_ID + "<>?",
|
|
|
|
|
new String[] { String.valueOf(widgetId), String.valueOf(Notes.ID_TRASH_FOLER) },
|
|
|
|
|
null);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
|
|
|
|
|
update(context, appWidgetManager, appWidgetIds, false);
|
|
|
|
|
}/*这是 NoteWidgetProvider 抽象类中的一个受保护的方法 update(),它接受一个 Context 对象、一个 AppWidgetManager 对象和一个整型数组 appWidgetIds 作为参数,并在方法中调用了另一个同名方法。*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds,
|
|
|
|
|
boolean privacyMode) {
|
|
|
|
@ -133,21 +122,11 @@ public abstract class NoteWidgetProvider extends AppWidgetProvider {
|
|
|
|
|
appWidgetManager.updateAppWidget(appWidgetIds[i], rv);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}/*这是 `NoteWidgetProvider` 抽象类中的一个私有方法 `update()`,它接受一个 `Context` 对象、一个 `AppWidgetManager` 对象、一个整型数组 `appWidgetIds` 和一个布尔型参数 `privacyMode` 作为参数。该方法用于更新小部件的显示内容和点击事件。
|
|
|
|
|
|
|
|
|
|
方法中首先对 `appWidgetIds` 数组进行遍历,对于每个小部件 ID,如果它不等于 `AppWidgetManager.INVALID_APPWIDGET_ID`,则执行以下操作:
|
|
|
|
|
|
|
|
|
|
- 获取小部件的默认背景 ID,以及一个空的摘录字符串。
|
|
|
|
|
- 创建一个 `NoteEditActivity` 的意图,并将小部件 ID、小部件类型等信息作为附加数据放入其中。
|
|
|
|
|
- 调用 `getNoteWidgetInfo()` 方法获取与当前小部件关联的笔记信息,并根据结果设置摘录字符串、背景 ID 和意图的操作类型。
|
|
|
|
|
- 根据背景 ID 创建一个 `RemoteViews` 对象,并将背景图片、背景 ID 和点击事件所需的 `PendingIntent` 添加到其中。
|
|
|
|
|
- 调用 `AppWidgetManager` 的 `updateAppWidget()` 方法更新小部件的显示内容。
|
|
|
|
|
|
|
|
|
|
如果 `privacyMode` 为 `true`,则小部件将显示 "隐私模式",并且点击小部件将启动 `NotesListActivity`;否则,小部件将显示与笔记关联的摘录字符串,点击小部件将启动 `NoteEditActivity`。*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected abstract int getBgResourceId(int bgId);//用于获取小部件的背景资源 ID。
|
|
|
|
|
protected abstract int getBgResourceId(int bgId);
|
|
|
|
|
|
|
|
|
|
protected abstract int getLayoutId();//用于获取小部件的布局资源 ID。
|
|
|
|
|
protected abstract int getLayoutId();
|
|
|
|
|
|
|
|
|
|
protected abstract int getWidgetType();//用于获取小部件的类型。
|
|
|
|
|
protected abstract int getWidgetType();
|
|
|
|
|
}
|
|
|
|
|