Skip to content

Eiffelyk/MJSdkDemo

Repository files navigation

SDK简述

本SDK开发旨在提供方便快捷地获取汽车配件信息,通过VIN码或汽车品牌配置信息进行车辆定型后即可使用圈选或者配件名、OE等形式获取配件信息。

本SDK使用时需要获取正式授权的license文件。商务合作请联系明觉科技,SDK仅提供合作客户使用,违用必究!

更新记录

时间 版本 更新内容
2018年11月19日 mjsdk:1.0.19
mjthinkkey:1.0.1
mjspeech:1.0.1
1.修复获取TopN无数据的bug
2.添加设备唯一标识UUID
3.规范上传字段
2018年11月27日 mjsdk:1.0.29
mjthinkkey:1.0.1
mjspeech:1.0.1
1.添加授权自动续约,解决授权到期后需要重新初始化的问题
2.SDK代码深层加密
3.加密网络数据交互(有效防止抓包,修改报文等中间人攻击)
4.初始化更灵活,添加了一种初始化的时候调用license文件的方式
2018年12月25日 mjsdk:1.0.30
mjthinkkey:1.0.1
mjspeech:1.0.1
1.新增语义解析功能
2.优化圈选定位的准确性
2019年1月21日 mjsdk:1.0.30
mjthinkkey:1.0.1
mjspeech:1.0.2
1.修改语音单次录入时长为30,静音等待时间调整为5秒
2019年9月26日 mjsdk:1.0.50
mjthinkkey:1.0.2
mjspeech:1.0.3
1.初始化加入userKey必填字段(用户的唯一标识)
2.优化升级内部调用库(armeabi升级为armeabi-v7a)
3.修复语音识别功能最后一个词不识别的bug
2019年11月27日 mjsdk:1.0.50
mjthinkkey:1.0.3
mjspeech:1.0.4
语音搜索和首字母功能去掉v7:28.0.0,兼容低版本编译

使用步骤:

0.拷贝申请到的license.lic(此文件请勿重命名)文件到assets目录中

1.添加依赖及权限:

在工程build.gradle配置脚本中buildscript和allprojects段中添加【明觉科技SDK】 新maven仓库地址

allprojects {
    repositories {
        maven {
            url 'https://dl.bintray.com/dataenlighten/MJSDK'
        }
    }
}
*Gradle

在项目module build.gradle配置脚本中dependencies添加

android {
   ...
    defaultConfig {
       ...
        ndk {
            abiFilters "armeabi-v7a"
        }
    }
}

dependencies {
    ...
    //SDK依赖
    implementation 'com.mingjue.sdk:mjsdk:1.0.50'
    implementation 'com.mingjue.sdk:mjthinkkey:1.0.3'
    implementation 'com.mingjue.sdk:mjspeech:1.0.4'
}
* 在项目AndroidManifest.xml配置脚本中添加权限
    <!-- 网络状态 -->
    <uses-permission android:name="android.permission.INTERNET" />
    <!--获取网络状态请求网络前判断是否有网络-->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <!-- 获取手机录音机使用权限此权限为敏感权限请在使用时动态申请),听写识别语义理解需要用此权限不用mjspeech功能可以不加此权限) -->
    <uses-permission android:name="android.permission.RECORD_AUDIO" />

2.初始化以及方法调用:

* 初始化
    /**
     * 服务初始化。
     *
     * @param ctx android 上下文
     * @param userKey 用户唯一标识
     * @param onSdkInitLisener 初始化回调
     * @throws LicenseNotFoundException 未发现license异常
     */
    void init(Context ctx,String userKey, OnSdkInitLisener onSdkInitLisener) throws LicenseNotFoundException;
    /**
     * @param ctx android 上下文
     * @param userKey 用户唯一标识
     * @param licenseContent license文件内容
     * @param onSdkInitLisener 初始化回调
     */
    void init(Context ctx, String userKey,String licenseContent, OnSdkInitLisener onSdkInitLisener);
* VIN解析
/**
 * VIN解析,返回对应VIN码的车辆信息
 * @param vin VIN码
  * @param partList 获取常用配件个数(0不获取[默认],1获取top300,2获取top600,3获取topAll)
 * @param queryCallBack 请求回调。
 */
void VINQuery(String vin,int partList, QueryCallBack queryCallBack);

详细信息.

*语意解析
/**
* 语义解析,将一段文字转化为 配件带工项的形式
* @param vinCode  vin码(大写),没有VIN码时传空字符串
* @param key   要解析的文字信息
* @param queryCallBack
*/
void queryPartAnalysis(String vinCode, String key, QueryCallBack queryCallBack);
* 智能推荐接口
/**
 * 智能推荐接口
 * @param params 智能推荐参数(RecommendPartsRequesParams中的selectedPartNameList为null的时候为依照车身部位浏览配件,selectedPartNameList如果有值会根据这些值进行推荐)
 * @param queryCallBack
 */
void queryRecommendPartsBySelected(RecommendPartsRequesParams params, QueryCallBack queryCallBack);

详细信息.

* 查询关联配件
/**
 * 查询关联配件(又名查询相邻配件)
 * @param params 关联配件查询参数
 * @param queryCallBack
 */
void queryRelatedParts(RelatedPartsRequesParams params, QueryCallBack queryCallBack);

