27

我正在尝试让我的应用程序向用户的日历添加提醒。代码在添加之前搜索titleandstart date以检查事件是否已存在于日历中(以免重复)。我的问题是:如果我手动从日历中删除事件(使用日历),事件会从日历中消失(我正在查看我的所有日​​历,但在日历应用程序中看不到它),但不会从数据库中消失。我不明白的另一件事是我试图以编程方式删除事件,但它们仍然没有被删除。

这是我的代码片段:

Cursor cur = null;
ContentResolver cr = getContentResolver();
String calUriString = "content://com.android.calendar/events";
Uri cal=Uri.parse(calUriString);
String[] EVENT_PROJECTION=new String[]{"calendar_id","title","dtstart","_id"};
String selection = "((" + "calendar_id" + " = 1) AND ("
        + "title" + " LIKE '"+name+"') AND ("
        + "dtstart" + " = "+String.valueOf(c.getTimeInMillis())+"))";

cur = cr.query(cal, EVENT_PROJECTION, selection, null, null);

boolean found=false;
if(cur!=null) 
    if(cur.moveToFirst()){
        DatabaseUtils.dumpCursor(cur);/*Just to view my results (which always include the deleted events)*/
        do{
            if(cur.getString(1).equals(name)){
                /*I use this part to try to remove the events manually*/
                Uri eventUri =ContentUris.withAppendedId(cal, Long.valueOf(cur.getString(3)));
                String reminderUriString = "content://com.android.calendar/reminders";
                Uri remUri =Uri.parse(reminderUriString);
                cr.delete(remUri, "event_id="+cur.getString(3), null);
                cr.delete(eventUri, null, null);
                /*It is not working also*/

                Toast.makeText(getApplicationContext(), "Event already exists in Calendar", Toast.LENGTH_LONG).show();
                found=true;
                //break;
            }
        }while(cur.moveToNext());
    }
    cur.close();
    if(found){
        /*Event is found even if I remove it from the Calendar manually and even if I remove it programmatically using cr.delete()*/
    }
    else{
        values.put("calendar_id",1); /*I am using the same Calendar that I query, or is this wrong*/
        values.put("title", name);
        /*More values are added*/
        Uri calendarUri = cr.insert(cal, values);
        long eventID = Long.parseLong(calendarUri.getLastPathSegment());
        String reminderUriString = "content://com.android.calendar/reminders";
        ContentValues reminderValues = new ContentValues();
        reminderValues.put("event_id", eventID);
        reminderValues.put("minutes", 5); 
        reminderValues.put("method", 1); 
        Uri reminderUri = getApplicationContext().getContentResolver().insert(Uri.parse(reminderUriString),  reminderValues);
    }

为什么从日历应用程序中删除事件后仍然存在,为什么我什至无法以编程方式将其删除?

更新 问题只有当我calendar_id=1用于插入和删除时。其他calendar_id的工作正常。

更新 2 我在三星 Galaxy S1 上测试了代码,它运行良好。这似乎是三星 Galaxy S3 的问题(我有问题,我认为这是 S-planner 应用程序中的错误)

4

3 回答 3

17

如果不是 URI 问题,

您可以尝试包含在选择字符串中吗

AND (deleted != 1)

所以选择字符串变成了,

String selection = "((" + "calendar_id" + " = 1) AND ("
    + "title" + " LIKE '"+name+"') AND ("
    + "dtstart" + " = "+String.valueOf(c.getTimeInMillis())+") AND ( deleted != 1 ) )";

有时,CalendarDB 需要一些时间才能删除事件。但是“已删除”的 COLUMN 将被标记为“1”,表示它们将很快被删除。延迟的原因可能是日历正在等待同步

ps:尝试使用这个工具——http: //www.cellobject.net/Tools/CellObjectSQLiteXMLBrowser.aspx来可视化日历数据库。请检查数据库中的“已删除”和“脏”列

于 2013-04-03T06:53:32.177 回答
1

不同版本的 android 使用不同的 URI 路径来查找日历数据。例如,您可以为 android 2.1 和 2.2 使用以下常量:

private static final String URI_VERSION_2_1 = "content://calendar/events";
private static final String URI_VERSION_2_2 = "content://com.android.calendar/events";

在 4.0 中,首选不同的方法:

http://android-developers.blogspot.com/2011/10/ics-and-non-public-apis.html http://developer.android.com/reference/android/provider/CalendarContract.Events.html

Galaxy S3 很有可能至少安装了 Android 4.0。此更改可能解释了在 S1 上工作的代码,而不是在 S3 上工作的代码。

于 2013-03-19T01:53:57.673 回答
0

你也可以这样做:

private boolean isEventInCal(Context context, String id) {
    Uri event = ContentUris.withAppendedId(CalendarContract.Events.CONTENT_URI, Long.parseLong(id));

    Cursor cursor = context.getContentResolver().query(event, null, null, null, null);
    if (cursor != null && cursor.getCount() == 1) {
        //the event exists?
        if (cursor.moveToFirst() && !TextUtils.equals(cursor.getString(cursor.getColumnIndex("deleted")), "1")) {

            cursor.close();
            return true;
        } else {
            return false;
        }
    }
    return false;
}

它适用于所有设备。

于 2017-09-14T03:27:36.990 回答