我试图使用Android的新日历API来读取所有今天的日历事件。 我有麻烦找上了数据库查询正确的选择返回所有事件。 这一切似乎经常性和全天的事件留出了选择的。 什么选择ARGS会允许我从日历API获得所有在今天的事件?
这是我当前的尝试:
Cursor cur = null;
String selection = "((" + CalendarContract.Events.DTSTART
+ " >= ?) AND (" + CalendarContract.Events.DTEND + " <= ?))";
Time t = new Time();
t.setToNow();
String dtStart = Long.toString(t.toMillis(false));
t.set(59, 59, 23, t.monthDay, t.month, t.year);
String dtEnd = Long.toString(t.toMillis(false));
String[] selectionArgs = new String[] { dtStart, dtEnd };
cur = c.getContentResolver().query(CalendarContract.Events.CONTENT_URI,
null, selection, selectionArgs, null);
我不确定如何拓宽选择或增加它来获得经常性事件和全天事件。 任何帮助,将不胜感激。
为了让所有事件的今天,包括经常性的活动,您需要使用实例表,即
Uri.Builder eventsUriBuilder = CalendarContract.Instances.CONTENT_URI
.buildUpon();
ContentUris.appendId(eventsUriBuilder, timeNow);
ContentUris.appendId(eventsUriBuilder, endOfToday);
Uri eventsUri = eventsUriBuilder.build();
Cursor cursor = null;
cursor = mContext.getContentResolver().query(eventsUri, columns, null, null, CalendarContract.Instances.DTSTART + " ASC");
请注意,您必须URI追加时间限制的事件,你无法排序任何其他方式。
为了包括所有日事件为好,只是扩大搜索到下午11:59前一天晚上和上午12:00在今晚。
你的条件只给你,是严格限制的今天的事件。 你应该检查今天开始前的那些后(multidays事件)结束。
对于周期性事件,我手动检查。 我没有找到另一种方式。
我用的是这样的:
String selection = "((" + CalendarContract.Events.DTSTART + " <= ?) AND (" + CalendarContract.Events.DTEND + " >= ?)) OR (" + CalendarContract.Events.RRULE + " is not null )";
String[] selectionArgs = new String[] { dtEnd, dtStart};
问候,
你应该能够在CalendarContract.Events.ALL_DAY添加到您的选择条件来过滤所有ALL_DAY事件。
我知道这是有点晚了,但我有一个非常类似的问题,很难找到我一直在寻找的答案。 全天活动的强制UTC时区所做的事情非常棘手。 这里是我的解决方案:
// "allDayStart" is an all-day event today, encoded in the default time zone
Time allDayStart = new Time();
allDayStart.timezone=TimeZone.getDefault().toString();
allDayStart.set(dayStart.monthDay, dayStart.month, dayStart.year);
// 2 time selections for the query:
// 1) Between day-start and day-end (not all-day); or
// 2) Equals today at 0:00:00 (all-day) in the default timezone
String calSelection =
"((" + Calendars.ACCOUNT_NAME + " = ?) " +
"AND (" + Calendars.OWNER_ACCOUNT + "= ?) " +
"AND (" +
"((" + Events.DTSTART + ">= ?) " +
"AND (" + Events.DTSTART + "<= ?) " +
"AND (" + Events.ALL_DAY + "= ?) " +
") " +
"OR ((" + Events.DTSTART + "= ?) " +
"AND (" + Events.ALL_DAY + "= ?)" +
")" +
")" +
")";
String[] calSelectionArgs = new String[] {
accountName, ownerName,
dayStartInMillis.toString(), dayEndInMillis.toString(), "0", // during today, not all day
allDayStartInMillis.toString(), "1" // Started today at default start-time for all-day events (all-day), default time zone
};
查询可细化到不需要两个部分,但是这对我来说不够好。
如果有帮助,这里的地方一天开始和dayEnd来自何处:
Time dayStart = new Time();
dayStart.setToNow();
dayStart.hour=0;
dayStart.minute=0;
dayStart.second=0;
Time dayEnd = new Time();
dayEnd.set(dayStart);
dayEnd.hour=dayStart.hour+23;
dayEnd.minute=dayStart.minute+59;
dayEnd.second=dayStart.second+59;
Long dayStartInMillis = dayStart.toMillis(false);
Long dayEndInMillis = dayEnd.toMillis(false) + 999;
Long allDayStartInMillis = allDayStart.toMillis(false);
尝试使用Instances.CONTENT_BY_DAY_URI。 检查这个答案的一个例子- https://stackoverflow.com/a/36622111/1219241