Android自定义SeekBar实现滑动验证且不可点击

最近公司因为短信接口被盗刷的比较严重,需要做一个类似于淘宝的滑动验证,用于特定环境,以增加一层保障。拿到需求首先想到的是自定义ViewGroup来实现,里面放一个seekbar和TextView即可。但是有更简单的方法,直接在布局中放入seekbar和TextView,不就ok了?用最简单快捷的方法实现需求,才是硬道理。

值得一提的是,seekbar默认情况下是支持点击事件的,也就是说,用户可以直接点击进度条以实现滑动验证这是不允许的,因此,自定义seekbar,屏蔽点击事件。下面我们先从seekbar + textxiew实现滑动验证效果开始,最后实现seekbar点击事件的屏蔽。

滑动验证实现:

先上一张效果图:

不太美观,UI还没设计,只是个demo。

1、布局

<RelativeLayout
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:background="@color/white"
   android:padding="10dp">

 <com.dmlc.app.android.widget.NoClickSeekbar
   android:id="@+id/sb_bar"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:max="100"
   android:progress="0"
   android:progressDrawable="@drawable/style_seekbar_verify"
   android:thumb="@drawable/style_seekbar_thumb"
   android:thumbOffset="0dp" />

<TextView
   android:id="@+id/sb_tv"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:layout_centerInParent="true"
   android:gravity="center"
   android:text="请按住滑块,拖动到最右边"
   android:textColor="#888888"
   android:textSize="14dp" />
</RelativeLayout>

其中,android:progressDrawable用于定义滑动条背景,android:thumb定义滑块样式。

滑动条背景:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
 <!--seekBar背景-->
 <item android:id="@android:id/background">
 <!--形状-->
 <shape android:shape="rectangle">
  <!--大小-->
  <size android:height="30dp" />
  <!--圆角-->
  <corners android:radius="5dp" />
  <!--背景-->
  <solid android:color="#E7EAE9" />
  <!--边框-->
  <stroke
  android:width="1dp"
  android:color="#C3C5C4" />
 </shape>
 </item>
 <!--seekBar的进度条-->
 <item android:id="@android:id/progress">
 <clip>
  <shape>
  <corners android:radius="5dp" />
  <solid android:color="#7AC23C" />
  <stroke
   android:width="1dp"
   android:color="#C3C5C4" />
  </shape>
 </clip>
 </item>

</layer-list>

滑块样式:

<?xml version="1.0" encoding="utf-8"?>
<selector
 xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:state_focused="true" android:state_pressed="false" android:drawable="@drawable/seekbar_thumb_normal" />
 <item android:state_focused="true" android:state_pressed="true" android:drawable="@drawable/seekbar_thumb_pressed" />
 <item android:state_focused="false" android:state_pressed="true" android:drawable="@drawable/seekbar_thumb_pressed" />
 <item android:drawable="@drawable/seekbar_thumb_normal" />
</selector>

2、自定义seekbar

重写setOnSeekBarChangeListener,监听seekbar。
简单介绍下几个回调方法的作用:

  • onProgressChanged :当progress进度改变时调用;
  • onStartTrackingTouch :开始滑动时调用;
  • onStopTrackingTouch : 滑动结束时调用;
public class NoClickSeekbar extends SeekBar{
 private int oldsign = 0;
 private int mTemp = 10;//点击最大值,超过这个值则不响应
 private int mStep = 0;
 OnNoClickSeekBarChangeListener mOnSeekBarChangeListener;

 public NoClickSeekbar(Context context) {
 this(context,null);
 }

 public NoClickSeekbar(Context context, AttributeSet attrs) {
 this(context, attrs,0);
 }

 public NoClickSeekbar(Context context, AttributeSet attrs, int defStyleAttr) {
 super(context, attrs, defStyleAttr);
 init();
 }

 private void init() {
 setOnSeekBarChangeListener(new OnSeekBarChangeListener(){
  @Override
  public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
  // TODO 自动生成的方法存根
  if(Math.abs(progress - oldsign) > mTemp){
   seekBar.setProgress(oldsign);
   if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onProgressChanged(seekBar,oldsign,fromUser);
   }
   return;
  }
  seekBar.setProgress(progress);
  oldsign = progress;
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onProgressChanged(seekBar,oldsign,fromUser);
  }

  }

