Android手势操作(三)

简介: mainActivity如下: package cn.c; import java.io.File; import java.util.ArrayList; import java.

mainActivity如下:

package cn.c;
import java.io.File;
import java.util.ArrayList;
import java.util.Set;
import android.app.Activity;
import android.gesture.Gesture;
import android.gesture.GestureLibraries;
import android.gesture.GestureLibrary;
import android.gesture.GestureOverlayView;
import android.gesture.GestureOverlayView.OnGestureListener;
import android.gesture.Prediction;
import android.os.Bundle;
import android.os.Environment;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnKeyListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
/**
 * 需求描述:
 * 绘制手势,如已经存在则提示;不存在则可保存
 * 该例子是Android手势识别(一)(二)的综合
 * 遇到的问题:
 * 利用mGestureOverlayView.clear(true)不能清除手势.
 * 解决办法:
 * mGestureOverlayView.clear(true)
 * mGestureOverlayView.cancelGesture();
 * 
 */
public class MainActivity extends Activity {
    private EditText mEditText;
    private GestureOverlayView mGestureOverlayView;
    private GestureLibrary mGestureLibrary;
    private Gesture mGesture;
    private Button mSaveButton;
    private Button mResetButton;
    private String mGestureLibraryPath;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        init();
    }

	private void init() {
		mEditText = (EditText) findViewById(R.id.editText);
		mEditText.setOnKeyListener(new OnKeyListener() {
			public boolean onKey(View v, int keyCode, KeyEvent event) {
				if (mGesture!=null&&mEditText.getText().toString().length()>0) {
					mSaveButton.setEnabled(true);
				} else {
					mSaveButton.setEnabled(false);
				}
				return false;
			}
		});
		mGestureOverlayView = 
		(GestureOverlayView) findViewById(R.id.gestureOverlayView);
		mSaveButton = (Button) findViewById(R.id.saveButton);
		mSaveButton.setOnClickListener(new ButtonOnClickListenerImpl());
		mSaveButton.setEnabled(false);
		mResetButton = (Button) findViewById(R.id.resetButton);
		mResetButton.setOnClickListener(new ButtonOnClickListenerImpl());
		//GestureLibrary文件的路径
		mGestureLibraryPath =
		Environment.getExternalStorageDirectory()+File.separator+"gestures9527";
		//为GestureOverlayView添加监听事件
		//多笔监听
		mGestureOverlayView.addOnGestureListener(new GestureListenerImpl());
	}
	private class GestureListenerImpl implements OnGestureListener{
		//开始绘制手势
		public void onGestureStarted(GestureOverlayView overlay,MotionEvent event) {
			mSaveButton.setEnabled(false);
			mGesture=null;
		}
		public void onGesture(GestureOverlayView overlay, MotionEvent event) {
		}
        //手势绘制结束
		public void onGestureEnded(GestureOverlayView overlay, MotionEvent event) {
			boolean isSaved = false;
			mGesture = mGestureOverlayView.getGesture();
			mGestureLibrary = GestureLibraries.fromFile(mGestureLibraryPath);
			if (mGestureLibrary.load()) {
				ArrayList<Prediction> predictionsList = mGestureLibrary.recognize(mGesture);
				if (predictionsList.size() > 0) {
					System.out.println("xxxx1111 开始对比");
					Prediction bestPrediction = predictionsList.get(0);
					if (bestPrediction.score > 5.0) {
						isSaved = true;
						mGestureOverlayView.clear(true);
						mGestureOverlayView.cancelGesture();
						mSaveButton.setEnabled(false);
						mEditText.setText("");
						Toast.makeText(MainActivity.this, "手势已存在",Toast.LENGTH_SHORT).show();
					}
				} else {
					isSaved = false;
					System.out.println("xxxx1111 手势不存在");
				}
			} else {
				System.out.println("xxxxx 1111手势库打开失败");
			}
			// 1 手势不为空
			// 2 手势名正确
			// 3 手势未保存
			// 保存手势
			if (mGesture != null && mEditText.getText().toString().length() > 0&& !isSaved) {
				mSaveButton.setEnabled(true);
			}
		}
		public void onGestureCancelled(GestureOverlayView overlay,MotionEvent event) {
		}
	}
	
	private class ButtonOnClickListenerImpl implements OnClickListener {
		public void onClick(View v) {
			switch (v.getId()) {
			case R.id.resetButton:
				mGestureOverlayView.clear(true);
				mSaveButton.setEnabled(false);
				mEditText.setText("");
				break;
			case R.id.saveButton:
				String gestureName = mEditText.getText().toString();
				try {
					File gestureLibraryFile = new File(mGestureLibraryPath);
					// fromFile()加载该路径下的手势库.
					// 若不存在,则会在路径下创建一个手势库
					mGestureLibrary = GestureLibraries.fromFile(mGestureLibraryPath);
					if (!gestureLibraryFile.exists()) {
						System.out.println("gestureLibraryFile 文件不存在");
						mGestureLibrary.addGesture(gestureName, mGesture);
						if (mGestureLibrary.save()) {
							//只有执行完mGestureLibrary.save()的时候
							//gestureLibraryFile文件才不为空
							mSaveButton.setEnabled(false);
							mEditText.setText("");
							mGestureOverlayView.clear(true);
							System.out.println("xxx 成功");
						} else {
							System.out.println("xxx 失败");
						}
					} else {
						if (!mGestureLibrary.load()) {
							System.out.println("xxxx1111 加载手势库失败");
						} else {
							Set<String> gesturyies = mGestureLibrary.getGestureEntries();
							// 删除已经存在的同名的手势
							if (gesturyies.contains(gestureName)) {
								ArrayList<Gesture> list = mGestureLibrary.getGestures(gestureName);
								for (int i = 0; i < list.size(); i++) {
									mGestureLibrary.removeGesture(gestureName,list.get(i));
								}
							}
							// 添加手势
							mGestureLibrary.addGesture(gestureName, mGesture);
							// 判断手势是否保存成功
							if (mGestureLibrary.save()) {
								mGestureOverlayView.clear(true);
								mSaveButton.setEnabled(true);
								mEditText.setText("");
								System.out.println("xxxx1111 手势保存成功");
							} else {
								System.out.println("xxxx1111 手势保存失败");
							}

						}
					}
				} catch (Exception e) {
				}
				break;
			default:
				break;
			}
		}

	}
}


 


