首页 > 其他分享 >对于相机调用和相册调用的优化以及定位地址进行识别优化

对于相机调用和相册调用的优化以及定位地址进行识别优化

时间:2023-05-17 23:13:16浏览次数:45  
标签:调用 String 相册 data uri new null 优化 out

第一阶段已经实现了,但是由于过于匆忙,导致实现bug过多,如识别优化利用外部类进行实现,内部也进行实现,相机功能与手机不匹配,每一次运行需打开储存权限,今天进行了优化,将代码简化,同时套用《第一行代码》的相机调用与相册调用的,进行修改。

实验阶段:将代码在新一个activity内进行书写,最后在进行移植,移植过程旭需注意manifist,包名等的条件。

以下为代码以及结果:

一:我的接口类:主要处理文字提取

public class Main {
String information = "";
public String qiuqiu(String address)
{
// 通用文字识别
String url = "https://api.textin.com/ai/service/v2/recognize";
// 请登录后前往 “工作台-账号设置-开发者信息” 查看 x-ti-app-id
// 示例代码中 x-ti-app-id 非真实数据
String appId = "d368dac2ac82d494a983b1baeafab48e";
// 请登录后前往 “工作台-账号设置-开发者信息” 查看 x-ti-secret-code
// 示例代码中 x-ti-secret-code 非真实数据
String secretCode = "84926c65950082820bf0385a1deab535";
BufferedReader in = null;
DataOutputStream out = null;
String result ="";
// System.out.println(1);
try {

byte[] imgData = readfile(address); // image
URL realUrl = new URL(url);
HttpURLConnection conn = (HttpURLConnection) realUrl.openConnection();
conn.setRequestProperty("connection", "Keep-Alive");
conn.setRequestProperty("Content-Type", "application/octet-stream");
conn.setRequestProperty("x-tixxxxxxxx-id", appId);//进行加密处理,可自己免费申请
conn.setRequestProperty("x-ti-xxxxxxxx", secretCode);
            conn.setDoOutput(true);
conn.setDoInput(true);
conn.setRequestMethod("POST"); // 设置请求方式
out = new DataOutputStream(conn.getOutputStream());
out.write(imgData);
out.flush();
out.close();
in = new BufferedReader(
new InputStreamReader(conn.getInputStream(), "UTF-8"));
String line;
// System.out.println(3);
while ((line = in.readLine()) != null) {
result += line;
}
// System.out.println(4);
} catch (Exception e) {
System.out.println("发送 POST 请求出现异常!" + e);
e.printStackTrace();
} finally {
try {
if (out != null) {
out.close();
}
if (in != null) {
in.close();
}
} catch (IOException ex) {
ex.printStackTrace();
}
}
// System.out.println(5);
String str = result;
String startStr = "text\":\"";
String endStr = "\"}";
// System.out.println("识别结束");
printSubstringsBetween(str, startStr, endStr);
//System.out.println("识别结束");
// System.out.println(6);
return information;
}


public static byte[] readfile(String path) {
String imgFile = path;
InputStream in = null;
byte[] data = null;
try {
in = new FileInputStream(imgFile);
data = new byte[in.available()];
in.read(data);
in.close();
} catch (IOException e) {
e.printStackTrace();
}
return data;
}


public void printSubstringsBetween(String str, String startStr, String endStr) {
int startIndex = 0;
while (startIndex != -1) { // 循环直到找到所有符合条件的子字符串
startIndex = str.indexOf(startStr, startIndex); // 找到起始字符串的索引位置
if (startIndex != -1) {
int endIndex = str.indexOf(endStr, startIndex + startStr.length()); // 找到结束字符串的索引位置
if (endIndex != -1) {

String substring = str.substring(startIndex + startStr.length(), endIndex); // 获取符合条件的子字符串
System.out.println(substring); // 换行输出子字符串
information = information + substring + '\n';
startIndex = endIndex + endStr.length(); // 更新起始位置
} else {
break; // 如果没有找到结束字符串,则结束循环
}
} else {
break; // 如果没有找到起始字符串,则结束循环
}
}
}
二:MainActivity
public class MainActivity extends AppCompatActivity {

public static final int TAKE_PHOTO = 1;

public static final int CHOOSE_PHOTO = 2;

private ImageView picture;

private Uri imageUri;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button takePhoto = (Button) findViewById(R.id.take_photo);
Button chooseFromAlbum = (Button) findViewById(R.id.choose_from_album);
picture = (ImageView) findViewById(R.id.picture);
takePhoto.setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View view) {
//用于存放拍下的照片
File outputImage = new File(getExternalCacheDir(), "output_image.jpg");
try {
if(outputImage.exists()){
outputImage.delete();
}
outputImage.createNewFile();
} catch (IOException e) {
e.printStackTrace();
}
if(Build.VERSION.SDK_INT >= 24){
//File对象转换为Uri标识对象
System.out.println("outputImage = " + outputImage);
imageUri = FileProvider.getUriForFile(MainActivity.this, "com.launcher.photoshop.fileprovider", outputImage);
System.out.println("imageUri = " + imageUri);
}else{
//指定图片的输出地址
imageUri = Uri.fromFile(outputImage);
}
//隐式Intent,启动相机程序
Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);
startActivityForResult(intent, TAKE_PHOTO);
}
});
chooseFromAlbum.setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View v) {
if(ContextCompat.checkSelfPermission(MainActivity.this,
Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(MainActivity.this, new
String[] {Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1);
} else {
openAlbum();
}
}
});
}
private void openAlbum() {
Intent intent = new Intent("android.intent.action.GET_CONTENT");
intent.setType("image/*");
startActivityForResult(intent, CHOOSE_PHOTO);
}
@SuppressLint("MissingSuperCall")
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode) {
case TAKE_PHOTO:
if( resultCode == RESULT_OK ){
try{
Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(imageUri));
picture.setImageBitmap(bitmap);
// Android 4.0 之后不能在主线程中请求HTTP请求
new Thread(new Runnable(){
@Override
public void run() {
Main main = new Main();
main.qiuqiu(String.valueOf("/storage/emulated/0/Android/data/com.example.photoshop/cache/output_image.jpg"));
}
}).start();
} catch (FileNotFoundException e){
e.printStackTrace();
}
}
break;
case CHOOSE_PHOTO:
if(resultCode == RESULT_OK){
//判断版本型号
if(Build.VERSION.SDK_INT >= 19) {
//4.4以上版本
handleImageOnKitKat(data);
new Thread(new Runnable(){
@Override
public void run() {
Main main = new Main();
main.qiuqiu(String.valueOf("/storage/emulated/0/Android/data/com.example.photoshop/cache/output_image.jpg"));
}
}).start();
} else {
handleImageBeforeKitKat(data);
}
}
break;
default:
break;
}
}

