android解锁动画效果,Android 5秒学会使用手势解锁功能

Android手势解锁

本文讲述的是一个手势解锁的库,可以定制显示隐藏宫格点、路径、并且带有小九宫格显示图,和震动!让你学会使用这个简单,高效的库!

先来一波效果效果展示:

e8fc0cf2a50b12379b40caaca8d00e59.gif

手势解锁效果

今天给大家介绍的是本人良心制作的一个手势解锁开源库,大家有什么建议和想法都可以发到我的邮箱: diosamolee2014@gmail.com 或者评论,我会为大家提供我力所能及的帮助!

GitHub地址:

添加依赖:

添加的gradle

第一步:

Add it in your root build.gradle at the end of repositories:

repositories {

maven { url "https://dl.bintray.com/freecoders/GestureLock"

}

}

第二步:

Step 2. Add the dependency

dependencies {

compile 'com.gesturelock:GestureLock:1.0'

}

布局使用:

下面是我测试时写的完整的所有布局:(懒人直接copy)

xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:app="http://schemas.android.com/apk/res-auto"

android:background="#ffffff"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:gravity="center"

>

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

android:gravity="center_horizontal"

android:padding="50dp">

android:textColor="#434242"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:textSize="16sp"

android:text="绘制图案"

android:paddingBottom="10dp"/>

android:id="@+id/lockviewIndicator"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

app:indicator_selected="@drawable/indicator_selected"

app:indicator_unselected="@drawable/indicator_unselected"

android:layout_gravity="center_horizontal"/>

android:id="@+id/tvMessage"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:textSize="14sp"

android:text=""

android:paddingTop="20dp"

/>

android:id="@+id/rl"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:paddingTop="30dp"

>

android:id="@+id/lockviewExpand"

android:layout_width="280dp"

android:layout_height="280dp"

app:lock_selected1="@drawable/gusture_icon_left"

app:lock_selected2="@drawable/gusture_icon_center"

app:lock_selected3="@drawable/gusture_icon_right"

app:lock_trackColor="#ff0432"

app:lock_selected_error="@drawable/circle_error"

app:lock_unselected="@drawable/gusture_icon_default"

android:layout_gravity="center_horizontal"/>

到这里小伙伴直接运行,就可以看到手势解锁的布局,大家也可以根据自己的需求去改变这个xml.

com.gestruelock.IndicatorLockView : 路径显示图,小的九个点

com.gestruelock.ExpandLockView: 手势解锁的九宫格

使用配置:

下面的代码是在Activity中直接使用的代码:(懒人直接copy)

public class MainActivity extends AppCompatActivity implements ExpandLockView.OnLockPanelListener, ExpandLockView.OnUpdateIndicatorListener, ExpandLockView.OnUpdateMessageListener, ExpandLockView.OnFinishDrawPasswordListener {

private ExpandLockView mLockviewExpand;

private IndicatorLockView lockviewIndicator;

private TextView tvMessage;

private Animation mShakeAnimal;

private Vibrator mVibrator;

//返回信息如果是正确的

private String succeeMsg="再次输入密码,密码已设置,密码正确,密码正确,请输入新密码";

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mLockviewExpand = (ExpandLockView) findViewById(R.id.lockviewExpand);

tvMessage = (TextView) findViewById(R.id.tvMessage);

lockviewIndicator = (IndicatorLockView) findViewById(R.id.lockviewIndicator);

mVibrator =(Vibrator)getApplication().getSystemService(Service.VIBRATOR_SERVICE); //震动

// mLockviewExpand.getPaintL().setStrokeWidth(20); //获取paint 修改连接线段的样式

// mLockviewExpand.setLock_trackColor(0xff0000); //给路径设置不同颜色

//加载动画资源文件

mShakeAnimal = AnimationUtils.loadAnimation(this, R.anim.shake);

mLockviewExpand.setActionMode(0);//set mode 设置手势密码

// mLockviewExpand.setActionMode(1);//set mode 验证手势密码

// mLockviewExpand.setActionMode(2);//set mode 更换手势密码

// mLockviewExpand.setHiddenTrack(true); //隐藏轨迹和按钮

mLockviewExpand.setShowError(true); //显示失败视图

// mLockviewExpand.setLockTime(2);//设置显示的锁住的时间

//设置各种回调事件

mLockviewExpand.setOnLockPanelListener(this);

mLockviewExpand.setOnUpdateIndicatorListener(this);

mLockviewExpand.setOnUpdateMessageListener(this);

mLockviewExpand.setOnFinishDrawPasswordListener(this);

}

