私はアンドロイドカレンダーにイベントを格納するために使用される列のリストを抽出しました。ここ リスト:
[0] "originalEvent"(ID = 830007842672)
[1] "availabilityStatus"(ID = 830007842752)
[2] "ownerAccount"(ID = 830007842840)
[3 "_sync_account_type"(ID = 830007842920)
[4] "可視性"(ID = 830007843008)
[5] "RRULE"(ID = 830007843080)
[6] "lastDate"(ID = 830007843144)
[7] "hasAlarm"(id = 830007843216)
[8] "guestsCanModify"(id = 830007843288) [9] "guestsCanSeeGuests"(ID = 830007843376)
[10] "exrule"(ID = 830007843464)
[11] "RDATE"(ID = 830007843528)
[12] "透明"(ID = 830007843592 )
[13] "タイムゾーン"(ID = 830007843672)
[14] "選択"(ID = 830007843744)
[15] "DTSTART"(ID = 830007843816) [16] "タイトル"(ID = 830007843888)
[17] "_sync_time"(ID = 830007843952)
[18] "_id"(ID = 830007844024) [19] "hasAttendeeData"(ID = 830007844088) [20]「_sync_i D "(ID = 830007844176)
[21] "commentsUri"(ID = 830007844248) [22] "説明"(ID = 830007844328) [23] "htmlUri"(ID = 830007844408) [24]" _sync_account次に、 "(ID = 830007844480)
[25] "_sync_version"(ID = 830007844560)
[26] "hasExtendedProperties"(ID = 830007844640)
[27] "CALENDAR_ID"(ID = 830007844736)
私のイベントの新しいイベントIDを取得したい場合:
public static long getNewEventId(ContentResolver cr, Uri cal_uri){
Uri local_uri = cal_uri;
if(cal_uri == null){
local_uri = Uri.parse(calendar_uri+"events");
}
Cursor cursor = cr.query(local_uri, new String [] {"MAX(_id) as max_id"}, null, null, "_id");
cursor.moveToFirst();
long max_val = cursor.getLong(cursor.getColumnIndex("max_id"));
return max_val+1;
}
およびINSERTイベントのため:
public void insertDomainEntry(Date exp_date, String name, long event_id){
SQLiteDatabase db = getWritableDatabase();
ContentValues values = new ContentValues();
values.put("exp_date", exp_date.getTime()/1000);
values.put("event_id", event_id);
values.put("domainname", name);
db.insertOrThrow("domains_events", null, values);
}
ソリューションは、おそらくこれは非常に良い解決策はない場合でも、動作するように思われます。getNextEventIdの目的は、イベントテーブルに新しいイベントエントリを作成することです
EDIT 02/2015 、このメソッドの使用方法と、ここでコード:
@Override
public void onItemClick(AdapterView<?> adapter, View curview, int position,
long id) {
WhoisEntry entry = this.adapter.getItem(position);
long event_id = CalendarUtils.getNewEventId(getContentResolver(), null);
Toast.makeText(getApplicationContext(), "Domain: " + entry.getDomainName(),
Toast.LENGTH_SHORT).show();
Intent intent = new Intent(Intent.ACTION_EDIT);
intent.setType("vnd.android.cursor.item/event");
intent.putExtra("beginTime", entry.getExpiration().getTime());
intent.putExtra("_id", event_id);
intent.putExtra("allDay", false);
intent.putExtra("endTime", entry.getExpiration().getTime()+60*30);
intent.putExtra("title", "Expiration of " + entry.getDomainName());
startActivity(intent);
database.insertDomainEntry(entry.getExpiration(),
entry.getDomainName(), event_id);
}
更新09/2015
コメントでリクエストしたとおり、私はカレンダーURIを取得する方法を追加します(カレンダーが保存されている場所であり、アプリケーションは推測しようとしているすべての可能なカレンダーパスを検索します)
public static String getCalendarUriBase(Activity act) {
String calendarUriBase = null;
Uri calendars = Uri.parse("content://calendar/calendars");
Cursor managedCursor = null;
try {
managedCursor = act.getContentResolver().query(calendars,
null, null, null, null);
} catch (Exception e) {
}
if (managedCursor != null) {
calendarUriBase = "content://calendar/";
} else {
calendars = Uri.parse("content://com.android.calendar/calendars");
try {
managedCursor = act.getContentResolver().query(calendars,
null, null, null, null);
} catch (Exception e) {
}
if (managedCursor != null) {
calendarUriBase = "content://com.android.calendar/";
}
}
calendar_uri= calendarUriBase;
return calendarUriBase;
}
endTimeを現在の時刻に設定してもよろしいですか? – toto2
ops:Dノー!ちょうど私の気晴らし:D – Ivan
あなたがICSのために開発している場合は、カレンダーのための新しいAPIがあります。この[blog](http://android-developers.blogspot.com/2011/10/ics-and-non-public-apis.html)を参照してください。 – toto2