以图搜图这个功能相当实用, 之前在实现这个功能的时候, 有一些笔记, 今天就整合成博文, 分享给大家。

这个demo主要实现的功能包括:

  • 自定义拍照界面
  • 图像识别
  • 以图搜图
  • 信息获取(通过识别出的图像, 获取对应信息)

下面是一个简单的演示,  如下:

     

那么如何实现这样的功能呢?

如果自己去完成图像识别, 显然不现实。

最早我研究的是谷歌API, 不过谷歌在天朝, 大家都懂得...

然后是百度了,尝试了下,  效果还不错。 另外, 百度也有自己“以图搜图”对应的App。不过我们只是为了学会如何实现怎样的功能, 管他呢。

所以,在以图搜图功能上, 我选择了使用百度API,不过百度这个API只提供给他们的“百度轻拍”APP, 不对外开放,我也是通过轻拍抓到的API,然后进行分析。

好了, 接下去就是分析过程了。 demo之后会提供。

1. UIImage 转 NSString

之后我们会采用 post方式, 获取对应的json数据,但是这个请求里面,要传入 base64Encoding 编码的 NSString (这里放的是图片信息)

(不要问我为什么, 百度就是这样设计的 )

    UIImage* pic =[UIImage imageNamed:@"test_1.png"];NSData* pictureData =UIImagePNGRepresentation(pic);NSString* pictureDataString =[pictureData base64Encoding];

2. POST请求

这里, 我抓到的URL是这样的: http://qingpai.baidu.com/api/irs/rex?reqid=196423494211296782&ak=eyJjdCI6IjIwIn0%3D&encoding=base64

如果感兴趣如何获取的, 可以留言, 如果真有疑惑, 我之后会专门再写一篇文章。 这里不是本次的主题, 就不涉及这部分内容了

简单分析下这个API。

qingpai.baidu.com/api/  很明显 , 它是为 ”百度轻拍“提供的

reqid, ak 这个是绑定设备的。 这里固定使用这个就可以

encoding=base64 表示传入数据的编码方式。

上面那个API是固定的, 需要改变的是我们post时候传入的数据

具体如下:

    UIImage* pic =[UIImage imageNamed:@"test_1.png"];NSData* pictureData =UIImagePNGRepresentation(pic);NSString* pictureDataString =[pictureData base64Encoding];//Post请求NSString *post = [NSString stringWithFormat:@"%@", pictureDataString];NSData *bodyData = [[post stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]dataUsingEncoding:NSUTF8StringEncoding];//把bodyString转换为NSData数据NSURL *serverUrl = [NSURL URLWithString:@"http://qingpai.baidu.com/api/irs/rex?reqid=196423494211296782&ak=eyJjdCI6IjIwIn0%3D&encoding=base64"];//获取到服务器的url地址NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:serverUrlcachePolicy:NSURLRequestReloadIgnoringCacheDatatimeoutInterval:10];//请求这个地址, timeoutInterval:10 设置为10s超时:请求时间超过10s会被认为连接不上,连接超时[request setHTTPMethod:@"POST"];//POST请求[request setHTTPBody:bodyData];//body 数据[request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"content-type"];//请求头NSData *returnData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];NSString *result = [[NSString alloc] initWithData:returnData encoding:NSUTF8StringEncoding];NSMutableDictionary *addressDic = [result objectFromJSONString];//异步发送request,成功后会得到服务器返回的数据//返回的数据 根据系统的不同会返回不同编码的数据,比如windows 为GBK,Ubuntu 为UTF8.。。//注意转换编码格式NSLog(@"%@", addressDic);

看一下打印的信息, 是json数据, 我拆分完以后, 大体长这样:

返回的数据很多, 大家感兴趣可以自己逐一分析。

简单的介绍下.

facesatar 表示 识别出来相似的明星人脸。

                 "name": "\u90ac\u9756\u9756","nameid": "1931","simi": "0.904725","pid": "1932\/64.jpg","width": "440","height": "440","face_left": "143","face_top": "107","face_width": "193","face_height": "193"

这里是一项的数据. 我们需要的主要是 “name” 和 “simi”属性,分别标示 明星姓名, 相似度。

其他的熟悉包括图片的大小, 人脸的位置, 如果需要也可以使用。

另外, name 这里的编码是Unicode,所以如果一起输出可能不明白什么意思。(缩小到name, 单个输出, 在终端可以看到中文)不过我们获取到这个“name”值后,是可以直接显示,会显示中文的。

另外. 提供一个好用的网站,便于测试

中文转Unicode
Unicode转中文
http://javawind.net/tools/native2ascii.jsp?action=transform

再有,similar列表这里列举出了相似的图片及其来源。 具体大家可以自己分析。

三。获取详细信息

我们可以通过json数据里面, 获取到相似度最高的那个人物姓名(也可以是景点名字, 这个API比较强大)

然后调用如下API,就可以显示显示详细信息了。百度都为“轻拍”封装好了。

比如, 人物姓名是 “邬靖靖” , 调用如下URL:

http://qingpai.baidu.com/api/proxy/search?word=邬靖靖&pn=1

我这里直接用Safari打开, 就可以看到如下效果:

这样一个封装好的WAP界面, 我们可以直接在UIWebView中, 利用URL打开, 效果就很好了。

将到这里, 主要就是分享一些可供我们直接使用的API。 当然, 这个API在别处肯定是找不到的。

另外, 图片搜索我们还可以拓展出好多知识,

比如 人脸识别,光学字符识别, 图像文字识别....

