很多程序中我们可能会输入长文本内容,比如短信,写便笺等,如果想一次性撤销所有的键入内容,很多手机需要一直按住退格键逐字逐句的删除,稍稍麻烦,不过 在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. false) {
42. if ((!(txt_content.getText().toString().equals("")))
43. false) {
44. 200);//设置振动的频率
45. showDialog();
46. 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. new AlertDialog.Builder(this);
70. dialog = builder.create();
71. this);
72. LinearLayout layout = (LinearLayout) inflater.inflate(
73. null);
74. false);//点击框外的空白处不会让对话框消失
75. dialog.show();
76. new LayoutParams(400, 250));
77.
78. btn_delete = (Button) layout.findViewById(R.id.btn_delete);
79. new OnClick());
80. btn_cancle = (Button) layout.findViewById(R.id.btn_cancle);
81. 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. false;
94. break;
95. case R.id.btn_cancle:
96. dialog.dismiss();
97. 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>