iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android自定义控件实现简单滑动开关效果
  • 933
分享到

Android自定义控件实现简单滑动开关效果

2024-04-02 19:04:59 933人浏览 独家记忆
摘要

本文实例为大家分享了Android自定义控件实现简单滑动开关的具体代码,供大家参考,具体内容如下 ToggleButton 滑动开关 项目概述 滑动开关是一个纯粹的自定义控件,上面的

本文实例为大家分享了Android自定义控件实现简单滑动开关的具体代码,供大家参考,具体内容如下

ToggleButton 滑动开关

项目概述

滑动开关是一个纯粹的自定义控件,上面的按钮会随着我们的左右滑动而滑动,并且在状态改变时通知用户,效果如下图1-9 所示,这也是应用中设置某些状态信息时最常见的控件,因此,我们有必要学习关于如何

自定义一个这样的滑动开关。

滑动开关UI

布局文件为activity_main.xml,代码如下:res/layout/activity_main.xml

<RelativeLayout xmlns:android="Http://schemas.android.com/apk/res/android"
                xmlns:itheima="http://schemas.android.com/apk/res/com.itheima.togglebuttondemo"
                xmlns:tools="http://schemas.android.com/tools"
                android:layout_width="match_parent"
                android:layout_height="match_parent">
    <com.itheima.togglebuttondemo.view.ToggleButton
        android:id="@+id/togglebutton"
        android:layout_width="wrap_content"
        android:layout_centerInParent="true"
        itheima:SwitchBtnBackgroud="@drawable/switch_background"
        itheima:SlidBtnBackgroud="@drawable/slide_button_background"
        itheima:CurrentState="false"
        android:layout_height="wrap_content"/>
</RelativeLayout>

在activity_main.xml 布局中引入如下命名空间:

xmlns:itheima=”http://schemas.android.com/apk/res/com.itheima.togglebuttondemo”,com.itheima.togglebuttondemo 是包名,itheima 是自定义的命名控件名,可以任取名字,也可以使用类名。

上面的布局主要是引入com.itheima.togglebuttondemo.view.ToggleButton 类和自定义属性的使用。添加自定义属性,在values 目录下创建attrs.xml 文件,具体代码如文件所示:

res/values/attrs.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <declare-styleable name="ToggleButton">
        <!-- 滑动开关背景图片属性-->
        <attr
            name="SwitchBtnBackgroud"
            fORMat="reference"/>
        <!-- 滑动块背景图片属性-->
        <attr
            name="SlidBtnBackgroud"
            format="reference"/>
        <!-- 滑动开关的状态-->
        <attr
            name="CurrentState"
            format="boolean"/>
    </declare-styleable>
</resources>

attrs.xml 文件目录结构如下图所示:

滑动开关业务逻辑实现

下拉选择框activity 界面,MainActivity.java 代码如下:com/itheima/MySwitch/MainActivity

public class MainActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ToggleButton togglebutton = (ToggleButton) findViewById(R.id.togglebutton);
        //设置滑动开关的背景图片
        // togglebutton.setSwitchBtnBackgroudResource(R.drawable.switch_background);
        //设置滑动块的背景图片
        // togglebutton.setSlidBtnBackgroudResource(R.drawable.slide_button_background);
        //设置滑动开关的默认状态
        // togglebutton.setCurrentState(true);
        //设置滑动开关状态改变监听
        Togglebutton.setToggleBtnStateChangeListener(new ToggleBtnStateChangeListener() {
            @Override
            public void onToggleBtnStateChange(boolean currentState) {
                if (currentState) {
                    Toast.makeText(getApplicationContext(), "开关打开", 0).show();
                }else{
                    Toast.makeText(getApplicationContext(), "开关关闭", 0).show();
                }
            }
        });
    }
}

自定义的滑动开关ToggleButton 类的实现,具体代码如文件所示:com/itheima/MySwitch/MainActivity