以上提到的那3部分, 之前都有写过相关demo。 不过最近忙着考试, 等以后有时间了再逐一分享。

希望以上内容对你有所帮助。

ps: 拉票啦~

我参加了2014博客之星评选比赛, 麻烦大家帮忙投下票
http://vote.blog.csdn.net/blogstar2014/details?username=hitwhylz#content

谢谢。

iOS开发- 以图搜图功能实现 (源码+解析)相关推荐

  1. Java调用Pytorch实现以图搜图(附源码)

    Java调用Pytorch实现以图搜图 设计技术栈: 1.ElasticSearch环境: 2.Python运行环境(如果事先没有pytorch模型时,可以用python脚本创建模型): 1.运行效果 ...

  2. 以图搜图 图像匹配_图像匹配,基于深度学习DenseNet实现以图搜图功能

    原标题:图像匹配,基于深度学习DenseNet实现以图搜图功能 度学习的发展使得在此之前以机器学习为主流算法的相关实现变得简单,而且准确率更高,效果更好,在图像检索这一块儿,目前有谷歌的以图搜图,百度 ...

  3. 以图搜图功能该如何测试

    以图搜图功能该如何测试 最近在测试以图搜图的功能,以下是一些测试思路 图片上传后,图片可以被搜索到 图片删除到回收站后图片无法被搜索到,其他图片不受影响 图片回收站恢复后可以被搜索到 图片同名被替换时 ...

  4. 图像匹配,基于深度学习DenseNet实现以图搜图功能

    向AI转型的程序员都关注了这个号???????????? 机器学习AI算法工程   公众号:datayx 度学习的发展使得在此之前以机器学习为主流算法的相关实现变得简单,而且准确率更高,效果更好,在图 ...

  5. 基于深度学习实现以图搜图功能

    前记: 深度学习的发展使得在此之前以机器学习为主流算法的相关实现变得简单,而且准确率更高,效果更好,在图像检索这一块儿,目前有谷歌的以图搜图,百度的以图搜图,而百度以图搜图的关键技术叫做"感 ...

  6. 在vue2使用百度脑图的kityminder-core进行二次开发思维导图,在源码中添加新的命令

    需求说明:最近在搞kityminder-core的思维导图,需要增加一个给节点添加文件的功能,一直在研究源码,发现都是通过执行命令的方式实现的.一直卡在新增命令的步骤,搞了好多天了今天找到了如何在源码 ...

  7. iOS富文本组件的实现—DTCoreText源码解析 数据篇

    本文转载 http://blog.cnbang.net/tech/2630/ DTCoreText是个开源的iOS富文本组件,它可以解析HTML与CSS最终用CoreText绘制出来,通常用于在一些需 ...

  8. 使用AnalyticDB轻松实现以图搜图和人脸检索

    1. 背景 以图搜图在生活中有着广泛的应用, 当我们在电视上看到有人穿着一件美丽的裙子或者帅气的球鞋也想拥有时, 我们可以拍张照片然后打开淘宝然后上传照片就可以快速的找到这个商品. 我们看到一张电影截 ...

  9. 无法检索数据和目标数据的列信息_使用AnalyticDB轻松实现以图搜图和人脸检索...

    1. 背景 以图搜图在生活中有着广泛的应用, 当我们在电视上看到有人穿着一件美丽的裙子或者帅气的球鞋也想拥有时, 我们可以拍张照片然后打开淘宝然后上传照片就可以快速的找到这个商品. 我们看到一张电影截 ...

最新文章

  1. JAVA实现中点画线_实验1-中点画线和Bresenham画线算法的实现
  2. Python-OpenCV 笔记6 -- 轮廓(Contours)
  3. django19:项目开发流程
  4. Ubuntu开机自动启动script(2)
  5. 使用 webstorm 写 typescript 的一些小技巧
  6. nohup执行的jar 怎么kill_使用Shell脚本如何启动/停止Java的jar程序
  7. 课时47:魔法方法:定制序列
  8. 开源阅读书源_强力推荐一个开源阅读软件
  9. c语言二级考试题库及答案,c语言二级考试题库
  10. 智慧旅游信步而来 互联网安防助力景区智能化
  11. 最全离散数学 集合运算基本法则(包括差集公式)
  12. r语言如何计算t分布临界值_「SPSS数据分析」SPSS差异分析(3)独立样本T检验操作步骤及解读...
  13. 北京大学 引进一位人工智能世界级专家!
  14. 18软工实践-团队现场编程实战(抽奖系统)
  15. 在线loading图标生成网站
  16. Java truelicense 实现License授权许可和验证
  17. Unity 设置程序在后台运行
  18. 2016【淘宝运营】,如何营销宝贝详情页,提高宝贝的转化率
  19. 图片怎么格式转换成jpg?介绍几种思路
  20. equestresponseservletContext

热门文章

  1. SaaSBase:什么是企业微信?
  2. 2023年创业必火的十个行业是哪些?创业必赚钱!
  3. 靠猪八戒接单根本就没什么肉吃,这些才是程序员赚外快的最佳方法!!!
  4. 红黑树(一)的原理和算法详细介绍
  5. 小程序怎么弄?小程序开发多少钱?
  6. java开发有必要刷leetcode吗_刷 leetcode 需要哪些基础?
  7. Android视频监控!!!随时随地监控你的家庭
  8. 2021届毕业生还没找到Android开发工作,看这一篇就够了!
  9. excel中如何自动添加邮箱后缀
  10. 全排列、全组合 java实现