@SuppressLint("MissingSuperCall")
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
switch (requestCode) {
case 1:
if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
openAlbum();
} else {
Toast.makeText(this, "You denide the permission", Toast.LENGTH_SHORT).show();
}
break;
default:
break;
}
}
@TargetApi(19)
private void handleImageOnKitKat(Intent data) {
String imagePath = null;
Uri uri = data.getData();
if(DocumentsContract.isDocumentUri(this, uri)) {
//如果是document类型的uri,则通过document id处理
String docId = DocumentsContract.getDocumentId(uri);
if("com.android.providers.media.documents".equals(uri.getAuthority())) {
Toast.makeText(this, "success01", Toast.LENGTH_SHORT).show();
String id = docId.split(":")[1];
String secletion = MediaStore.Images.Media._ID + "=" + id;
imagePath = getImagePath(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, secletion);
} else if("com.android.providers.downloads.documents".equals(uri.getAuthority())) {
Toast.makeText(this, "success02", Toast.LENGTH_SHORT).show();
Uri contentUri = ContentUris.withAppendedId(Uri.parse("content://downloads/public_downloads"), Long.valueOf(docId));
imagePath = getImagePath(contentUri, null);
}
} else if("content".equalsIgnoreCase(uri.getScheme())) {
Toast.makeText(this, "success03", Toast.LENGTH_SHORT).show();
//如果是content类型的Uri,则使用普通方式处理
imagePath = getImagePath(uri, null);
} else if("file".equalsIgnoreCase(uri.getScheme())) {
//如果是file类型的uri,则直接获取文件路径
Toast.makeText(this, "success04", Toast.LENGTH_SHORT).show();
imagePath = uri.getPath();
}
displayImage(imagePath);
}
private void handleImageBeforeKitKat(Intent data) {
Uri uri = data.getData();
String imagePath = getImagePath(uri, null);
displayImage(imagePath);
}
@SuppressLint("Range")
private String getImagePath(Uri uri, String seclection) {
String path = null;
//通过Uri和secletion来获取真实的图片路径
Cursor cursor = getContentResolver().query(uri, null, seclection, null, null);
if(cursor != null) {
if(cursor.moveToFirst()) {
path = cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.DATA));
}
cursor.close();
}
return path;
}
private void displayImage(String imagePath) {
if(imagePath != null) {
Bitmap bitmap = BitmapFactory.decodeFile(imagePath);
picture.setImageBitmap(bitmap);
} else {
Toast.makeText(this, "failed to get image", Toast.LENGTH_SHORT).show();
}
}
三 进行实现:
运行结果(手机上的结果):

 

 