main.xml

<RelativeLayout 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" >

    <LinearLayout
        android:id="@+id/linearLayout"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:orientation="horizontal" >

        <TextView
            android:id="@+id/textView"
            android:layout_width="100dip"
            android:layout_height="wrap_content"
            android:text="手势的名称:" />

        <EditText
            android:id="@+id/editText"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:hint="在此输入" />
    </LinearLayout>
 <android.gesture.GestureOverlayView
     android:id="@+id/gestureOverlayView"
     android:layout_width="fill_parent"
     android:layout_height="fill_parent"
     android:layout_below="@id/linearLayout"
     android:layout_marginBottom="50dip"
     android:gestureStrokeType="multiple"
  />
  <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="50dip"
        android:layout_alignParentBottom="true"
        android:orientation="horizontal" >
    <Button 
        android:id="@+id/saveButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1" 
        android:text="保存"
        />
     <Button 
        android:id="@+id/resetButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1" 
        android:text="重置"
        />
   </LinearLayout>
 
</RelativeLayout>


 

相关文章
|
Android开发
Android手势操作耍起来!
目录 前言 初步了解手势操作 六个重写方法 小栗子体验一下 别忘了双击事件 最后 前言 手势操作是Android交互当中至关重要的. 可以说, 如果一个软件没有好的手势操作, 就不能将其定义为移动端的软件.
1070 0
|
Android开发
Android手势操作(二)
mainActivity如下: package cn.c; import java.io.File; import java.util.ArrayList; import android.
782 0
|
Android开发
Android手势操作(一)
mainActivity如下: package cn.c; import java.io.File; import java.util.ArrayList; import java.
737 0
|
28天前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
15天前
|
搜索推荐 前端开发 API
探索安卓开发中的自定义视图:打造个性化用户界面
在安卓应用开发的广阔天地中,自定义视图是一块神奇的画布,让开发者能够突破标准控件的限制,绘制出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战技巧,逐步揭示如何在安卓平台上创建和运用自定义视图来提升用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开新的视野,让你的应用在众多同质化产品中脱颖而出。
40 19
|
28天前
|
IDE Java 开发工具
移动应用与系统:探索Android开发之旅
在这篇文章中,我们将深入探讨Android开发的各个方面,从基础知识到高级技术。我们将通过代码示例和案例分析,帮助读者更好地理解和掌握Android开发。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。让我们一起开启Android开发的旅程吧!
|
15天前
|
JSON Java API
探索安卓开发:打造你的首个天气应用
在这篇技术指南中,我们将一起潜入安卓开发的海洋,学习如何从零开始构建一个简单的天气应用。通过这个实践项目,你将掌握安卓开发的核心概念、界面设计、网络编程以及数据解析等技能。无论你是初学者还是有一定基础的开发者,这篇文章都将为你提供一个清晰的路线图和实用的代码示例,帮助你在安卓开发的道路上迈出坚实的一步。让我们一起开始这段旅程,打造属于你自己的第一个安卓应用吧!
41 14
|
18天前
|
Java Linux 数据库
探索安卓开发:打造你的第一款应用
在数字时代的浪潮中,每个人都有机会成为创意的实现者。本文将带你走进安卓开发的奇妙世界,通过浅显易懂的语言和实际代码示例,引导你从零开始构建自己的第一款安卓应用。无论你是编程新手还是希望拓展技术的开发者,这篇文章都将为你打开一扇门,让你的创意和技术一起飞扬。