Android自定义滑动解锁控件使用详解

发布时间 - 2026-01-11 02:28:00    点击率:

最近的项目里用到了,在网上找不到合适的,于是自己写了个简单的,带回弹效果:

可以自定义的属性有:

<!-- 滑动解锁控件 xml配置属性 -->
<declare-styleable name="SlideToUnlockView">
 <attr name="slideImageViewWidth" format="dimension"/><!-- 滑块宽度 -->
 <attr name="slideImageViewResId" format="reference"/><!-- 滑块资源id -->
 <attr name="slideImageViewResIdAfter" format="reference"/><!-- 滑动到右边时,滑块资源id -->
 <attr name="viewBackgroundResId" format="reference"/><!-- 背景资源id -->
 <attr name="textHint" format="string"/><!-- 文本内容 -->
 <attr name="textSize" format="integer"/><!-- 文本字号 -->
 <attr name="textColorResId" format="color"/><!-- 文本字色 -->
 <attr name="slideThreshold" format="float"/><!-- 滑动阈值,默认是0.5,当右滑距离不满整个控件宽度的0.5,就会回弹至左边 -->
</declare-styleable>

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 xmlns:chuck="http://schemas.android.com/apk/res-auto"
 android:paddingBottom="@dimen/activity_vertical_margin"
 android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 tools:context="com.qdong.slidetounlockdemo.MainActivity">


 <RelativeLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:id="@+id/relativeLayout">

 <!-- chuck:textSize="14sp"
   chuck:textColorResId="@color/colorWhite"-->
 <com.qdong.slide_to_unlock_view.CustomSlideToUnlockView
  android:id="@+id/slide_to_unlock"
  android:layout_width="match_parent"
  android:layout_height="50dp"


  chuck:viewBackgroundResId="@drawable/shape_round_normal_green"
  chuck:slideImageViewWidth="@dimen/slide_width"
  chuck:slideImageViewResId="@mipmap/icon_slide"
  chuck:slideImageViewResIdAfter="@mipmap/ic_launcher"
  chuck:slideThreshold="0.5"
  chuck:textSize="6"
  chuck:textHint="@string/hint"
  chuck:textColorResId="@color/colorWhite"

  >

 </com.qdong.slide_to_unlock_view.CustomSlideToUnlockView>

 </RelativeLayout>

 <Button
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:text="reset"
 android:id="@+id/button"
 android:layout_below="@+id/relativeLayout"
 android:layout_centerHorizontal="true"
 android:layout_marginTop="150dp"/>

 <TextView
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:id="@+id/tv_text"
 android:text="slide distance:"
 android:layout_alignBottom="@+id/button"
 android:layout_centerHorizontal="true"
 android:layout_marginBottom="60dp"/>

</RelativeLayout>

MainActivity:

public class MainActivity extends AppCompatActivity {

 private com.qdong.slide_to_unlock_view.CustomSlideToUnlockView mCustomSlideToUnlockView;
 private TextView tv_text;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 mCustomSlideToUnlockView= (com.qdong.slide_to_unlock_view.CustomSlideToUnlockView) findViewById(R.id.slide_to_unlock);
 tv_text= (TextView) findViewById(R.id.tv_text);

 CustomSlideToUnlockView.CallBack callBack=new CustomSlideToUnlockView.CallBack() {
  @Override
  public void onSlide(int distance) {
  tv_text.setText("slide distance:"+distance);
  }

  @Override
  public void onUnlocked() {
  tv_text.setText("onUnlocked");
  }
 };
 mCustomSlideToUnlockView.setmCallBack(callBack);
 findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
  mCustomSlideToUnlockView.resetView();
  }
 });
 }
}

下载地址:

https://github.com/506954774/AndroidCustomSlideToUnlockView

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


# Android  # 滑动解锁  # Android自定义控件实现可左右滑动的导航条  # Android控件之SlidingDrawer(滑动式抽屉)详解与实例分享  # Android开源堆叠滑动控件仿探探效果  # Android自定义控件ScrollView实现上下滑动功能  # Android实现可滑动的自定义日历控件  # Android控件SeekBar仿淘宝滑动验证效果  # Android自定义View实现随手势滑动控件  # Android仿微信列表滑动删除之可滑动控件(一)  # Android自定义控件实现滑动开关效果  # Android自定义双向滑动控件  # 滑块  # 就会  # 下载地址  # 找不到  # 写了  # 自定义  # 大家多多  # 解锁  # 里用  # 在网上  # version  # encoding  # xmlns  # RelativeLayout  # utf  # activity_main  # color  # textColorResId  # integer  # slideThreshold 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 装修招标网站设计制作流程,装修招标流程?  Laravel如何实现API速率限制?(Rate Limiting教程)  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  创业网站制作流程,创业网站可靠吗?  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Laravel怎么上传文件_Laravel图片上传及存储配置  如何在服务器上三步完成建站并提升流量?  微信小程序 HTTPS报错整理常见问题及解决方案  java获取注册ip实例  PythonWeb开发入门教程_Flask快速构建Web应用  Python文件操作最佳实践_稳定性说明【指导】  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  常州企业网站制作公司,全国继续教育网怎么登录?  Android GridView 滑动条设置一直显示状态(推荐)  Laravel怎么在Controller之外的地方验证数据  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  如何快速搭建高效服务器建站系统?  智能起名网站制作软件有哪些,制作logo的软件?  Swift开发中switch语句值绑定模式  如何用AWS免费套餐快速搭建高效网站?  香港服务器如何优化才能显著提升网站加载速度?  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  b2c电商网站制作流程,b2c水平综合的电商平台?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  详解jQuery中基本的动画方法  实例解析angularjs的filter过滤器  Laravel如何实现用户注册和登录?(Auth脚手架指南)  三星网站视频制作教程下载,三星w23网页如何全屏?  laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  如何在云主机上快速搭建多站点网站?  如何制作一个表白网站视频,关于勇敢表白的小标题?  QQ浏览器网页版登录入口 个人中心在线进入  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Laravel如何实现一对一模型关联?(Eloquent示例)  Linux系统命令中screen命令详解  北京的网站制作公司有哪些,哪个视频网站最好?  Laravel如何配置Horizon来管理队列?(安装和使用)  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Laravel中的withCount方法怎么高效统计关联模型数量  如何用搬瓦工VPS快速搭建个人网站?  如何在Ubuntu系统下快速搭建WordPress个人网站?  如何快速生成凡客建站的专业级图册?  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)