详细信息.

* 通过字符串查询配件,支持返回操作项。
/**
 * 根据关键字查询配件。
 * @param params  关键字查询参数。
 * @param queryCallBack
 */
void queryPartsByKey(QueryPartsByKeyRequesParams params, QueryCallBack queryCallBack);

详细信息.

* 获取配件EPC装配图
/**
 * 获取配件EPC装配图
 * @param imageName  配件图片名
 * @param imagePrefix  车辆图片前缀 ,在VIN定型接口中获取。
 * @param queryCallBack
 */
void queryPartEPCImg(String imageName,String imagePrefix, QueryCallBack queryCallBack);

详细信息.

* 生成圈选小汽车 View

第一种方式---直接使用返回的DrawPartView动态填充界面

/**
 * 生成圈选小汽车 View
 * @param context  Android上下文
 * @param carInfo   车辆信息。
 * @param onDrawQueryListener
 * @return DrawPartView  圈选的view
 */
DrawPartView createDrawPartView(Context context,CarInfo carInfo, OnDrawQueryListener onDrawQueryListener);

第二种方式---布局xml文件种直接引用DrawPartView,并且设置车辆信息以及回调

//先设置车辆信息
DrawManager.getInstance().init(carInfo);
DrawManager.getInstance().setOnDrawQueryListenerlistener//再初始化DrawPartView

注:turnSurfaceChassis方法为切换全车件和底盘件

drawPartView.turnSurfaceChassis(boolean flag);
* 语音定损服务。

添加依赖:

 implementation 'com.mingjue.sdk:mjspeech:1.0.1'

接口定义:

/**
 * 语音定损服务。
 * @param context  android上下文,建议用app的context
 * @param touchView  长按说话的view
 * @param speechListener 语音回调
 */
SpeechService speechService = SpeechService.getInstance(context);
speechService.init(View touchView, SpeechListener speechListener);
* 通过已选配件智能定损
/**
 * 通过已选配件智能定损
 * @param params 定损的参数。
 * @param queryCallBack
 */
void estimateByParts(EstimateByPartsRequestParams params, QueryCallBack queryCallBack);

参数说明:

/**
 * 智能定损接口参数
 */
public class EstimateByPartsRequestParams {
    /** 车辆信息*/
    private CarInfo carInfo = null;
    /** 修理厂id*/
    private String repairer = null;
    /** 维修类型 如"送修" */
    private String repairType = null;
    /** 保险公司id*/
    private String insurer = null;
    /** 选择的配件工项信息列表 */
    private List<DamageInfo> damageInfoList = null;
}
public class DamageInfo {
    /** 配件选择的工项 */
    private String operation = null;
    /** 配件Id */
    private String partId = null;
    /** 配件标准名称 */
    private String standardPartName = null;
    /** 配件损伤程度 */
    private String severity = null;
    /** 配件价格 */
    private String partPrice = null;
    /** 工时价格 */
    private String laborCost = null;
}
* 首字符关联配件名。

添加依赖:

 implementation 'com.mingjue.sdk:mjthinkkey:1.0.1'

接口定义:

	/**
     * 首字母关联配件名
     * @param input   用户输入的首字母串
     * @param names   VIN定型里面返回的top1000 配件名称数组
     * @param callBack  查询回调
     */
    void queryThinkedKeys(String input, String[] names, QueryThinKedKeysCallback callBack)

接口调用:

MJInitialService.getInstance().queryThinkedKeys(input,names,queryThinKedKeysCallback

3.混淆文件:

    #-libraryjars libs/okhttp3
    -dontwarn okhttp3.**
    -keep class okhttp3.** { *; }

    #-libraryjars libs/okio
    -dontwarn okio.**
    -keep class okio.** { *; }

4.接口错误码表

错误码 描述
0000 成功
1001 VIN不合法
1002 VIN不支持
1003 非乘用车
1004 VIN错误
1005 VIN无法解析
1006 无权查看该品牌数据
1011 请求VIN的配件数据不存在
1012 该车无此配件
1013 请求图片不存在
1014 推荐配件数据不存在
1015 该车型查不到配件
9007 后台API异常
8000002 系统验证:成功退出系统!
0000 系统验证:成功刷新访问票据!
8000004 系统验证: 账号不存在或无权限!
8000005 系统验证:需要进一步鉴权.
9999999 其他错误,请联系技术支持!
9000001 系统验证:请求参数不完整或者有错误!
9002 系统验证:访问票据非法或已过期!
9000004 系统验证:权限不足,无权访问该产品.
9000005 系统验证:权限不足,无权访问该资源.
9006 系统验证:认证失败!
9000007 系统验证:请求验证码过于频繁 请稍后重试.
9000008 系统验证:访问过于频繁 请稍后重试.
9000009 系统验证:权限不足.
9000010 服务响应超时 请稍后重试.
9000011 请输入用户组名称
9000012 外键错误
9000013 手机号码格式错误
9000014 列名部分有问题,请再次确认
9000015 手机号已注册
9000024 用户不存在
9000016 用户名已注册
9000017 分组已存在
9000018 分组公司关系已存在
9000019 请输入分组ID
9000020 请选择分组
9000021 请选择公司
9000022 组织信息未填写,请确认
9005 服务器升级中!

About

明觉AiSDKDemo

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages