以下是要用到的主要的类
1.GestureDetector类的实例代表一个手势检测器,创建这个实例时要传入一个GestureDetector.OnGestureListener监听器;
2.GestureLibrary和GestureLibraries类,GestureOverlayView组件;GestureLibrary是一个手势库,可以理解为保存手势的类,GestureLibraries是一个工具
类为GestureLibrary创建实例。 *GestureOverlayView是手势编辑组件,可以理解为我们平常画图的笔,经常用的监听器是
是在手势事件完成时提供响应, public void onGesturePerformed(GestureOverlayView overlay, Gesture gesture)这是它提供的方法,gesture就是我们画的手势。
3.TextToSpeech(TTL)类是android提供的自动朗读的一个类;
以上类的用法
1. GestureDetector
第一步:创建实例GestureDetector detector = new GestureDetector(this,this);让主类 implements
GestureDetector.OnGestureListener。它包含的处理事件有 onDown(MotionEvent e)当触碰事件按下时触发该方法
onShowPress(MotionEvent e)当用户手指按下还未松开和移动时触发
onSingleTapUp(MotionEvent e)用户手指轻击触摸屏时触发
onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY)手指在触摸屏滚动时触发
onLongPress(MotionEvent e)长按时触发
onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)手指在触摸屏上“拖过”时触发,
velocityX,velocityY为速度。
第二步:把Activity的TouchEvent事件交给GestureDetector处理
@Override
public boolean onTouchEvent(MotionEvent event) {
return detector.onTouchEvent(event);
}
2. GestureLibrary和GestureLibraries类,GestureOverlayView组件;
GestureLibraries有如下几个静态方法来创建GesureLibrary的实例:
fromFile(String path)从path代表的文件中加载手势库
fromFile(File path)从path代表的文件中加载手势库
fromPrivateFile(Context context, String name)从指定应用程序的数据文件夹的name文件中加载手势库
fromRawResource(Context context, int resourceId)从resourceId所代表的资源中加载手势库
GestureLibraries提供了对手势添加等方法:
addGesture(String entryName, Gesture gesture)添加一个名为entryName的手势。
ArrayListrecognize(Gesture gesture)从当前手势库中识别与gesture匹配的全部手势
boolean save()对手势库进行添加,删除后要用此方法进行保存
其他删除等方法可以查询API;
GestureOverlayView在布局中使用
在Activity中获得
图片描述
根据上图中的onGesturePerformed(GestureOverlayView overlay, Gesture gesture)就可以用GestureLibrary和GestureLibraries类对gesture进行操作了
3.TextToSpeech(TTL)类
第一步:创建实例, TextToSpeech textToSpeech = new TextToSpeech(this, new TextToSpeech.OnInitListener() {
@Override
public void onInit(int status) {
if(status == TextToSpeech.SUCCESS){}//判断TTS引擎是否装载成功
}
});
第二步:设置语言,textToSpeech.setLanguage(Locale.US);不支持中文,
int result = textToSpeech.setLanguage(Locale.US);
if(result != TextToSpeech.LANG_COUNTRY_AVAILABLE && result != TextToSpeech.LANG_AVAILABLE){}//判断设置的语言是否可用
第三步:调用 speak()或者synthesizeToFile()方法
speak(CharSequence text, int queueMode, Bundle params, String utteranceId)第二个参数是有两种模式TextToSpeech.QUEUE_ADD是添加到当前队列之后,TextToSpeech.QUEUE_FLUSH中断当前任务,执行当前新的语音任务。
synthesizeToFile(CharSequence text, Bundle params, File file, String utteranceId)
第四步:关闭TTS,回收资源,textToSpeech.shutdown();
简单demo:https://github.com/islaughing/GestureStudio.git