- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用新的 API 在我的手机上插入/更新联系人,我正在使用这种方法来更新它们..
String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Note.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
String[] selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1, selectArgs2)
.withValue(Note.Note, "hello@hi.com")
.build());
这一切都很好,除了当我开始更新笔记时。没有 Note.Type_1
或类似的东西,所以我不知道在 selectArgs1 和 selectArgs2 中放什么来代替 Email.TYPE
和 String.valueOf(Email.TYPE_OTHER)
如有任何帮助,我们将不胜感激。谢谢! :)
[编辑]
public static void updateContact(Context c, int recordId, String key, String value) {
context = c;
if (database == null) database = new SavedContactsDatabase(context);
ArrayList<ContentProviderOperation> operationList = new ArrayList<ContentProviderOperation>();
ContentProviderOperation.Builder builder = ContentProviderOperation.newUpdate(Data.CONTENT_URI);
String contactId = String.valueOf(recordId);
String selectArgs1 = "";
String[] selectArgs2 = null;
String type = "";
String subkey = "";
if (key.contains(":")) {
String[] split = key.split(":");
key = split[0];
type = split[1];
if (split.length == 3) subkey = split[2];
}
if (key.equals("Email")) {
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_WORK)};
} else if (type.equals("Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_MOBILE)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Email.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Email.DATA1, value);
}
if (key.equals("Nickname")) {
if (type.equals("Default")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_DEFAULT)};
} else if (type.equals("Other Names")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_OTHER_NAME)};
} else if (type.equals("Maiden Name")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_MAINDEN_NAME)};
} else if (type.equals("Short Name")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_SHORT_NAME)};
} else if (type.equals("Initials")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_INITIALS)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Nickname.CONTENT_ITEM_TYPE + "'" + " AND " + Nickname.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Nickname.NAME, value);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Note")) {
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Note.CONTENT_ITEM_TYPE + "'";
selectArgs2 = new String[]{contactId, "vnd.android.cursor.item/note"};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Note.NOTE, "hello@hi.com");
}
/////////////////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Organization")) {
String data = "";
if (type.equals("Company")) {
data = Organization.COMPANY;
} else if (type.equals("Title")) {
data = Organization.TITLE;
} else if (type.equals("Department")) {
data = Organization.DEPARTMENT;
} else if (type.equals("Job Descripiton")) {
data = Organization.JOB_DESCRIPTION;
} else if (type.equals("Symbol")) {
data = Organization.SYMBOL;
} else if (type.equals("Phonetic Name")) {
data = Organization.PHONETIC_NAME;
} else if (type.equals("Office Location")) {
data = Organization.OFFICE_LOCATION;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Organization.CONTENT_ITEM_TYPE + "'" + " AND " + Organization.TYPE + "=?";
selectArgs2 = new String[]{contactId, String.valueOf(Organization.TYPE_WORK)};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
if (key.equals("Phone")) {
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_HOME)};
} else if (type.equals("Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MOBILE)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK)};
} else if (type.equals("Fax Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_FAX_WORK)};
} else if (type.equals("Fax Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_FAX_HOME)};
} else if (type.equals("Pager")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_PAGER)};
} else if (type.equals("Other")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_OTHER)};
} else if (type.equals("Callback")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_CALLBACK)};
} else if (type.equals("Car")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_CAR)};
} else if (type.equals("Company Main")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_COMPANY_MAIN)};
} else if (type.equals("ISDN")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_ISDN)};
} else if (type.equals("Main")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MAIN)};
} else if (type.equals("Other Fax")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_OTHER_FAX)};
} else if (type.equals("Radio")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_RADIO)};
} else if (type.equals("Telex")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_TELEX)};
} else if (type.equals("TTY TDD")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_TTY_TDD)};
} else if (type.equals("Work Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK_MOBILE)};
} else if (type.equals("Work Pager")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK_PAGER)};
} else if (type.equals("Assistant")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_ASSISTANT)};
} else if (type.equals("MMS")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MMS)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'" + " AND " + Phone.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Phone.NUMBER, value);
}
//TODO Relation?
//////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Name")) {
String data = "";
if (type.equals("Display Name")) {
data = StructuredName.DISPLAY_NAME;
} else if (type.equals("Given Name")) {
data = StructuredName.GIVEN_NAME;
} else if (type.equals("Family Name")) {
data = StructuredName.FAMILY_NAME;
} else if (type.equals("Prefix")) {
data = StructuredName.PREFIX;
} else if (type.equals("Middle Name")) {
data = StructuredName.MIDDLE_NAME;
} else if (type.equals("Suffix")) {
data = StructuredName.SUFFIX;
} else if (type.equals("Phonetic Given Name")) {
data = StructuredName.PHONETIC_GIVEN_NAME;
} else if (type.equals("Phonetic Middle Name")) {
data = StructuredName.PHONETIC_MIDDLE_NAME;
} else if (type.equals("Phonetic Family Name")) {
data = StructuredName.PHONETIC_FAMILY_NAME;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + StructuredName.CONTENT_ITEM_TYPE + "'" + " AND " + StructuredName.MIMETYPE + "=?";
selectArgs2 = new String[]{contactId, String.valueOf(StructuredName.MIMETYPE)};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Address")) {
String data = "";
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_WORK)};
} else if (type.equals("Other")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_OTHER)};
}
if (subkey.equals("Street")) {
data = CommonDataKinds.StructuredPostal.STREET;
} else if (subkey.equals("PO Box")) {
data = CommonDataKinds.StructuredPostal.POBOX;
} else if (subkey.equals("Neighbourhood")) {
data = CommonDataKinds.StructuredPostal.NEIGHBORHOOD;
} else if (subkey.equals("City")) {
data = CommonDataKinds.StructuredPostal.CITY;
} else if (subkey.equals("Region")) {
data = CommonDataKinds.StructuredPostal.REGION;
} else if (subkey.equals("Postcode")) {
data = CommonDataKinds.StructuredPostal.POSTCODE;
} else if (subkey.equals("Country")) {
data = CommonDataKinds.StructuredPostal.COUNTRY;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE + "'" + " AND " + CommonDataKinds.StructuredPostal.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
if (key.equals("Website")) {
if (type.equals("Homepage")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_HOMEPAGE)};
} else if (type.equals("Blog")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_BLOG)};
} else if (type.equals("Profile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_PROFILE)};
} else if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_WORK)};
} else if (type.equals("FTP")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_FTP)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Website.CONTENT_ITEM_TYPE + "'" + " AND " + Website.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Website.URL, value);
}
if (key.equals("Event")) {
if (type.equals("Anniversary")) {
selectArgs2 = new String[]{contactId, String.valueOf(Event.TYPE_ANNIVERSARY)};
} else if (type.equals("Birthday")) {
selectArgs2 = new String[]{contactId, String.valueOf(Event.TYPE_BIRTHDAY)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Event.CONTENT_ITEM_TYPE + "'" + " AND " + Event.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Event.START_DATE, value);
}
/*
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(Data.RAW_CONTACT_ID + "=?", new String[] {sdf})
.withValue(Email.DATA1, "work.hi.com")
.withValue(Email.TYPE, Email.TYPE_WORK)
.build());
*/
/*
String selectPhone = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" +
Email.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
String[] phoneArgs = new String[]{contactId, String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectPhone, phoneArgs)
.withValue(Email.DATA1, "hello@hi.comm")
.build());
*/
try {
operationList.add(builder.build());
ContentProviderResult[] res = context.getContentResolver().applyBatch(ContactsContract.AUTHORITY, operationList);
if (res[0].count == 0) {
//TODO Then Use the Insert Command Instead!
}
} catch (Exception e) { Log.d("fhksdsdj", e.toString()); }
}
最佳答案
String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "= ? ";
String[] selectArgs2 = new String[]{contactId, "vnd.android.cursor.item/note"};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1, selectArgs2)
.withValue(ContactsContract.CommonDataKinds.Note.NOTE, "hello@hi.com")
.build());
试试这个代码...
关于java - Android 通讯录 - 更新说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6506260/
您好,我是个菜鸟,如果您对此有任何帮助,我将不胜感激。我正在尝试使用用户保存在他们地址簿中的数据,之后我想让他们选择使用该地址进行递送。 这是我的地址 Controller class Address
我目前正在为我的公司开发一个网络应用程序。在此应用程序中,有一个表单,其中的输入字段包含有关联系人的信息。我想创建一个按钮,单击即可在地址簿中创建联系人。 是否可以使用 JavaScript 或其他网
在隐藏通讯录界面之前,是否可以一次选择多个联系人?还是每次地址簿界面出现时实际上只需要选择一个联系人? 最佳答案 是的,Whatsapp做到了。 如果您需要一个示例,请参见以下示例: MultiCon
我正在尝试获取 Android 中联系人的所有电话号码。我的代码如下所示: ContentResolver cr = context.getContentResolver(); String[] pr
我正在为域中的所有用户构建一个表。我让表格正常工作,并在其中为我的分页添加了一些代码,但现在我不断收到错误... //connection $conn = new mysqli($servername
我正在开发一个可以访问 iPhone 通讯录的应用程序。模拟器仅包含几个示例条目。我想找到一个包含数千个条目的示例地址簿字符集(英语、中文、阿拉伯语等)来全面测试我的应用程序。自己填写地址簿将花费永远
是否有任何 android API 可以提取 vcard 3.0 格式的联系人?我遇到了一个开源 vcard 项目 android-vcard 但在用法示例中提到了以下注释。 重要提示:如果您正在为
我的应用程序能够在应用程序的不同实例之间共享其内容,即有一个按钮可以让我将文档附加到电子邮件并将其发送给应用程序的另一个用户。当他们收到此文件时,它会在他们的应用程序实例中打开。这一切正常。 但是,在
我正在开发 iPhone 联系人管理应用程序。一位用户报告说他的所有联系人都是重复的。当他选择特定来源时,联系人不会重复。显然,这是因为他的地址簿同步了两次:一次是与他 PC 上的 iTunes 同步
我有两个继承自 UIViewController 的 Objective-C 类,我正在尝试一种不同的方法来学习如何与 iPhone 的地址簿进行交互。 example Apple 假设一切都在一个类
我想添加在 iOS 通讯录中保存联系人(电话号码、姓名、地址和电子邮件)的功能,方法是单击我的应用程序中的一个按钮!我该怎么做? 最佳答案 非常简单,只需按照以下步骤操作, 首先,您需要导入以下框架,
我正在使用新的 API 在我的手机上插入/更新联系人,我正在使用这种方法来更新它们.. String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.
我目前正在开发 Contact Importer 网络应用程序(使用 PHP),这样我就可以从 Gmail、Yahoo 等网站的用户帐户中获取电子邮件地址,并将它们用于我自己的邪恶目的。开个玩笑,我的
我与 Google 通讯录合作,一切顺利。但一个小时后,我需要手动刷新授予的访问权限。据此SO question我应该能够通过这个调用更新我的 refresh_token : refresh_toke
我正在使用以下代码获取 google 联系人姓名和电话号码。授权页面本身没有正常显示错误,如“您请求的页面无效”。 :( 请帮我解决这个问题... ` google.load("gdata",
正在尝试使用 google contacts api,如果我使用的话 https://www.google.com/m8/feeds/contacts/default/full 我有 25 个联系人,
由于 Google 停止了对旧版 Auth 的支持,现在我们必须使用 oAuth 2,我们简单的桌面应用程序无法再从我的 Google 帐户读取联系人。 很好 - 我明白这一点,但是这个新的 oAut
我想以编程方式将联系人直接保存到 iOS 设备的地址簿。 我该怎么做? 最佳答案 这是一个小例子: CFErrorRef error = NULL; NSLog(@"%@", [self descri
我正在尝试使用 Javascript 提取我在 Google 通讯录 ( https://contacts.google.com ) 上的联系人。为此,我需要将联系人面板滚动到底部,以便获取所有页面源
我目前正在开发一个 VoIP 应用程序,但我真的很受地址簿困扰。 由于自定义设计, native 地址簿不适合我的应用程序。此外,我想添加一些 native 地址簿中不存在的额外数据。但这会导致一些问
我是一名优秀的程序员,十分优秀!