使用说明

本文档主要介绍微信图像 SDK(Android 版)使用方法,利用 SDK 可以准确搜索到用户上传的图像。

本文属于入门级文档,旨在帮助开发者快速学习 Android SDK 的使用并应用到自身开发工作。具体 API 可到“资源下载 ”页下载《微信图像SDK(Android版)开发手册》进行查询。

准备工作

第一步 创建移动应用

请到“管理中心”中点击“创建移动应用”,填写相关资料,然后将该应用提交审核,只有审核通过的应用才能进行开发。

申请资料中需要提交应用签名值,可前往“资源下载”页下载签名生成工具。

注册完毕,我们会在 7 个工作日内完成审核工作。 审核通过之后,开放平台将分配给该移动应用全局唯一的AppID。

第二步 下载 Android SDK

进入“资源中心”的“资源下载”页下载 Android SDK,压缩包中包括 Demo+SDK+开发文档。其中的 Demo 使用 SDK 的各功能 API;SDK 包括.so 和.jar 文件。

第三步 上传图片

每个 AppID 只能检索到自身上传的图片,图片上传位置:资源中心 –> 图像识别图片库,待图片审核通过, 即可对此图片进行识图操作。

Demo介绍

为了更好的理解微信图像接口 SDK 的使用,下面将通过一个简单的实例来讲解一下 SDK 各个关键 API 接口的使用。

1. 开发工具

Android 开发工具有很多,开发者可以根据自身的喜好来选择。在讲解本示例的时候,我们将使用 Eclipse 来一步步分析。

2. 工程配置

首先新建一个示例工程,按以下步骤进行配置。

i. 引入.so 文件

如下图,在 libs\armeabi 目录下粘贴 libwxnet.so 文件。

智能图像截图

ii. 引入 jar 包:

在工程属性->Java Build Path->Libraries 中选择“Add External JARs”,选定 wximg.jar,确定后返回,完成后的效果如图 1所示。

3. AndroidManifest.xml 设置

i. 添加必要的权限支持:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<uses-permission android:name="android.permission.RECORD_AUDIO"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

4. 图像识别 Demo(包括通用识别和语法识别)

i. 初始化

ImgSearcher.shareInstance().setListener(this);
if (ImgSearcher.shareInstance().init(this, screKey) != 0) {
//初始化失败 
}

注:此处的 screKey 就是在官网上申请的应用授权码。

ii. 开始识别

ImgSearcher.shareInstance().start(img); 

iii. 取消识别

ImgSearcher.shareInstance().cancel();

此接口的如果返回非 0 值, 则表示 cancel 过程结束, 否则其状态将通过 public void onGetState(ImgSearcherState state)回调获取。

iv. 实现 ImgListener,并重写其函数

直接在 Activity 类中实现 ImgListener,重写 ImgListener 各函数如下所示:

@Override public void onGetError(int arg0) {
// TODO Auto-generated method stub
}
@Override
public void onGetResult(ImgResult result) {
// TODO Auto-generated method stub
String mResUrl;
String mResMD5;
String mResPicDesc;
if (result != null) {
if (1 == result.ret && result.res != null) {
int resSize = result.res.size();
for (int i = 0; i < resSize; ++i) {
mgResult.Result res = (ImgResult.Result) result.res.get(i);
if (res != null) {
ResMD5 = res.md5;
mResUrl = res.url;
mResPicDesc = res.picDesc;
}
}
}
}
}
@Override public void onGetState(ImgSearcherState state) {
// TODO Auto-generated method stub
}

v. 释放系统资源

ImgSearcher.shareInstance().destroy();

注:调用此函数, 需要确保识别过程或者 cancel 过程已经结束, 否则会出现问题。

vi. Demo 截图

编译运行,图 2、图 3 分别是开始界面和识别结果界面:

更多内容在“资源下载”页下载SDK+Demo+开发文档。