• Android仿iPhone晃动撤销输入功能(微信摇一摇功能)


          很多程序中我们可能会输入长文本内容,比如短信,写便笺等,如果想一次性撤销所有的键入内容,很多手机需要一直按住退格键逐字逐句的删除,稍稍麻烦,不过 在iPhone上,有个人性化的功能,当我们想要去撤销刚刚输入的所有内容的时候,可以轻轻晃动手机,会弹出提示框,点击确定就可以清空内容,如下图:

                                             

          在 android中,一般手机貌似没有定制这个功能,不过我们可以自己去实现这样的功能,放置在我们的项目程序中,体现更人性化的设计,思路很简单,主要是 利用手机内置的加速度传感器装置,其实大家一定会想到微信的“摇一摇”功能,个人觉得该功能就应该是这样实现的,当我们错误输入并想撤销所有输入内容的时 候,可以摇晃我们的设备,弹出一个自定义的alertdialog,根据按钮的点击事件完成相应的清除操作。

    首先我们自己定义一个alertdialog,自己依据个人的设计写一个布局,之后在代码中创建一个AlertDialog并使用LayoutInflater载入写好的布局文件

         AlertDialog.Builder builder = new AlertDialog.Builder(this);
         dialog = builder.create();
         LayoutInflater inflater = LayoutInflater.from(this);
         LinearLayout layout = (LinearLayout) inflater.inflate( R.layout.alertdialog, null);

    当弹出对话框的时候,我们希望点击框外的空白处不会让对话框消失,我们可以设置如下属性:

        dialog.setCanceledOnTouchOutside(false);

    然后可以显现对话框,并自己定义其大小等属性:

       dialog.show();
       dialog.setContentView(layout, new LayoutParams(400, 250));

    ------------------------------------------------------------------------------------

    其次我们需要了解如何使用加速度传感器的相关的东西:

    1.获取系统的相关服务,所有传感器都须要通过SensorMannager来访问,sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);

    2.通过SensorManager对象获取相应的Sensor类型的对象,本例使用加速度传感器,其类型是TYPE_ACCELEROMETER,

        sensor = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);

    3.创建一个SensorEventListener 对象的监听器,来监测Sensor 事件,主要重写onSensorChanged方法。

    4.在onResume中注册监听事件,在注册时,会有监听器listener,感应装置sensor和灵敏度rate三个参数,其中灵敏度有四种:

        SENSOR_DELAY_FASTEST:最灵敏的,反应非常迅速

        SENSOR_DELAY_GAME:从名字可以看出多数游戏中会用到的频率

        SENSOR_DELAY_NORMAL:一般情况下使用的频率,比较慢,适用多数应用

        SENSOR_DELAY_UI:使用传感器更新UI中的数据,使用该值

    5.在onPause中取消注册监听事件

    ------------------------------------------------------------------------------------

    重写onSensorChanged方法时,使用SensorEvent的实例来获取一系列的值

       float values[] = event.values;
       float x = values[0];// x轴方向的重力加速度
       float y = values[1];// y轴方向的重力加速度
       float z = values[2];// z轴方向的重力加速度

    每个值的范围都介于-10~10之间,可以通过对各个方向值的判断来到达我们所需要的效果,即当各个方向上的数值满足一定条件后去触发我们预期的事件

    ------------------------------------------------------------------------------------

    PS:为了避免出现没有输入的时候摇晃也弹出窗口,或者在已经弹出对话框后继续摇晃还会弹窗,我们可以使用一个自己定义的标志位加以控制

    下为主要代码部分以及实现后的效果图

    1. <span style="font-family:Comic Sans MS;font-size:18px;">package com.example.shakedemo;  
    2.   
    3. import android.hardware.Sensor;  
    4. import android.hardware.SensorEvent;  
    5. import android.hardware.SensorEventListener;  
    6. import android.hardware.SensorManager;  
    7. import android.os.Bundle;  
    8. import android.os.Vibrator;  
    9. import android.view.LayoutInflater;  
    10. import android.view.View;  
    11. import android.view.ViewGroup.LayoutParams;  
    12. import android.widget.Button;  
    13. import android.widget.EditText;  
    14. import android.widget.LinearLayout;  
    15. import android.app.Activity;  
    16. import android.app.AlertDialog;  
    17.   
    18. public class MainA extends Activity {  
    19.   
    20.     private SensorManager sensorManager;  
    21.     private Vibrator vibrator;//手机的振动  
    22.     private EditText txt_content;  
    23.     private Button btn_delete, btn_cancle;  
    24.     private AlertDialog dialog;  
    25.     private Sensor sensor;  
    26.     private boolean hasShaked = false;// 判断是否已经摇晃的标志位  
    27.   
    28.     private SensorEventListener listener = new SensorEventListener() {  
    29.   
    30.         @Override  
    31.         public void onSensorChanged(SensorEvent event) {  
    32.             // TODO Auto-generated method stub  
    33.             float values[] = event.values;  
    34.             float x = values[0];// x轴方向的重力加速度  
    35.             float y = values[1];// y轴方向的重力加速度  
    36.             float z = values[2];// z轴方向的重力加速度  
    37.               
    38.             //这里设置的一个阈值为18,经测试比较满足一般的摇晃,也可以自己按需定义修改  
    39.             int medumValue = 18;  
    40.             if ((Math.abs(x) > medumValue || Math.abs(y) > medumValue || Math  
    41.                     .abs(z) > medumValue) && hasShaked == false) {  
    42.                 if ((!(txt_content.getText().toString().equals("")))  
    43.                         && hasShaked == false) {  
    44.                     vibrator.vibrate(200);//设置振动的频率  
    45.                     showDialog();  
    46.                     hasShaked = true;  
    47.                 }  
    48.             }  
    49.         }  
    50.   
    51.         @Override  
    52.         public void onAccuracyChanged(Sensor sensor, int accuracy) {  
    53.             // TODO Auto-generated method stub  
    54.   
    55.         }  
    56.     };  
    57.   
    58.     @Override  
    59.     protected void onCreate(Bundle savedInstanceState) {  
    60.         super.onCreate(savedInstanceState);  
    61.         setContentView(R.layout.main);  
    62.         sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);  
    63.         sensor = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);  
    64.         vibrator = (Vibrator) getSystemService(VIBRATOR_SERVICE);  
    65.         txt_content = (EditText) findViewById(R.id.txt_content);  
    66.     }  
    67.   
    68.     private void showDialog() {  
    69.         AlertDialog.Builder builder = new AlertDialog.Builder(this);  
    70.         dialog = builder.create();  
    71.         LayoutInflater inflater = LayoutInflater.from(this);  
    72.         LinearLayout layout = (LinearLayout) inflater.inflate(  
    73.                 R.layout.alertdialog, null);  
    74.         dialog.setCanceledOnTouchOutside(false);//点击框外的空白处不会让对话框消失  
    75.         dialog.show();  
    76.         dialog.setContentView(layout, new LayoutParams(400, 250));  
    77.   
    78.         btn_delete = (Button) layout.findViewById(R.id.btn_delete);  
    79.         btn_delete.setOnClickListener(new OnClick());  
    80.         btn_cancle = (Button) layout.findViewById(R.id.btn_cancle);  
    81.         btn_cancle.setOnClickListener(new OnClick());  
    82.     }  
    83.   
    84.     class OnClick implements android.view.View.OnClickListener {  
    85.   
    86.         @Override  
    87.         public void onClick(View v) {  
    88.             // TODO Auto-generated method stub  
    89.             switch (v.getId()) {  
    90.             case R.id.btn_delete:  
    91.                 txt_content.getText().clear();  
    92.                 dialog.dismiss();  
    93.                 hasShaked = false;  
    94.                 break;  
    95.             case R.id.btn_cancle:  
    96.                 dialog.dismiss();  
    97.                 hasShaked = false;  
    98.             default:  
    99.                 break;  
    100.             }  
    101.         }  
    102.   
    103.     }  
    104.   
    105.     @Override  
    106.     protected void onResume() {  
    107.         // TODO Auto-generated method stub  
    108.         super.onResume();  
    109.         //注册监听事件  
    110.         if (sensorManager != null) {  
    111.             sensorManager.registerListener(listener, sensor,  
    112.                     SensorManager.SENSOR_DELAY_NORMAL);  
    113.         }  
    114.     }  
    115.   
    116.     @Override  
    117.     protected void onPause() {  
    118.         // TODO Auto-generated method stub  
    119.         super.onPause();  
    120.         //取消监听  
    121.         if (sensorManager != null) {  
    122.             sensorManager.unregisterListener(listener);  
    123.         }  
    124.     }  
    125.   
    126. }  
    127.   
    128.   
    129. </span>  


                                                    

    点击“撤销键入”,即可将文字清空!

     
     
  • 相关阅读:
    linux 总结一下git reset的各个选项吧
    深入C++的new
    Android中binderDied()以及"Unknown binder error code" 出现的原因说明
    C/C++语言void及void指针深层探索
    Android 不通过USB数据线调试的方法
    Android Browser Gallery3D无法两指手势缩放
    Android eMMC Booting
    android基础知识13:AndroidManifest.xml文件解析
    Package sunjava6jdk is not available Ubuntu 10.04 LTS 安装sunjava6jdk ,出现错误
    SQL Server 2008中Service Broker基础应用(上)
  • 原文地址:https://www.cnblogs.com/xgjblog/p/4037657.html
Copyright © 2020-2023  润新知