  @Override
  public void onStartTrackingTouch(SeekBar seekBar) {
  // TODO 自动生成的方法存根
  seekBar.setProgress(oldsign);
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onStartTrackingTouch(seekBar);
  }
  }

  @Override
  public void onStopTrackingTouch(SeekBar seekBar) {
  // TODO 自动生成的方法存根
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onStopTrackingTouch(seekBar);
  }
  }

 });
 }

 public interface OnNoClickSeekBarChangeListener {

 void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser);

 void onStartTrackingTouch(SeekBar seekBar);

 void onStopTrackingTouch(SeekBar seekBar);
 }

 public void setNoClickSeekBarChangeListener(OnNoClickSeekBarChangeListener l) {
 mOnSeekBarChangeListener = l;
 }
 }

在自定义seekbar的时候,设置供用户的回调监听,

public interface OnNoClickSeekBarChangeListener {

 void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser);

 void onStartTrackingTouch(SeekBar seekBar);

 void onStopTrackingTouch(SeekBar seekBar);
 }

并在seekbar中重写监听时,重写对应的事件回调时,将上面对应的接口方法对应的执行。用户在使用自定义seekbar时,执行监听,加入我们需要实现的需求。

mSeekBar.setNoClickSeekBarChangeListener(new NoClickSeekbar.OnNoClickSeekBarChangeListener() {
  @Override
  public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
  if (progress == seekBar.getMax()){
   mSeekbarTV.setVisibility(View.VISIBLE);
   mSeekbarTV.setText("验证通过");
  } else {
   mSeekbarTV.setVisibility(View.INVISIBLE);
   if (progress < 10){
   mSeekbarTV.setVisibility(View.VISIBLE);
   mSeekbarTV.setText("请按住滑块,拖动到最右边");
   }
  }
  }

  @Override
  public void onStartTrackingTouch(SeekBar seekBar) {

  }

  @Override
  public void onStopTrackingTouch(SeekBar seekBar) {

  }
 });

SeekBar点击事件的屏蔽

1、解决办法一:

在我们滑动seekbar的时候,是可以监听到progress的。因此,我们用一个变量记录上一次的progress,当点击事件发生时,计算点击的进度与之前的进度是否超过一定范围,从而判断是否需要响应。比较简单,直接上代码:

setOnSeekBarChangeListener(new OnSeekBarChangeListener(){
  @Override
  public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
  // TODO 自动生成的方法存根
  if(Math.abs(progress - oldsign) > mTemp){
   seekBar.setProgress(oldsign);
   if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onProgressChanged(seekBar,oldsign,fromUser);
   }
   return;
  }
  seekBar.setProgress(progress);
  oldsign = progress;
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onProgressChanged(seekBar,oldsign,fromUser);
  }

  }

  @Override
  public void onStartTrackingTouch(SeekBar seekBar) {
  // TODO 自动生成的方法存根
  seekBar.setProgress(oldsign);
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onStartTrackingTouch(seekBar);
  }
  }

  @Override
  public void onStopTrackingTouch(SeekBar seekBar) {
  // TODO 自动生成的方法存根
  if (mOnSeekBarChangeListener != null) {
   mOnSeekBarChangeListener.onStopTrackingTouch(seekBar);
  }
  }

 });

2、解决办法二:

通过view的事件监听,重写view的onTouchEvent事件,在MotionEvent.ACTION_DOWN的时候,同样判断前后两次事件之间的距离,判断是否要处理该点击事件。

@Override
 public boolean onTouchEvent(MotionEvent event) {
 int x = (int) event.getX();
 switch (event.getAction()){
  case MotionEvent.ACTION_DOWN:
  if (Math.abs(x - mStep) > 100) {
   return false;
  }
  break;
  case MotionEvent.ACTION_MOVE:

  break;
  case MotionEvent.ACTION_UP:
  mStep = x;
  break;
 }
 return super.onTouchEvent(event);
 }

对于上面自定义SeekBar来说,在屏蔽点击事件上,还是有瑕疵的。是能设定一定的范围,小于了该范围,比如用户小范围的点击,是会响应的。把问题都在这儿,后面解决了再补充!

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

(0)

