疯狂android讲义有什么用,疯狂Android讲义--- 一些有手写识别意思的小玩意儿

2023-12-09 21:30

本文主要是介绍疯狂android讲义有什么用,疯狂Android讲义--- 一些有手写识别意思的小玩意儿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

疯狂Android讲义--- 一些有意思的小玩意儿

[x] 增强手势

[x] 手势的识别

[x] 自动朗读(TTS)

今天来一波新鲜小程序~~

294d9fc75a88

gesture.gif

增强手势

来来来....先上新布局控件--GestureOverlayView(一个记录手势的平台)

activity_main_xml

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:text="@string/gestureTip"

android:textStyle="bold"

android:textSize="22sp"/>

android:id="@+id/gesture"

android:layout_width="match_parent"

android:layout_height="410dp"

android:gestureStrokeType="multiple"/>

MainActivity

Android 使用GestureLibrary来代表手势库,并提供了GestureLibraries工具类来创建手势库,并且 GestureLibraries 还提供了以下四个静态方法:

static GrstureLibrary fromFile(String path):从path代表的文件中加载手势库

staic Gesturelirary froPrivateFile context.Stingname): 从指定应用程序的数据文件夹的mame 文件中加载手势库

static GesturelLibrary fromRawResource(Context context,int resourceld)从所代表的资源中加载手势库

void addGesture(Sting entyName,Gesturegesture): 添加一个名为entyName 的手势

ArrayList getGestures(String entryName): 获取entry Name 名称对应的全部手势

ArrayListrecognize(Gesture gesture): 从当前手势库中识别与gesture匹配的全部手势

void removeEntry(String entryName): 制除手势库中entryName 对应的手势

void removeGesture(String entryName,Gesture gesture): 删除手势库中entyYame、gesture 对应的手势。

bolean save():当向手势库中添加手势或从中删除手势后调用该方法保存手势库

//获取文本编辑框

mEditText = (EditText)findViewById(R.id.gesture_name);

//获取手势编辑框

mGestureView = (GestureOverlayView) findViewById(R.id.gesture);

//设置手势绘制的颜色

mGestureView.setGestureColor(Color.RED);

//设置手势绘制的宽度

mGestureView.setGestureStrokeWidth(8);

//为gesture设置监听器

mGestureView.addOnGesturePerformedListener(

new OnGesturePerformedListener() {

@Override

public void onGesturePerformed(GestureOverlayView overlay, final Gesture gesture) {

//加载save.xml界面布局所代表的视图

View saveDialog = getLayoutInflater().inflate(R.layout.save,null);

//获取saveDialog的show组件

ImageView imageView = (ImageView) saveDialog.findViewById(R.id.show);

//获取saveDialog里的gesture_name组件

final EditText gestureName = (EditText) saveDialog.findViewById(R.id.gesture_name);

//根据Gesture包含的手势创建一个位图

Bitmap bitmap = gesture.toBitmap(128,128,10,0xffff0000);

//将那个将位图用图片显示出来

imageView.setImageBitmap(bitmap);

//使用对话框显示saveDialog的组件

new AlertDialog.Builder(MainActivity.this)

.setView(saveDialog)

.setPositiveButton("保存", new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

//获取指定文件对应的收拾库

gestureLib = GestureLibraries

.fromFile("/wanghao");

//添加手势

gestureLib.addGesture(gestureName.getText().toString(),gesture);

//保存手势库

gestureLib.save();

}

}).setNegativeButton("取消",null).show();

}

}

);

手势的识别

布局呢。。。。就很简单了,如果看过上面的代码的话,相信可以自己写一个GestureOverlayView了吧

重要的就是gestureAcitvity.java

gestureLibrary_1 = GestureLibraries

.fromFile("/wanghao");

if (gestureLibrary_1.load()){

Toast.makeText(getsureActivity.this, "手势装载成功", Toast.LENGTH_SHORT).show();

}else {

Toast.makeText(getsureActivity.this, "手势装载失败", Toast.LENGTH_SHORT).show();

}

gestureView = (GestureOverlayView) findViewById(R.id.gesture_1);

gestureView.addOnGesturePerformedListener(

new GestureOverlayView.OnGesturePerformedListener() {

@Override

public void onGesturePerformed(GestureOverlayView overlay, Gesture gesture) {

ArrayList predictions = gestureLibrary_1

.recognize(gesture);

ArrayList result = new ArrayList<>();

for (Prediction pred : predictions) {

if (pred.score > 2.0){

result.add("与手势【" + pred.name + "】相似度为" + pred.score);

}

}

if (result.size() > 0){

ArrayAdapter adapter = new ArrayAdapter(getsureActivity.this,

android.R.layout.simple_dropdown_item_1line,result.toArray());

new AlertDialog.Builder(getsureActivity.this)

.setAdapter(adapter,null)

.setPositiveButton("确定",null).show();

}else {

Toast.makeText(getsureActivity.this, "无法找到匹配的手势", Toast.LENGTH_SHORT).show();

}

}

}

);

}

自动朗读

这个布局么。。。EditText + 两个Button,相信大家也应该学会了吧

直接走逻辑

GestureLibrary提供了recognize(Festure ges)方法来识别手势,

该方法会返回手势库中所有与ges相匹配的手势

recognize(Festure ges)方法的返回值为ArrayList

prediction封装了手势的匹配信息

Prediction对象的name属性代表了匹配的手势名,score代表了手势的相似度

TextToSpeech tts;

EditText mEditText;

Button speech;

Button record;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_tts);

//初始化TextToSpeech对象

tts = new TextToSpeech(this, new TextToSpeech.OnInitListener() {

@Override

public void onInit(int status) {

//如果TTS引擎成功

if (status == TextToSpeech.SUCCESS){

//设置使用美式英语朗读

int result = tts.setLanguage(Locale.US);

//如果不支持所设置的语言

if (result != TextToSpeech.LANG_COUNTRY_AVAILABLE

&& result != TextToSpeech.LANG_AVAILABLE){

Toast.makeText(TtsActivity.this, "TTS暂时还不支持这种语言的朗读",

Toast.LENGTH_SHORT).show();

}

}

}

});

mEditText = (EditText) findViewById(R.id.txt);

speech = (Button ) findViewById(R.id.speech);

record = (Button) findViewById(R.id.record);

speech.setOnClickListener(new View.OnClickListener() {

@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)

@Override

public void onClick(View v) {

//执行朗读

tts.speak(mEditText.getText().toString(),

TextToSpeech.QUEUE_ADD,null,"speed");

}

});

record.setOnClickListener(new View.OnClickListener() {

@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)

@Override

public void onClick(View v) {

//将朗读文本音频尽录到指定文件

tts.synthesizeToFile(mEditText.getText().toString(),null,

new File("/wanghao"),"record");

Toast.makeText(TtsActivity.this, "声音记录成功", Toast.LENGTH_SHORT).show();

}

});

}

//

//一定要在Activity回调之前关闭TextSpeech对象

@Override

protected void onDestroy() {

super.onDestroy();

//关闭TextSpeech对象

if (tts != null){

tts.shutdown();

}

}

最最最重要的,可别忘了饿哦们这可是访问SD卡的

从Android4.0开始读取SD卡就成为危险了,所以尽快加上一行代码

不过这个简单的朗读最大的缺陷就是无法朗读中文~~~~~~~~

这篇关于疯狂android讲义有什么用,疯狂Android讲义--- 一些有手写识别意思的小玩意儿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio