专栏首页恩蓝脚本Android实现iPhone晃动撤销输入功能 Android仿微信摇一摇功能

Android实现iPhone晃动撤销输入功能 Android仿微信摇一摇功能

很多程序中我们可能会输入长文本内容,比如短信,写便笺等,如果想一次性撤销所有的键入内容,很多手机需要一直按住退格键逐字逐句的删除,稍稍麻烦,不过在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:为了避免出现没有输入的时候摇晃也弹出窗口,或者在已经弹出对话框后继续摇晃还会弹窗,我们可以使用一个自己定义的标志位加以控制

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

import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.os.Vibrator;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.app.Activity;
import android.app.AlertDialog;
public classMainAextendsActivity{
private SensorManagersensorManager;
private Vibratorvibrator;//手机的振动
private EditTexttxt_content;
private Buttonbtn_delete,btn_cancle;
private AlertDialogdialog;
private Sensorsensor;
private booleanhasShaked=false;//判断是否已经摇晃的标志位
private SensorEventListenerlistener=newSensorEventListener(){
@Override
public void on SensorChanged(SensorEventevent){
//TODOAuto-generatedmethodstub
floatvalues[]=event.values;
floatx=values[0];//x轴方向的重力加速度
floaty=values[1];//y轴方向的重力加速度
floatz=values[2];//z轴方向的重力加速度
//这里设置的一个阈值为18,经测试比较满足一般的摇晃,也可以自己按需定义修改
intmedumValue=18;
if((Math.abs(x) medumValue||Math.abs(y) medumValue||Math
.abs(z) medumValue)&&hasShaked==false){
if((!(txt_content.getText().toString().equals("")))
&&hasShaked==false){
vibrator.vibrate(200);//设置振动的频率
showDialog();
hasShaked=true;
}
}
}
@Override
publicvoidonAccuracyChanged(Sensorsensor,intaccuracy){
//TODOAuto-generatedmethodstub
}
};
@Override
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
sensorManager=(SensorManager)getSystemService(SENSOR_SERVICE);
sensor=sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
vibrator=(Vibrator)getSystemService(VIBRATOR_SERVICE);
txt_content=(EditText)findViewById(R.id.txt_content);
}
private void showDialog(){
AlertDialog.Builderbuilder=newAlertDialog.Builder(this);
dialog=builder.create();
LayoutInflaterinflater=LayoutInflater.from(this);
LinearLayoutlayout=(LinearLayout)inflater.inflate(
R.layout.alertdialog,null);
dialog.setCanceledOnTouchOutside(false);//点击框外的空白处不会让对话框消失
dialog.show();
dialog.setContentView(layout,newLayoutParams(400,250));
btn_delete=(Button)layout.findViewById(R.id.btn_delete);
btn_delete.setOnClickListener(newOnClick());
btn_cancle=(Button)layout.findViewById(R.id.btn_cancle);
btn_cancle.setOnClickListener(newOnClick());
}
classOnClickimplementsandroid.view.View.OnClickListener{
@Override
publicvoidonClick(Viewv){
//TODOAuto-generatedmethodstub
switch(v.getId()){
caseR.id.btn_delete:
txt_content.getText().clear();
dialog.dismiss();
hasShaked=false;
break;
caseR.id.btn_cancle:
dialog.dismiss();
hasShaked=false;
default:
break;
}
}
}
@Override
protectedvoidonResume(){
//TODOAuto-generatedmethodstub
super.onResume();
//注册监听事件
if(sensorManager!=null){
sensorManager.registerListener(listener,sensor,
SensorManager.SENSOR_DELAY_NORMAL);
}
}
@Override
protectedvoidonPause(){
//TODOAuto-generatedmethodstub
super.onPause();
//取消监听
if(sensorManager!=null){
sensorManager.unregisterListener(listener);
}
}
}

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

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Android实现3秒钟自动关闭界面

    功能如标题所示,简单的android的3秒倒计时关闭界面或点击关闭,如果3秒内点击就不会再开启自动关闭。看图说话,代码简单,注释清晰,一目了然:

    砸漏
  • Android 仿微信发动态九宫格拖拽、删除功能

    当选择完图片,长按图片拖拽过程中按下屏幕home键盘,再次进入这时候就不能点击输入文字,点击输入文字的时候会触发选择相册事件

    砸漏
  • Android实现遮罩层(蒙板)效果

    Android的遮罩效果就是把一张图片盖在另一张图片的上面,通过控制任意一张图片的显示百分比实现遮罩效果。下面我使用两张一样的图片来实现一个类似于 Androi...

    砸漏
  • Android Activity之间的跳转

    1、在应用中增加一个Activity,这需要修改AndroidManifest.xml文件

    week
  • [pytorch] 图像识别之GridMask

    GridMask: https://arxiv.org/abs/2001.04086

    MachineLP
  • Android编程实现捕获程序异常退出时的错误log信息功能详解

    本文实例讲述了Android编程实现捕获程序异常退出时的错误log信息功能。分享给大家供大家参考,具体如下:

    砸漏
  • __import__详解

    当使用import导入Python模块的时候,默认调用的是__import__()函数。直接使用该函数的情况很少见,一般用于动态加载模块。

    用户2936342
  • Android普通应用升级为系统应用并获取系统权限的操作

    有时候使用某些api需要使用系统权限,如调用PackageInstaller的相关接口,需要android.permission.INSTALL_PACKAGE...

    砸漏
  • 当飞桨PaddleHub遇到微信小程序,AI也能指物作诗

    最近飞桨PaddleHub大火,吸引无数开发者眼球,作为俗人的我也不例外,被看图写诗和艺术风格迁移两个模型吸引。假象一下,如果把AI和指物作诗的方仲永、江南四大...

    用户1386409
  • 安卓开发_浅谈OptionsMenus(选项菜单)

    听着music睡

扫码关注云+社区

领取腾讯云代金券