四:参考:

(40条消息) 《第一行代码》8.3调用摄像头和相册-从相册中选择照片_滚雪球~的博客-CSDN博客




标签:调用,String,相册,data,uri,new,null,优化,out
From: https://www.cnblogs.com/wudisanrenzu/p/17410629.html

相关文章

  • 30、Nginx优化
    nginx如何优化更改nginx配置文件:1、工作进程的数量,设为和CPU核数相同2、结亲缘,cpu核与工作进程进行绑定,防止工作进程在cpu上来回跳转3、设置工作进程优先级orker_priority-204、nginx能打开的文件数量上限worker_rlimit_nofile100000;和ulimit-n数量一致,ulimit-n100000......
  • 视差滚动的爱情故事之优化篇
    上篇博客链接:视差滚动的爱情故事 【优化问题:解决Chrome下跳动的bug】 在上一篇的爱(diao)情(si)故事里面,demo3在Chrome下是这样的问题:鼠标滚动视差元素动画生硬,鬼畜跳动,拖动滚动条却没有这样的问题。之前也分析过,是因为Chrome只触发一次scroll事件导致的(还有个上下跳动的原因,博客......
  • bayesian优化demo运行
    bayesian优化demo运行参考链接:贝叶斯优化准备工作在所使用的python版本下,应有一个bayes_opt目录如下:如果没有这个目录,可以用pipinstallbayesian-optimization命令下载demo代码新建一个python文件basic_bayesian.py,其中代码如下:defblack_box_function(x,y):"""Fun......
  • C++调用python过程+Anaconda使用arcpy包踩的坑
    C++调python(python文件包含第三方库):工具:VS2017QT5插件PycharmAnaconda1.下载Anaconda,配置一个虚拟环境2.将这个环境里的DLLs和Lib包以及相应py文件,放至C++项目生成.exe文件同级目录下 3.将include和libs放在项目某文件夹下,在VS里添加附加包含目录、附加库目录和附加依赖......
  • 基于储能电站服务的冷热微网系统双层优化 建立考虑不同时间尺
    基于储能电站服务的冷热微网系统双层优化建立考虑不同时间尺度问题的双层规划模型上层负责求解长时间尺度的储能配置问题下层求解短时间尺度的微网优化运行问题才用KKT条件将双层转化为单层又采用大M法将模型线性化处理最后用cplex/gurobi求解器进行求解ID:94150696225026353......
  • python调用企业微信webhook发送消息
    官方文档:群机器人配置说明-文档-企业微信开发者中心发送图片解决:{"errcode":301019,"errmsg":"mediamd5notmatch,hint:[1684315383531332325922225],fromip:222.71.242.114,moreinfoathttps://open.work.weixin.qq.com/devtool/query?e=301019"}这个是瞎......
  • React.FC中父组件调用子组件方法
    https://blog.csdn.net/qq_36990322/article/details/1098588901.函数式和hooks写法其实下面的缺点基本不算缺点了,因为函数式写法,下面算是简单的了。使用forwardRef只会让你的组件定义的更复杂优点:1、写法简单易懂2、假如子组件嵌套了HOC,也可以指向真实子组件缺点:1、需要自定......
  • 数据大盘加载耗时较长的优化案例
    背景:有一个数据大盘的需求,统计组织下的所有人员,优化前数据的加载耗时近30秒 优化思路:一、定位加载耗时慢的代码片段PHP里dump+die是我们经常用并且个人觉得是很好用的调试工具,利用这个特性,我们可以定位出哪些代码片段的加载是耗时最多的 二、逐个优化在优化过程中,可以将......
  • mysql 调优-sql 优化
    连接查询原理涉及到indexnested-loopjoin,blocknested-loopjoin,joinbuffersize,hashjoin(mysql8)等,感觉没必要记那么多需要知道会一次性把驱动表的数据加载到内存中(如果joinbuffersize放得下),然后循环每个驱动表去对比被驱动表的数据就好了保证被驱动表的JOIN字......
  • aop监控接口调用
    SpringBoot+AOP实现记录操作日志和异常日志,并保存到数据库_springboot请求日志保存数据库_C3Stones的博客-CSDN博客 springAOP实现操作日志记录,并记录请求参数与编辑前后字段的具体改变-香吧香-博客园(cnblogs.com)......