Androidがシステムカレンダーにスケジュールイベントを追加
12804 ワード
まとめ
プロジェクト開発では、予約アラート、タイミングアラートのニーズがある場合、システムカレンダーを使用してアラートを支援することができます.システムカレンダーにイベントを書き込み、アラーム方式(目覚まし時計)を設定することで、時間自動アラームの機能を実現する.
メリット:アラート機能はシステムカレンダーに渡されるため、アプリケーションが殺されることはなく、時間通りにアラートされます.悪いところ:システムカレンダーは注意する時、直接私たちのappに戻ることができなくて、注意文案の中でurlを加えて、ブラウザを呼び出して中継します;
一般に、システムカレンダーへのイベントの読み書きを実現する:1.カレンダーの読み書き権限が必要です.カレンダーアカウントがない場合は、まずアカウント3を作成する必要があります.カレンダーイベントの追加削除・変更、アラート機能の実現
購買依頼権限
プロジェクトでシステムカレンダーを呼び出し、スケジュールイベントを挿入するために、まずAndroidManifest.xmlファイルに関連する権限を追加します.次のようにします.
カレンダー関連uriの追加
システムcalendar content provider関連uri、以下Android 2.2バージョン以降のuriは、これまでは書かなかった
カレンダーアカウントのチェックと追加
1.既存のアカウントがあるかどうかを確認します.存在する場合はアカウントidを返し、そうでない場合は-1を返します.
2.アカウントを追加します.アカウントの作成に成功するとアカウントidが返されます.そうしないと-1が返されます.
3.アカウントを取得します.口座が存在しない場合は先に口座を作成し、口座には取得口座idが存在する.アカウントの取得に成功してアカウントidが返されました.そうしないと-1が返されます.
カレンダーイベント、スケジュールの追加
カレンダーイベント、スケジュールの削除
設定したtitleに基づいて検索および削除
これにより、システムカレンダーにアカウントを検索、追加し、スケジュールイベントを追加、削除、更新し、ユーザーに注意を促す方法を追加することができます.もう一度説明しますが、システムカレンダーがアラートをポップアップしたときに自分のappに直接戻ることはできません.descriptionフィールドを設定したテキストにhtmlを追加し、ユーザーがhtmlをクリックしたときにブラウザを呼び出し、ページから自分のappに戻る必要があります.
プロジェクト開発では、予約アラート、タイミングアラートのニーズがある場合、システムカレンダーを使用してアラートを支援することができます.システムカレンダーにイベントを書き込み、アラーム方式(目覚まし時計)を設定することで、時間自動アラームの機能を実現する.
メリット:アラート機能はシステムカレンダーに渡されるため、アプリケーションが殺されることはなく、時間通りにアラートされます.悪いところ:システムカレンダーは注意する時、直接私たちのappに戻ることができなくて、注意文案の中でurlを加えて、ブラウザを呼び出して中継します;
一般に、システムカレンダーへのイベントの読み書きを実現する:1.カレンダーの読み書き権限が必要です.カレンダーアカウントがない場合は、まずアカウント3を作成する必要があります.カレンダーイベントの追加削除・変更、アラート機能の実現
購買依頼権限
プロジェクトでシステムカレンダーを呼び出し、スケジュールイベントを挿入するために、まずAndroidManifest.xmlファイルに関連する権限を追加します.次のようにします.
"android.permission.READ_CALENDAR" />
"android.permission.WRITE_CALENDAR" />
カレンダー関連uriの追加
システムcalendar content provider関連uri、以下Android 2.2バージョン以降のuriは、これまでは書かなかった
private static String CALANDER_URL = "content://com.android.calendar/calendars";
private static String CALANDER_EVENT_URL = "content://com.android.calendar/events";
private static String CALANDER_REMIDER_URL = "content://com.android.calendar/reminders";
カレンダーアカウントのチェックと追加
1.既存のアカウントがあるかどうかを確認します.存在する場合はアカウントidを返し、そうでない場合は-1を返します.
private static int checkCalendarAccount(Context context) {
Cursor userCursor = context.getContentResolver().query(Uri.parse(CALANDER_URL), null, null, null, null);
try {
if (userCursor == null)//
return -1;
int count = userCursor.getCount();
if (count > 0) {// , id
userCursor.moveToFirst();
return userCursor.getInt(userCursor.getColumnIndex(CalendarContract.Calendars._ID));
} else {
return -1;
}
} finally {
if (userCursor != null) {
userCursor.close();
}
}
}
2.アカウントを追加します.アカウントの作成に成功するとアカウントidが返されます.そうしないと-1が返されます.
private static String CALENDARS_NAME = "test";
private static String CALENDARS_ACCOUNT_NAME = "[email protected]";
private static String CALENDARS_ACCOUNT_TYPE = "com.android.exchange";
private static String CALENDARS_DISPLAY_NAME = " ";
private static long addCalendarAccount(Context context) {
TimeZone timeZone = TimeZone.getDefault();
ContentValues value = new ContentValues();
value.put(CalendarContract.Calendars.NAME, CALENDARS_NAME);
value.put(CalendarContract.Calendars.ACCOUNT_NAME, CALENDARS_ACCOUNT_NAME);
value.put(CalendarContract.Calendars.ACCOUNT_TYPE, CALENDARS_ACCOUNT_TYPE);
value.put(CalendarContract.Calendars.CALENDAR_DISPLAY_NAME, CALENDARS_DISPLAY_NAME);
value.put(CalendarContract.Calendars.VISIBLE, 1);
value.put(CalendarContract.Calendars.CALENDAR_COLOR, Color.BLUE);
value.put(CalendarContract.Calendars.CALENDAR_ACCESS_LEVEL, CalendarContract.Calendars.CAL_ACCESS_OWNER);
value.put(CalendarContract.Calendars.SYNC_EVENTS, 1);
value.put(CalendarContract.Calendars.CALENDAR_TIME_ZONE, timeZone.getID());
value.put(CalendarContract.Calendars.OWNER_ACCOUNT, CALENDARS_ACCOUNT_NAME);
value.put(CalendarContract.Calendars.CAN_ORGANIZER_RESPOND, 0);
Uri calendarUri = Uri.parse(CALANDER_URL);
calendarUri = calendarUri.buildUpon()
.appendQueryParameter(CalendarContract.CALLER_IS_SYNCADAPTER, "true")
.appendQueryParameter(CalendarContract.Calendars.ACCOUNT_NAME, CALENDARS_ACCOUNT_NAME)
.appendQueryParameter(CalendarContract.Calendars.ACCOUNT_TYPE, CALENDARS_ACCOUNT_TYPE)
.build();
Uri result = context.getContentResolver().insert(calendarUri, value);
long id = result == null ? -1 : ContentUris.parseId(result);
return id;
}
3.アカウントを取得します.口座が存在しない場合は先に口座を作成し、口座には取得口座idが存在する.アカウントの取得に成功してアカウントidが返されました.そうしないと-1が返されます.
// ,
private static int checkAndAddCalendarAccount(Context context){
int oldId = checkCalendarAccount(context);
if( oldId >= 0 ){
return oldId;
}else{
long addId = addCalendarAccount(context);
if (addId >= 0) {
return checkCalendarAccount(context);
} else {
return -1;
}
}
}
カレンダーイベント、スケジュールの追加
public static void addCalendarEvent(Context context,String title, String description, long beginTime){
// id
int calId = checkAndAddCalendarAccount(context);
if (calId < 0) {
// id ,
return;
}
ContentValues event = new ContentValues();
event.put("title", title);
event.put("description", description);
// id
event.put("calendar_id", calId);
Calendar mCalendar = Calendar.getInstance();
mCalendar.setTimeInMillis(beginTime);//
long start = mCalendar.getTime().getTime();
mCalendar.setTimeInMillis(start + ONE_HOUR);//
long end = mCalendar.getTime().getTime();
event.put(CalendarContract.Events.DTSTART, start);
event.put(CalendarContract.Events.DTEND, end);
event.put(CalendarContract.Events.HAS_ALARM, 1);//
event.put(CalendarContract.Events.EVENT_TIMEZONE, "Asia/Shanghai"); // , ,
//
Uri newEvent = context.getContentResolver().insert(Uri.parse(CALANDER_EVENT_URL), event);
if (newEvent == null) {
//
return;
}
//
ContentValues values = new ContentValues();
values.put(CalendarContract.Reminders.EVENT_ID, ContentUris.parseId(newEvent));
// 10
values.put(CalendarContract.Reminders.MINUTES, 10);
values.put(CalendarContract.Reminders.METHOD, CalendarContract.Reminders.METHOD_ALERT);
Uri uri = context.getContentResolver().insert(Uri.parse(CALANDER_REMIDER_URL), values);
if(uri == null) {
//
return;
}
}
カレンダーイベント、スケジュールの削除
設定したtitleに基づいて検索および削除
public static void deleteCalendarEvent(Context context,String title){
Cursor eventCursor = context.getContentResolver().query(Uri.parse(CALANDER_EVENT_URL), null, null, null, null);
try {
if (eventCursor == null)//
return;
if (eventCursor.getCount() > 0) {
// , title title
for (eventCursor.moveToFirst(); !eventCursor.isAfterLast(); eventCursor.moveToNext()) {
String eventTitle = eventCursor.getString(eventCursor.getColumnIndex("title"));
if (!TextUtils.isEmpty(title) && title.equals(eventTitle)) {
int id = eventCursor.getInt(eventCursor.getColumnIndex(CalendarContract.Calendars._ID));// id
Uri deleteUri = ContentUris.withAppendedId(Uri.parse(CALANDER_EVENT_URL), id);
int rows = context.getContentResolver().delete(deleteUri, null, null);
if (rows == -1) {
//
return;
}
}
}
}
} finally {
if (eventCursor != null) {
eventCursor.close();
}
}
}
これにより、システムカレンダーにアカウントを検索、追加し、スケジュールイベントを追加、削除、更新し、ユーザーに注意を促す方法を追加することができます.もう一度説明しますが、システムカレンダーがアラートをポップアップしたときに自分のappに直接戻ることはできません.descriptionフィールドを設定したテキストにhtmlを追加し、ユーザーがhtmlをクリックしたときにブラウザを呼び出し、ページから自分のappに戻る必要があります.