public class ToggleButton extends View {
    private Bitmap  switchBitmap;//滑动开关的背景图片
    private Bitmap  slidBitmap;//滑动块的背景图片
    private boolean currentState;
    private int     currentX;//手指触摸点的X 值
    private boolean isTouching = false;
    private ToggleBtnStateChangeListener mToggleBtnStateChangeListener;//状态改变监听器
    //在xml 中引用该控件时,调用该方法
    public ToggleButton(Context context, AttributeSet attrs) {
        super(context, attrs);
        String namespace = "http://schemas.android.com/apk/res/com.itheima.togglebuttondemo";
        currentState = attrs.getAttributeBooleanValue(namespace, "CurrentState", false);
        int switchBtnBackgroudId =
                attrs.getAttributeResourceValue(namespace, "SwitchBtnBackgroud", -1);
        int slidBtnBackgroudId =
                attrs.getAttributeResourceValue(namespace, "SlidBtnBackgroud", -1);
        setSwitchBtnBackgroudResource(switchBtnBackgroudId);
        setSlidBtnBackgroudResource(slidBtnBackgroudId);
    }
    //在代码中创建该控件时,调用该构造方法
    public ToggleButton(Context context) {
        super(context);
    }
    //设置滑动开关的背景图片
    public void setSwitchBtnBackgroudResource(int switchBackground) {
        switchBitmap = BitmapFactory.decodeResource(getResources(), switchBackground);
    }
    // 为了可以高度自定义和增强可扩展性,我们可以给其创建一个自定义控件底部背景了一个方法
    // 设置滑动块的背景图片
    public void setSlidBtnBackgroudResource(int slideButtonBackground) {
        slidBitmap = BitmapFactory.decodeResource(getResources(), slideButtonBackground);
    }
    //设置滑动开关的默认状态
    public void setCurrentState(boolean b) {
        currentState = b;
    }
    // 1、测量滑动开关的宽高
    // 测量控件的宽高
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        setMeasuredDimension(switchBitmap.getWidth(), switchBitmap.getHeight());
    }
    // 2、绘制,画出我们的滑动开关
    //canvas:画布,将图形绘制在canvas,才能显示到屏幕上
    @Override
    protected void onDraw(Canvas canvas) {
        //绘制滑动开关的背景图片
        canvas.drawBitmap(switchBitmap, 0, 0, null);
        //绘制滑动块的背景图片
        if(isTouching){//手指触摸的时候,根据currentx 的值来绘制滑动块
            //根据手指的X 值,来绘制滑动块图片
            int left = currentX - slidBitmap.getWidth()/2;
            if(left < 0){//设置左边界
                left = 0;
            }else if(left > (switchBitmap.getWidth() - slidBitmap.getWidth())){//设置右边界
                left = switchBitmap.getWidth() - slidBitmap.getWidth();
            }
            canvas.drawBitmap(slidBitmap, left, 0, null);
        }else{ // 手指离开控件的时候,根据状态来绘制滑动块
            // 根据状态值,来绘制滑动块
            if(currentState){ //当前为true,开关打开,滑动块显示在最右边
                canvas.drawBitmap(slidBitmap,switchBitmap.getWidth() - slidBitmap.getWidth(),
                        0, null);
            }else{//当前为false,开关关闭,滑动块显示在最左边
                canvas.drawBitmap(slidBitmap, 0, 0, null);
            }
        }
    }
    //当控件被触摸后,会调用该方法
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN://手指按下
                isTouching = true;
                currentX = (int) event.getX();
                break;
            case MotionEvent.ACTION_MOVE://手指滑动
                isTouching= true;
                currentX = (int) event.getX();
                break;
            case MotionEvent.ACTION_UP://手指抬起
                isTouching = false;
                currentX = (int) event.getX();
                int center = switchBitmap.getWidth()/2;
                //当滑动块中心点大于滑动开关背景图片的中心线时,显示到右边,当前状态为true
                boolean state = currentState;
                currentState = currentX > center;
                if(mToggleBtnStateChangeListener !=null&&state != currentState ){
                    mToggleBtnStateChangeListener.onToggleBtnStateChange(currentState);
                }
                break;
            default:
                break;
        }
        invalidate(); //强制让控件重新绘制,ondraw;
        return true; //自己处理触摸事件
    }
    public void setToggleBtnStateChangeListener(ToggleBtnStateChangeListenerlistener){
        this.mToggleBtnStateChangeListener = listener;
    }
    // 定义滑动开关状态改变的回调接口
    public interface ToggleBtnStateChangeListener{
        void onToggleBtnStateChange(boolean currentState);
    }
}

