设置、读取联络人头像 ---- save UIImage to ABAddressBook

2024-02-07 16:58

本文主要是介绍设置、读取联络人头像 ---- save UIImage to ABAddressBook,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

其中设置和读取联系人头像有两种方法

1、通过系统方法设置

其中要有2个参数  1、UIImage 2、联系人电话号码 

 

extern "C" ABRecordRef ABCFindPersonMatchingPhoneNumber(ABAddressBookRef addressBook,NSString *phoneNumber,int, int);

 

 

ABAddressBookRef addressbook = ABAddressBookCreate();

 

ABRecordRef ref1 = ABCFindPersonMatchingPhoneNumber(addressbook, pn, 0, 0);

int record =  ABRecordGetRecordID(ref1);//获取联络人的recordId

 

ABRecordRef  person = ABAddressBookGetPersonWithRecordID(addressbook, record);//获取联络人的ABRecordRef

 

/

设置联络人图片

UIImage * img = [UIImage imageNamed:@"image.png"];

NSData *dataRef = UIImagePNGRepresentation(img);

ABPersonSetImageData(person, (CFDataRef)dataRef, nil);

ABAddressBookAddRecord(addressbook, person, nil);

ABAddressBookSave(addressbook, nil);

 

CFRelease(addressbook);//create、copy、retrain对应的release

 

读取系统联络人图片

CFDataRef dataRef = ABPersonCopyImageData(person);

UIImage *image = [UIImage imageWithData:(NSData *)dataRef];//这个就是我们要获取的Image的值

[dataRef release];

 

 

注意:用系统方法插入的操作在数据库中保存的时候只会保存缩略图的形式

相当于在数据库中的格式format为0 fromat(分为3中 0为缩略图 1、大号缩略图 2、源图)

 

 

///

///

使用读取数据库的方法来读取 (这里就只说读取,具体的插入也类似)

 

#define DBNAME "/var/mobile/Library/AddressBook/AddressBookImages.sqlitedb"

-(UIImage *) getSystemImage:(int)record_id formatImg:(int) format

{

sqlite3 *m_db;

UIImage *image = nil;

int m_errno;

NSData* dataObj = nil;

m_errno=sqlite3_open(DBNAME,&m_db);

if (m_db==NULL) {

        return nil;

    }

int len;

    char *next;

sqlite3_stmt *st;

    char sql[256];

sprintf(sql,"select data from ABImage where record_id = %d and format = %d",record_id, format);

len = strlen(sql);

m_errno = sqlite3_prepare(m_db, (const char *)sql, len, &st, (const char **)&next);

if (m_errno != SQLITE_OK) 

{

         return nil;

}

m_errno = sqlite3_step(st);

if(m_errno == SQLITE_ROW)

{

int length = sqlite3_column_bytes(st, 0);

const unsigned char*pData = sqlite3_column_text(st, 0);

dataObj = [NSData dataWithBytes:pData length:length];

}

image = [UIImage imageWithData:dataObj];

sqlite3_finalize(st);

sqlite3_close(m_db);

    return image;

}


这篇关于设置、读取联络人头像 ---- save UIImage to ABAddressBook的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/688360

相关文章

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Java实现为PDF设置背景色和背景图片

《Java实现为PDF设置背景色和背景图片》在日常的文档处理中,PDF格式因其稳定性和跨平台兼容性而广受欢迎,本文将深入探讨如何利用Spire.PDFforJava库,以简洁高效的方式为你的PDF文档... 目录库介绍与安装步骤Java 给 PDF 设置背景颜色Java 给 PDF 设置背景图片总结在日常的

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

Java利用Spire.XLS for Java设置Excel表格边框

《Java利用Spire.XLSforJava设置Excel表格边框》在日常的业务报表和数据处理中,Excel表格的美观性和可读性至关重要,本文将深入探讨如何利用Spire.XLSforJava库... 目录Spire.XLS for Java 简介与安装Maven 依赖配置手动安装 JAR 包核心API介

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据