相关推荐

  • Andorid实现点击获取验证码倒计时效果

    我们在开发中经常用到倒计时的功能,比如发送验证码后,倒计时60s再进行验证码的获取,为了方便以后使用,这里做个记录,讲讲倒计时器的实现. 1.先进行倒计时工具类的封装 public class CountDownTimerUtils extends CountDownTimer { private TextView mTextView; /** * @param textView The TextView * * * @param millisInFuture The number of mil

  • Android 高仿斗鱼滑动验证码

    如下图.在Android上实现起来就不太容易,有些效果还是不如web端酷炫.) 我们的Demo,Ac娘镇楼 (图很渣,也忽略底下的SeekBar,这不是重点) 一些动画,效果录不出来了,大家可以去斗鱼web端看一下,然后下载Demo看一下,效果还是可以的. 代码 传送门: https://github.com/mcxtzhang/SwipeCaptcha 我们的Demo和web端基本上一样. 那么本控件包含不仅包含以下功能: 随机区域起点(左上角x,y)生成一个验证码阴影.验证码拼图 凹凸图形会

  • Android账号注册实现点击获取验证码倒计时效果

    网站中为了防止恶意获取验证短信.验证邮箱,都会在点击获取验证码的按钮上做个倒计时的效果,如何实现这个效果,具体内容如下 效果图:   代码: RegisterActivity.java import android.os.Bundle; import android.support.v7.widget.Toolbar; import android.view.View; import android.widget.Button; import com.jialianjia.bzw.BaseAct

  • Android控件SeekBar仿淘宝滑动验证效果

    SeekBar是一个拖动条控件,最简单的案例就是我们的调节音量,还有音频视频的播放,传统的SeekBar样式,如图 传统的实现太简单,不足以让我们到能装逼的地步.本来是打算实现滴滴出行滑动完成订单的效果,可惜找不到效果图,今天也就用淘宝的滑动验证来作为实例 1.1 实现分析 SeekBar:使用progressDrawable属性自定义SeekBar 拖动块:使用thumb属性更改,其实就是一张图片 文字:使用RelativeLayout嵌套在一起 1.2 实现布局 <?xml version=

  • Android利用CountDownTimer实现点击获取验证码倒计时效果

    本文实例为大家分享了Android点击获取验证码倒计时的具体代码,供大家参考,具体内容如下 package com.loaderman.countdowntimerdemo; import android.os.Bundle; import android.os.CountDownTimer; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.TextV

  • Android实现点击获取验证码60秒后重新获取功能

    本文实例为大家分享了Android实现点击获取验证码60秒后重新获取的具体代码,供大家参考,具体内容如下 上代码 /** * Created by Xia_焱 on 2017/5/7. */ public class CountDownTimerUtils extends CountDownTimer { private TextView mTextView; /** * @param millisInFuture The number of millis in the future from

  • android点击无效验证的解决方法

    背景 在写一个东西滑动删除列表的时候,出现了一个问题.我的需求是,左滑然后出现delete,然后点击delete,让该滑块消失. 我在点列表的第一行的时候,左滑,出现delete,点击删除,ok的,完美.然后我点击第三个,同样左滑出现delete,点击delete没有任何反应. 然后我再点击第一个,又可以删除. 模型如下: 子模型: ps: 黑色的是最外层,蓝色的是在黑块中,然后delete区域在滑块区.滑动是控制蓝色区域的移动. 如果仅仅是这样,我一点也不慌.出现了一些东西,更加我让疑惑.de

  • Android自定义滑动验证条的示例代码

    本文介绍了Android自定义滑动验证条的示例代码,分享给大家,具体如下: *注:不知道为什么,h5的标签在这里没用了,所以我也只能用Markdown的语法来写了 项目地址:https://github.com/994866755/handsomeYe.seekbar.github.io 需求: 在我们的某些应用中需要滑动验证.比如说这个样子的: 刚开始我也很懵逼要怎么去弄,结果我去看了一些人的代码,有人是用自定义viewgroup去做,就是viewgroup包含滑动块和滑动条.但我觉得太麻烦,

  • Android自定义SeekBar实现滑动验证且不可点击

    最近公司因为短信接口被盗刷的比较严重,需要做一个类似于淘宝的滑动验证,用于特定环境,以增加一层保障.拿到需求首先想到的是自定义ViewGroup来实现,里面放一个seekbar和TextView即可.但是有更简单的方法,直接在布局中放入seekbar和TextView,不就ok了?用最简单快捷的方法实现需求,才是硬道理. 值得一提的是,seekbar默认情况下是支持点击事件的,也就是说,用户可以直接点击进度条以实现滑动验证这是不允许的,因此,自定义seekbar,屏蔽点击事件.下面我们先从see

  • Android自定义Seekbar滑动条 Pop提示跟随滑动按钮滑动

    本文实例为大家分享了Android自定义Seekbar滑动条的具体代码,供大家参考,具体内容如下 由于项目需要做出此效果,自定义写了一个. 效果图 思路: 原始的seekbar只有滑动条并没有下方的提示文字,所以我们必须要继承Seekbar重写这个控件. 代码: 在values文件夹下新建attrs.xml,用于设置跟随滑动按钮的文字大小,颜色,背景. <declare-styleable name="MySeekBar"> <attr name="text

  • Android 自定义SeekBar动态改变硬件音量大小实现和音量键的同步(推荐)

    1,上图: 2,代码: MainActivity.Java package com.hero.zhaoq.seekbarchangeddemo; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.database.ContentObse

  • Android 自定义TextView实现滑动解锁高亮文字

    下面一段代码给大家分享Android 自定义TextView实现滑动解锁高亮文字效果,具体代码如下所示: public class HightLightTextView extends TextView { // 存储view的宽度 private int mTextViewWidth = 0; // 画笔 private Paint mPaint; // 线性渲染 private LinearGradient mLinearGradient; // 存储变换的matrix private Ma

  • Android自定义星星可滑动评分控件

    本文实例为大家分享了Android自定义星星可滑动评分控件的具体方法,供大家参考,具体内容如下 此控件通过线性布局结合ImageView来实现. 具有展示分数,滑动评分功能,可设置0-10分,自行设置星星图片,是否可点击与滑动,星星间距. 效果如下: 需准备好下面三张图片 先看自定义属性: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name

  • Android自定义实现可滑动按钮

    本文实例为大家分享了Android自定义实现可滑动按钮的具体代码,供大家参考,具体内容如下 实现逻辑 1.创建一个类继承view类,实现里面的onMeasure() onDraw()方法 2.在 onMeasure() 中需要调用setMeasuredDimension(viewWidth,viewheight),用来绘制按钮的位置区域 3.需要加载按钮的背景和滑块资源 并且转化为bitmap对象 4.获取背景图片的宽和高作为自定义控件的宽和高 5.获取滑块的宽度,用来调整按钮的开和关 6.在o

  • Android 自定义SeekBar 实现分段显示不同背景颜色的示例代码

    在最近的开发工作中,要实现一个调色板的进度条,SeekBar要分成10段显示不同颜色,功夫不负有心人,终于实现了这个功能,下面分享给大家 示例图: 1.自定义SeekBar import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Rect; import

  • Android自定义view实现滑动解锁效果

    本文实例为大家分享了Android自定义view实现滑动解锁的具体代码,供大家参考,具体内容如下 1. 需求如下: 近期需要做一个类似屏幕滑动解锁的功能,右划开始,左划暂停. 2. 需求效果图如下 3. 实现效果展示 4. 自定义view如下 /** * Desc 自定义滑动解锁View * Author ZY * Mail sunnyfor98@gmail.com * Date 2021/5/17 11:52 */ @SuppressLint("ClickableViewAccessibili

  • Android自定义SeekBar实现视频播放进度条

    首先来看一下效果图,如下所示: 其中进度条如下: 接下来说一说我的思路,上面的进度拖动条有自定义的Thumb,在Thumb正上方有一个PopupWindow窗口,窗口里面显示当前的播放时间.在SeekBar右边有一个文本框显示当前播放时间/总时间. step1.先来看一看PopupWindow的布局文件,seek_popu.xml,效果如下图所示: <?xml version="1.0" encoding="utf-8"?> <RelativeLa

  • android自定义ViewPager水平滑动弹性效果

    android ViewPager是一个经常要用到的组件,但android系统本身为我们提供的ViewPager是没有任何效果的,只能是一页一页的滑动,这样会让人感觉很死板,在看一些知名大公司的App时,看到了他们的ViewPager在滑动到最开始或者最后的时候是有一个弹性效果的,使用起来感觉非常的好,于是乎就是百度搜了一下,在StackOverflow中看到一篇文章就是讲如何实现这个效果的. 先看下效果图:滑动到最后一页时仍然可以拉动-- 代码如下: package com.example.m

随机推荐