运行程序,效果图如图1-11 所示。

知识点总结

1.通过setMeasuredDimension 方法,来设置自定义控件的宽高,见ToggleButton 类第42 行
2.View 可以通过invalidate()方法强制让自己重新绘制,见ToggleButton 类第96 行
3.View 通过实现onTouchEvent 方法来处理手指触摸事件,见ToggleButton 类第72 行

自定义控件之自定义属性

当我们使用自定义属性来自定义控件时,一般分为以下几个步骤进行设置:

1、在res 文件的values 里面创建attrs.xml,见文件【1-10】attrs.xml
2、在attrs.xml,里面定义我们需要的属性,见文件【1-10】attrs.xml 代码
3、在布局文件中使用自定义的属性,注意要添加命名空间,见文件【1-9】activity_main.xml 第2 行
4、在构造方法中来获取设置的属性数据,见文件【1-9】见ToggleButton 类第8~19 行

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

--结束END--

本文标题: Android自定义控件实现简单滑动开关效果

本文链接: https://www.lsjlt.com/news/139439.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android自定义控件实现简单滑动开关效果
    本文实例为大家分享了Android自定义控件实现简单滑动开关的具体代码,供大家参考,具体内容如下 ToggleButton 滑动开关 项目概述 滑动开关是一个纯粹的自定义控件,上面的...
    99+
    2024-04-02
  • Android自定义view实现滑动解锁效果
    本文实例为大家分享了Android自定义view实现滑动解锁的具体代码,供大家参考,具体内容如下 1. 需求如下: 近期需要做一个类似屏幕滑动解锁的功能,右划开始,左划暂停。 2. ...
    99+
    2024-04-02
  • Android自定义双向滑动控件
    本文实例为大家分享了Android自定义双向滑动控件的具体代码,供大家参考,具体内容如下 先看一下效果图 1.SeekBarPressure工具类 public class See...
    99+
    2024-04-02
  • Android自定义View实现竖向滑动回弹效果
    本文实例为大家分享了Android自定义View实现滑动回弹的具体代码,供大家参考,具体内容如下 前言 Android 页面滑动的时候的回弹效果 一、关键代码 public clas...
    99+
    2024-04-02
  • Android自定义控件实现雷达图效果
    本文实例为大家分享了Android自定义控件实现雷达图的具体代码,供大家参考,具体内容如下 学习了大神的源代码(奈何不知大神的博客地址),觉得必须记录一下,方便以后再次学习。 效果如...
    99+
    2024-04-02
  • android自定义左侧滑出菜单效果
    这里给大家提供一个类似QQ聊天那种可以左侧滑出菜单的自定义控件。希望对大家有帮助。参考了一些网友的做法,自己整理优化了一下,用法非常简单,就一个类,不需要自己写任何的代码,只要添加上...
    99+
    2024-04-02
  • Android实现手势滑动和简单动画效果
    一、手势滑动Activity都具有响应触摸事件,也就是说只要触摸Activity,他都会回调一个onTouchEvent()方法。但是在这个方法里无法处理事件,需要配合使用手势识别器(GestureDetector)中的方法onTouchE...
    99+
    2023-05-31
    android 手势滑动 roi
  • 基于Android自定义控件实现雷达效果
    如何制作出类似雷达扫描的效果,具体方法如下一、效果图二、实现思路 自定义控件RadarView用来画雷达的效果图,可以自定义属性包括 backgroundColor:背景颜色 circleNum:圆的数量 startColor:开始颜色 e...
    99+
    2023-05-30
    android 雷达 roi
  • Android自定义view实现滑动解锁九宫格控件
    目录前言需求效果图前言 上一篇文章用贝塞尔曲线画了一个看起来不错的小红点功能,技术上没什么难度,主要就是数学上的计算。这篇文章也差不多,模仿了一个常用的滑动解锁的九宫格控件。 需求 ...
    99+
    2023-02-09
    Android滑动解锁九宫格 Android滑动解锁 Android九宫格控件
  • Android怎么自定义双向滑动控件
    这篇文章主要介绍“Android怎么自定义双向滑动控件”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么自定义双向滑动控件”文章能帮助大家解决问题。先看一下效果图1.SeekBarPr...
    99+
    2023-06-30
  • Android怎么自定义View实现竖向滑动回弹效果
    这篇文章主要介绍“Android怎么自定义View实现竖向滑动回弹效果”,在日常操作中,相信很多人在Android怎么自定义View实现竖向滑动回弹效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Andro...
    99+
    2023-06-30
  • android怎么自定义开关控件
    要自定义开关控件,可以使用以下步骤:1. 创建一个自定义的开关控件类,继承自Switch或CompoundButton类。2. 在自...
    99+
    2023-08-16
    android
  • Android自定义ViewGroup实现侧滑菜单
    目录前言一、常用的几种交互方式1.1 事件的拦截处理1.2 自行处理事件的几种方式1.3 子View的滚动与协调交互1.4 ViewGroup之间的嵌套与协调效果二、ViewDrag...
    99+
    2023-01-05
    Android ViewGroup侧滑菜单 Android ViewGroup菜单 Android ViewGroup Android 菜单
  • C#实现滑动开关效果
    C#重绘checkbox生成滑动开关,供大家参考,具体内容如下 通过调用checkbox控件的paint事件,在重绘事件里判断checked属性,如果选中绘制选中图形,如果未选中绘制...
    99+
    2024-04-02
  • Android如何自定View实现滑动验证效果
    本篇内容主要讲解“Android如何自定View实现滑动验证效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android如何自定View实现滑动验证效果”吧!效果图自定义属性代码<xm...
    99+
    2023-06-22
  • Android自定义View实现拖动自动吸边效果
    本文实例为大家分享了Android自定义View实现拖动自动吸边的具体代码,供大家参考,具体内容如下 自定义View,一是为了满足设计需求,二是开发者进阶的标志之一。随心所欲就是我等...
    99+
    2024-04-02
  • android控件Banner实现简单轮播图效果
    本文实例为大家分享了android控件Banner实现简单轮播图效果的具体代码,供大家参考,具体内容如下 实现这个轮播图是在Fragment里实现的,所以要想实现,首先要创建Frag...
    99+
    2024-04-02
  • 通过在Android中自定义StickinessView实现一个粘性滑动效果
    这篇文章给大家介绍通过在Android中自定义StickinessView实现一个粘性滑动效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、首先,要确定HeadLayout什么时候可以拦截事件,那么就要确定List...
    99+
    2023-05-31
    android stickinessview roi
  • 怎么在Android中通过自定义view实现滑动解锁效果
    怎么在Android中通过自定义view实现滑动解锁效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。自定义view如下@SuppressLint("Clicka...
    99+
    2023-06-15
  • Android自定义滑动解锁控件使用详解
    最近的项目里用到了,在网上找不到合适的,于是自己写了个简单的,带回弹效果:可以自定义的属性有:<!-- 滑动解锁控件 xml配置属性 --><declare-styleable name="SlideToUnlockVie...
    99+
    2023-05-30
    android 滑动解锁 roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作