zoukankan      html  css  js  c++  java
  • Android基本功:手势

    来自:http://www.cnblogs.com/android100/p/Android-hand-shi.html

    一、概念 

    • 手势:其实是指用户手指或触摸笔在屏幕上的连续触碰行为,Andoird对两种手势行为都提供了支持 

      • Andorid提供了手势检测,并为手势检测提供了相应的监听器 

      • Android允许开发者添加手势,并提供了相应的API识别用户手势 

       

    二、手势检测 

    • Gesture类:代表了一个手势检测器 

    • GestureDectector.OnGestureListener类:代表一个监听器、负责对用户的手势行为提供响应 

      • boolean onDown(MotionEvent e):当触碰事件按下时触发的方法 

      • boolean onFling(MotionEvent e1,MotionEvent e2,float velocityX,float velocityY):当用户在触摸屏上”拖过”时触发该方法,velocityX,velocityY代表“拖过”动作的横向、纵向上的速度 

      • abstract void onLongPress(MotionEvent e):当用户在屏幕上长按时触发该方法 

      • abstract void onScroll(MotionEvent e1,MotionEvent e2,float distanceX,float diastanceY):当用户在屏幕上“滚动”时触发该方法 

      • void onShowPress(MotionEvent e):当用户在屏幕上按下,而且还未移动和松动的时候触发该方法 

      • boolean onSingleTapUp(MotionEvent e):当用户在触摸屏上的轻击事件将会触发该方法 

     

    三、使用步骤 

    1. 创建一个GestureDetector对象,创建对象时候必须创建一个GestureDectector.OnGestureListener监听器实例; 

    2. 为应用程序的Activity(偶尔也可以为特定组件)的TouchEvent事件绑定监听器,在事件处理中制定把Activity(或特定组件)上的TouchEvent事件交给GestureDetector处理; 

     

    • 使用实例(chapter08/GestureTest 

    MainActivity.java文件  

    1. public class MainActivity extends Activity implements OnGestureListener {   
    2.     // 定义手势检测实例   
    3.     GestureDetector detector;   
    4.    
    5.     @Override   
    6.     protected void onCreate(Bundle savedInstanceState) {   
    7.         super.onCreate(savedInstanceState);   
    8.         setContentView(R.layout.main_activity);   
    9.    
    10.         // 创建手势检测器   
    11.         detector = new GestureDetector(this, this);   
    12.     }   
    13.    
    14.     @Override   
    15.     public boolean onTouchEvent(MotionEvent event) {   
    16.         // 将该Activity上的触碰事件交给GestureDetector处理   
    17.         return detector.onTouchEvent(event);   
    18.     }   
    19.    
    20.     @Override   
    21.     public boolean onDown(MotionEvent e) {   
    22.          // 触碰时间按下时触发该方法   
    23.         Toast.makeText(this, "OnDown", Toast.LENGTH_LONG).show();   
    24.         return false;   
    25.     }   
    26.    
    27.     @Override   
    28.     public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,   
    29. float velocityY) {   
    30.          // 当用户在屏幕上“拖动”时触发该方法   
    31.         Toast.makeText(this, "onFling", Toast.LENGTH_LONG).show();   
    32.         return false;   
    33.     }   
    34.    
    35.     @Override   
    36.     public void onLongPress(MotionEvent e) {   
    37.         // 当用户在屏幕上长按时触发该方法   
    38.         Toast.makeText(this, "onLongPress", Toast.LENGTH_LONG).show();   
    39.     }   
    40.    
    41.     @Override   
    42.     public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,   
    43. float distanceY) {   
    44.         // 当屏幕“滚动”时触发该方法   
    45.         Toast.makeText(this, "onScroll", Toast.LENGTH_LONG).show();   
    46.         return false;   
    47.     }   
    48.    
    49.     @Override   
    50.     public void onShowPress(MotionEvent e) {   
    51.         // 当用户在触摸屏幕上按下、而且还未移动和松开时触发该方法   
    52.         Toast.makeText(this, "onShowPress", Toast.LENGTH_LONG).show();   
    53.     }   
    54.    
    55.     @Override   
    56.     public boolean onSingleTapUp(MotionEvent e) {   
    57.         // 在屏幕上的轻击事件将会触发该方法   
    58.        Toast.makeText(this, "onSingleTapUp", Toast.LENGTH_LONG).show();   
    59.         return false;   
    60.     }   
    61. }   

    四、增加手势 

    • Android除了提供了手势之外,还允许应用程序把用户手势(多个持续的触摸事件在屏幕上形成特定的形状)添加到制定文件中,以备以后使用; 

    • GestureLibrary类:代表手势库,并提供了GestureLibraries工具来创建手势库,提供了如下4个静态方法从不同的位置加载手势: 

      • static GestureLibrary from(String path):从path代表的文件中加载手势库 

      • static GestureLibrary fromFile(File path):从path代表的文件加载手势库 

      • static GestureLibrary fromPrivateFile(Context context,String name):从制定应用程序的数据文件夹中name文件中加载手势库 

      • static GestureLibrary fromRawResoure(Context context,int resourceId):从resourceId所代表的资源中加载手势库 

     

    • 获取GestureLibrary对象之后,该对象提供了如下方法来添加手势和识别手势 

      • void addGesture(String entryName,Gesture gesture):添加一个名为name的手势 

      • Set<String> getGestureEntries():获取手势库中所有的手势名称 

      • ArrayList<GuesturegetGestures(String entryName):获取entryName名称对应的全部手势 

      • ArrayList<Prediction> recongize(Guesture gesture):从当前手势库中识别与gesture匹配的全部手势 

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

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

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

     

    • 为了监听GestureOverlayView组件上的手势事件,Android为GestureOverlayView提供了OnGestureLisnter、OnGesturePerformedListener、OnGesturingListener三个监听器接口,分别用于响应手势事件开始、结束、完成、取消事件; 

       

    • 使用实例(chapter08/AddGesture 

    main_activity.xml文件  

    1. <?xml version="1.0" encoding="utf-8"?>   
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    3.     android:layout_width="match_parent"   
    4.     android:layout_height="match_parent"   
    5.     android:orientation="vertical" >   
    6.     <TextView   
    7.         android:layout_width="match_parent"   
    8.         android:layout_height="wrap_content"   
    9.         android:gravity="center_horizontal"   
    10.         android:text="请在下面屏幕上绘制手势" />   
    11.     <!-- android:gestureStrokeType手势是否需要一笔完成-->   
    12.     <android.gesture.GestureOverlayView   
    13.         android:id="@+id/gesture"   
    14.         android:layout_width="match_parent"   
    15.         android:layout_height="match_parent"   
    16.         android:gestureStrokeType="multiple" />   
    17. </LinearLayout>   
     

    sava.xml文件  

    1. <?xml version="1.0" encoding="utf-8"?>   
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    3.     android:layout_width="match_parent"   
    4.     android:layout_height="match_parent"   
    5.     android:orientation="vertical" >   
    6.     <LinearLayout   
    7.         android:layout_width="match_parent"   
    8.         android:layout_height="wrap_content"   
    9.         android:orientation="horizontal" >   
    10.         <TextView   
    11.             android:layout_width="wrap_content"   
    12.             android:layout_height="wrap_content"   
    13.             android:layout_marginRight="8dip"   
    14.             android:text="请输入手势名称" />   
    15.         <!-- 定义一个文本框让用户输入手势名 -->   
    16.         <EditText   
    17.             android:id="@+id/gesture_name"   
    18.             android:layout_width="match_parent"   
    19.             android:layout_height="wrap_content" />   
    20.     </LinearLayout>   
    21.     <!-- 定义一个图片框来显示手势 -->   
    22.     <ImageView   
    23.         android:id="@+id/show"   
    24.         android:layout_width="match_parent"   
    25.         android:layout_height="128dp"   
    26.         android:layout_marginTop="10dp"   
    27.         android:layout_weight="0.29" />   
    28. </LinearLayout>   
     

    MainActivity.java文件  

    1. public class MainActivity extends Activity {   
    2.     EditText editText;   
    3.     GestureOverlayView gestureOverlayView;   
    4.    
    5.     @Override   
    6.     protected void onCreate(Bundle savedInstanceState) {   
    7.         super.onCreate(savedInstanceState);   
    8.         setContentView(R.layout.main_activity);   
    9.    
    10.         // 使用文本编辑器   
    11.         editText = (EditText) findViewById(R.id.gesture_name);   
    12.         // 获取手势编辑视图   
    13.         gestureOverlayView = (GestureOverlayView) findViewById(R.id.gesture);   
    14.         // 设置手势绘图的颜色   
    15.         gestureOverlayView.setGestureColor(Color.RED);   
    16.         // 设置手势的绘制宽度   
    17.         gestureOverlayView.setGestureStrokeWidth(4);   
    18.         // 为gesture的手势完成事件绑定事件监听器   
    19.         gestureOverlayView.addOnGesturePerformedListener(new OnGesturePerformedListener() {   
    20.    
    21.         @Override   
    22.         public void onGesturePerformed(GestureOverlayView overlay,final Gesture gesture) {   
    23.             // 加载save.xml界面布局代表的视图   
    24.             View saveDialog = getLayoutInflater().inflate(R.layout.save, null);   
    25.             // 获取saveDialog里的show组件   
    26.             ImageView imageView = (ImageView) saveDialog.findViewById(R.id.show);   
    27.             // 获取saveDialog的gesture_name组件   
    28.             final EditText gestureEditText = (EditText) saveDialog.findViewById(R.id.gesture_name);   
    29.            // 根据Gesture包含的手势创建一个位图   
    30.             Bitmap bitmap = gesture.toBitmap(128, 128, 10,0xffff0000);   
    31.             imageView.setImageBitmap(bitmap);   
    32.             // 使用对话框显示saveDialog组件   
    33.             new AlertDialog.Builder(MainActivity.this).setView(saveDialog).setPositiveButton("保存", new OnClickListener() {   
    34.                 @Override   
    35.                 public void onClick(DialogInterface dialog,int which) {   
    36.                    // 获取制定文件对应的手势库   
    37.                    GestureLibrary guestureLibrary = GestureLibraries.fromFile(Environment   
    38. .getExternalStorageDirectory().getPath()+ "/mygestures");   
    39.                   // 添加手势   
    40.                   guestureLibrary.addGesture(gestureEditText.getText().toString(), gesture);   
    41.                   guestureLibrary.save();   
    42.                 }   
    43.            }).setNegativeButton("取消", null).show(); }   
    44.         });   
    45.     }   
    46. }   

    五、识别用户手势 

    • recoginze(Gesture guesture)方法:识别手势,该方法将会返回该手势库中所有与ges匹配的手势两个手势的图形越相似,相似度越高 

    • recogniza(Gusture ges)方法返回为ArrayList<Prediction>,启动Prediction封装了手势的匹配信息,Predictin对象的name属性代表了匹配的手势名,score属性代表了手势的相似度; 

     

    • 应用实例(/chapter08/RecognizeGesture 

    main_activity.xml文件  

    1. <?xml version="1.0" encoding="utf-8"?>   
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    3.     android:layout_width="match_parent"   
    4.     android:layout_height="match_parent"   
    5.     android:orientation="vertical" >   
    6.     <android.gesture.GestureOverlayView   
    7.         android:id="@+id/gesture"   
    8.         android:layout_width="match_parent"   
    9.         android:layout_height="match_parent"   
    10.         android:gestureStrokeType="multiple" />   
    11. </LinearLayout>   
     

    MainActivity.java文件 

     

    1. public class MainActivity extends Activity {   
    2.     // 定义手机编辑组件   
    3.     GestureOverlayView gestureOverlayView;   
    4.     // 记录手机上已有的手势库   
    5.     GestureLibrary gestureLibrariLibrary;   
    6.    
    7.     @Override   
    8.     protected void onCreate(Bundle savedInstanceState) {   
    9.         super.onCreate(savedInstanceState);   
    10.         setContentView(R.layout.main_activity);   
    11.    
    12.         gestureOverlayView = (GestureOverlayView) findViewById(R.id.gesture);   
    13.         gestureLibrariLibrary = GestureLibraries.fromFile(Environment.getExternalStorageDirectory().getPath() + "/mygestures");   
    14.    
    15.         if (gestureLibrariLibrary.load()) {   
    16.             Toast.makeText(MainActivity.this, "手势文件装在成功", Toast.LENGTH_LONG).show();   
    17.         } else {   
    18.             Toast.makeText(MainActivity.this, "手势文件装在失败", Toast.LENGTH_LONG).show();   
    19.         }   
    20.    
    21.         // 定义手势编辑组件绑定监听器   
    22.         gestureOverlayView.addOnGesturePerformedListener(new OnGesturePerformedListener() {   
    23.    
    24.         @Override   
    25.         public void onGesturePerformed(GestureOverlayView overlay,Gesture gesture) {   
    26.             // 识别用户刚刚所绘制的手势   
    27.             ArrayList<Prediction> predictions = gestureLibrariLibrary.recognize(gesture);   
    28.             ArrayList<String> result = new ArrayList<String>();   
    29.             // 遍历所有找到的Prediction对象   
    30.             for (Prediction prediction : predictions) {   
    31.                 // 只有相似度大于0.2的手势才会被输出   
    32.                 if (prediction.score > 0.2) {   
    33.                     result.add("与手势{" + prediction.name + "}相似度为:"+ prediction.score);   
    34.                 }   
    35.             }   
    36.    
    37.             if (result.size() > 0) {   
    38.                 ArrayAdapter<Object> arrayAdapter = new ArrayAdapter<Object>(MainActivity.this,   
    39. android.R.layout.simple_dropdown_item_1line,   
    40.                 result.toArray());   
    41.                 new AlertDialog.Builder(MainActivity.this).setAdapter(arrayAdapter, null).setPositiveButton("确定", null).show();   
    42.             } else {   
    43.                Toast.makeText(MainActivity.this, "无法能找到匹配的手势",   
    44.                Toast.LENGTH_LONG).show();   
    45.             }   
    46.         }});   
    47.     }   
    48. }  
  • 相关阅读:
    [转] HashMap的工作原理
    [原创] hadoop学习笔记:hadoopWEB监控
    [编辑] 分享一些java视频
    [原创]spring学习笔记:关于springsource-tool-suite插件的安装
    [原创]安装Oracle 11gR2,以及如何在win8下使用plsql develper连接Oracle数据库 ,在这里和大家分享下
    dedecms _ 当前位置问题的代码
    form表单验证
    input 不支持HTML5的placeholder属性
    Dede文章列表
    DEDE首页调用{dede:field.content/}
  • 原文地址:https://www.cnblogs.com/gisoracle/p/6381854.html
Copyright © 2011-2022 走看看