@Override

public void initData() {

}

//密码盘被锁住发生的回调

@Override

public void onLockPanel() {

}

//更新小点显示图

@Override

public void onUpdateIndicator() {

if (mLockviewExpand.getPointTrace().size() > 0) {

lockviewIndicator.setPath(mLockviewExpand.getPointTrace());

}

}

//返回信息如果是正确的

@Override

public void onUpdateMessage(String message) {

if (succeeMsg.contains(message)){

tvMessage.setTextColor(0xff434242);//设置提示文字颜色

}else {//Error

tvMessage.setTextColor(0xffe44d4d);

tvMessage.startAnimation(mShakeAnimal); //动画效果

}

tvMessage.setText(message);

}

//vibration 震动对应的接口

@Override

public void vibration(String time) {

if ("long".equals(time)){

mVibrator.vibrate(new long[]{50,200},-1);//长震动

}else {

mVibrator.vibrate(new long[]{50,50},-1);//震动

}

}

//设置密码成功

@Override

public void onSetPassword() {

Toast.makeText(mContext, "密码设置成功", Toast.LENGTH_SHORT).show();

finish();

}

//解开密码锁成功

@Override

public void onOpenLock() {

Toast.makeText(mContext, "成功解锁", Toast.LENGTH_SHORT).show();

finish();

}

/* 禁止返回按钮的点击 */

@Override

public boolean onKeyDown(int keyCode, KeyEvent event) {

if (keyCode == KeyEvent.KEYCODE_BACK && event.getAction()== KeyEvent.ACTION_DOWN &&activityNum == 0) {

return true;

} else {

return super.onKeyDown(keyCode, event);

}

}

}

手势解锁一共有3种模式,对应设置密码,验证密码,修改密码:

mLockviewExpand.setActionMode(0);//set mode 设置手势密码

mLockviewExpand.setActionMode(1);//set mode 验证手势密码

mLockviewExpand.setActionMode(2);//set mode 更换手势密码

对应回调接口设置:

mLockviewExpand.setOnLockPanelListener(this);// 手势解锁次数超出后,锁定解锁的回调

mLockviewExpand.setOnUpdateIndicatorListener(this);//手势完成后的回调,设置上面的路径显示图

mLockviewExpand.setOnUpdateMessageListener(this);//手势完成后,返回提示的信息

mLockviewExpand.setOnFinishDrawPasswordListener(this);//手势解锁成功,密码设置成功的回调

其他配置:

mLockviewExpand.getPaintL().setStrokeWidth(20); //获取paint 修改连接线段的样式

mLockviewExpand.setLock_trackColor(0xff0000); //给路径设置不同颜色

mLockviewExpand.setHiddenTrack(true); //隐藏轨迹和按钮

mLockviewExpand.setShowError(true); //显示失败视图

mLockviewExpand.setLockTime(2);//设置显示的锁住的时间

xml配置(com.gestruelock.ExpandLockView 只针对这个控件):

图片的指定就是在这里,可以设置左边,中间和右边的图片,如果一样就全部指定同一张图片,库里面自带上面图片显示效果的图片资源!

app:lock_selected1="@drawable/left" //设置最左边图片

app:lock_selected2="@drawable/center" //设置最中间图片

app:lock_selected3="@drawable/right" //设置最右边图片

app:lock_trackColor="#04ff9b" //设置轨迹颜色 app:lock_selected_error="@drawable/circle_error" //设置错误图片

app:lock_unselected="@drawable/gusture_icon_default" //设置未选中图片

总结:

以上所述是小编给大家介绍的Android 5秒学会使用手势解锁功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值