通过GestureOverlayView手势库来识别手写的字

2024-05-30 06:32

本文主要是介绍通过GestureOverlayView手势库来识别手写的字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MainActivity 文件

package qianfeng.gesture;import android.gesture.Gesture;
import android.gesture.GestureLibraries;
import android.gesture.GestureLibrary;
import android.gesture.GestureOverlayView;
import android.gesture.Prediction;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.os.Environment;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.widget.ImageView;import java.io.File;
import java.util.ArrayList;public class Main4Activity extends AppCompatActivity {private static final String TAG = "Main4Activity";private GestureOverlayView mGestureOverlay;private ImageView mImage1,mImage2;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main4);mGestureOverlay = (GestureOverlayView) findViewById(R.id.overlay);mImage1 = (ImageView) findViewById(R.id.images1);mImage2 = (ImageView) findViewById(R.id.images2);mGestureOverlay.addOnGesturePerformedListener(new GestureOverlayView.OnGesturePerformedListener() {@Overridepublic void onGesturePerformed(GestureOverlayView overlay, Gesture gesture) {//将手势转换成图片显示Bitmap bitmap = gesture.toBitmap(100,100,10, Color.BLUE);mImage1.setImageBitmap(bitmap);GestureLibrary libraries = GestureLibraries.fromFile(Environment.getExternalStorageDirectory().getAbsolutePath()+"/getsure");//加载手势库if(libraries.load()){Log.e(TAG,"load");}else{Log.e(TAG,"load error");}//返回的一堆 相近的手势ArrayList<Prediction> recognize = libraries.recognize(gesture);//判断相似度if(recognize.size()>0){for (Prediction prediction : recognize){Log.e(TAG,prediction.score+"");//且当 相似度大于10if(prediction.score>10.0f){//手势库通过名称 获取该名称下的所有手势ArrayList<Gesture> gestures = libraries.getGestures(prediction.name);//由于我们的手势 使用的唯一名称 所以只需要判断大于0 获取第0个 就可以if(gestures.size()>0){Gesture gesture_temp = gestures.get(0);Bitmap bitmap1 = gesture_temp.toBitmap(100, 100, 10, Color.RED);mImage2.setImageBitmap(bitmap1);}}}}//添加手势到库libraries.addGesture(String.valueOf(System.currentTimeMillis()),gesture);//保存手势libraries.save();}});}
}

布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context="com.qf.gestureoverlayview.MainActivity"><LinearLayout
        android:orientation="horizontal"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"><ImageView
            android:background="#400f"android:id="@+id/img1"android:layout_weight="1"android:layout_width="0dp"android:layout_height="match_parent" /><ImageView
            android:id="@+id/img2"android:layout_weight="1"android:layout_width="0dp"android:layout_height="match_parent"/></LinearLayout><android.gesture.GestureOverlayView
        android:background="#000"android:id="@+id/gest"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:gestureStrokeType="multiple"android:gestureStrokeLengthThreshold="2"></android.gesture.GestureOverlayView>
</LinearLayout>

这篇关于通过GestureOverlayView手势库来识别手写的字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的

Pytorch微调BERT实现命名实体识别

《Pytorch微调BERT实现命名实体识别》命名实体识别(NER)是自然语言处理(NLP)中的一项关键任务,它涉及识别和分类文本中的关键实体,BERT是一种强大的语言表示模型,在各种NLP任务中显著... 目录环境准备加载预训练BERT模型准备数据集标记与对齐微调 BERT最后总结环境准备在继续之前,确

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

Clion不识别C代码或者无法跳转C语言项目怎么办?

如果是中文会显示: 此时只需要右击项目,或者你的源代码目录,将这个项目或者源码目录标记为项目源和头文件即可。 英文如下:

stl的sort和手写快排的运行效率哪个比较高?

STL的sort必然要比你自己写的快排要快,因为你自己手写一个这么复杂的sort,那就太闲了。STL的sort是尽量让复杂度维持在O(N log N)的,因此就有了各种的Hybrid sort algorithm。 题主你提到的先quicksort到一定深度之后就转为heapsort,这种是introsort。 每种STL实现使用的算法各有不同,GNU Standard C++ Lib

BERN2(生物医学领域)命名实体识别与命名规范化工具

BERN2: an advanced neural biomedical named entity recognition and normalization tool 《Bioinformatics》2022 1 摘要 NER和NEN:在生物医学自然语言处理中,NER和NEN是关键任务,它们使得从生物医学文献中自动提取实体(如疾病和药物)成为可能。 BERN2:BERN2是一个工具,