Android编程实现滑动按钮功能详解

发布时间 - 2026-01-10 23:02:57    点击率:

本文实例讲述了Android编程实现滑动按钮功能。分享给大家供大家参考,具体如下:

首先效果图:

然后是分别建立三个文件,第一个是main.class,第二个是SlipButton.class,第三个是 onchangeListener.class

main.class

import android.app.Activity;
import android.os.Bundle;
import android.widget.Toast;
public class Main extends Activity implements OnChangedListener {
  /** Called when the activity is first created. */
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    SlipButton myBtn =(SlipButton) findViewById(R.id.slipBtn);//获得指定控件
    myBtn.SetOnChangedListener(this);//为控件设置监听器
  }
    @Override
    public void OnChanged(boolean CheckState) {//当按钮状态被改变时
    // TODO Auto-generated method stub
    if(CheckState)
      Toast.makeText(this,"打开了..." , Toast.LENGTH_SHORT).show();
    else
      Toast.makeText(this,"关闭了..." , Toast.LENGTH_SHORT).show();
  }
}

SlipButton.class

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
public class SlipButton extends View implements OnTouchListener{
  private boolean NowChoose = false;//记录当前按钮是否打开,true为打开,flase为关闭
  private boolean OnSlip = false;//记录用户是否在滑动的变量
  private float DownX,NowX;//按下时的x,当前的x,
  private Rect Btn_On,Btn_Off;//打开和关闭状态下,游标的Rect
  private boolean isChgLsnOn = false;
  private OnChangedListener ChgLsn;
  private Bitmap bg_on,bg_off,slip_btn;
  public SlipButton(Context context) {
    super(context);
    // TODO Auto-generated constructor stub
    init();
  }
  public SlipButton(Context context, AttributeSet attrs) {
    super(context, attrs);
    // TODO Auto-generated constructor stub
    init();
  }
  private void init(){//初始化
    //载入图片资源
    bg_on = BitmapFactory.decodeResource(getResources(), R.drawable.slip_bg_on);
    bg_off = BitmapFactory.decodeResource(getResources(), R.drawable.slip_bg_off);
    slip_btn = BitmapFactory.decodeResource(getResources(), R.drawable.slip_btn);
    //获得需要的Rect数据
    Btn_On = new Rect(0,0,slip_btn.getWidth(),slip_btn.getHeight());
    Btn_Off = new Rect(
        bg_off.getWidth()-slip_btn.getWidth(),
        0,
        bg_off.getWidth(),
        slip_btn.getHeight());
    setOnTouchListener(this);//设置监听器,也可以直接复写OnTouchEvent
  }
  @Override
  protected void onDraw(Canvas canvas) {//绘图函数
    // TODO Auto-generated method stub
    super.onDraw(canvas);
    Matrix matrix = new Matrix();
    Paint paint = new Paint();
    float x;
    {
      if(NowX<(bg_on.getWidth()/2))//滑动到前半段与后半段的背景不同,在此做判断
        canvas.drawBitmap(bg_off,matrix, paint);//画出关闭时的背景
      else
        canvas.drawBitmap(bg_on,matrix, paint);//画出打开时的背景
      if(OnSlip)//是否是在滑动状态,
      {
        if(NowX >= bg_on.getWidth())//是否划出指定范围,不能让游标跑到外头,必须做这个判断
          x = bg_on.getWidth()-slip_btn.getWidth()/2;//减去游标1/2的长度...
        else
          x = NowX - slip_btn.getWidth()/2;
      }else{//非滑动状态
        if(NowChoose)//根据现在的开关状态设置画游标的位置
          x = Btn_Off.left;
        else
          x = Btn_On.left;
      }
    if(x<0)//对游标位置进行异常判断...
      x = 0;
    else if(x>bg_on.getWidth()-slip_btn.getWidth())
      x = bg_on.getWidth()-slip_btn.getWidth();
    canvas.drawBitmap(slip_btn,x, 0, paint);//画出游标.
    }
  }
  @Override
  public boolean onTouch(View v, MotionEvent event) {
    // TODO Auto-generated method stub
    switch(event.getAction())//根据动作来执行代码
    {
    case MotionEvent.ACTION_MOVE://滑动
      NowX = event.getX();
      break;
    case MotionEvent.ACTION_DOWN://按下
    if(event.getX()>bg_on.getWidth()||event.getY()>bg_on.getHeight())
   return false;
      OnSlip = true;
      DownX = event.getX();
      NowX = DownX;
      break;
    case MotionEvent.ACTION_UP://松开
      OnSlip = false;
      boolean LastChoose = NowChoose;
      if(event.getX()>=(bg_on.getWidth()/2))
        NowChoose = true;
      else
        NowChoose = false;
      if(isChgLsnOn&&(LastChoose!=NowChoose))//如果设置了监听器,就调用其方法..
        ChgLsn.OnChanged(NowChoose);
      break;
    default:
    }
    invalidate();//重画控件
    return true;
  }
  public void SetOnChangedListener(OnChangedListener l){//设置监听器,当状态修改的时候
    isChgLsnOn = true;
    ChgLsn = l;
  }
}

onchangeListener.class

package CMD100.demo.slipButton;
public interface OnChangedListener {
  abstract void OnChanged(boolean CheckState);
}

main.xml代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  >
<TextView
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="@string/hello"
  />
<LinearLayout
  android:orientation = "horizontal"
  android:layout_width = "fill_parent"
  android:layout_height = "wrap_content"
  android:background = "#ff0000"
  >
  <TextView
    android:text = "测试:"
    android:layout_width = "wrap_content"
    android:layout_height = "wrap_content"
    />
 <CMD100.demo.slipButton.SlipButton
    android:id = "@+id/slipBtn"
    android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_marginLeft = "10sp"
  />
</LinearLayout>
</LinearLayout>

注意:在xml里头要放置的位置

<[包名].SlipButton
  android:id = "@+id/slipBtn"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  />

然后可以像其他控件一样使用了...

SlipButton myBtn =(SlipButton) findViewById(R.id.slipBtn);
myBtn.SetOnChangedListener(...);

代码到这里就全部完成了。

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android布局layout技巧总结》、《Android视图View技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。


# Android  # 滑动按钮  # Android自定义实现可滑动按钮  # Android自定义Seekbar滑动条 Pop提示跟随滑动按钮滑动  # Android编程之滑动按钮事件实例详解  # 自定义滑动按钮为例图文剖析Android自定义View绘制  # Android实现类似ios滑动按钮  # 画出  # 按下  # 进阶  # 是在  # 相关内容  # 第一个  # 在此  # 感兴趣  # 跑到  # 第二个  # 能让  # 给大家  # 可以直接  # 第三个  # 更多关于  # 解决方法  # 所述  # 程序设计  # 半段  # 操作技巧 


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


相关推荐: Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  简单实现Android验证码  Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】  Laravel如何使用Sanctum进行API认证?(SPA实战)  jquery插件bootstrapValidator表单验证详解  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  如何快速生成橙子建站落地页链接?  如何在万网开始建站?分步指南解析  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  中国移动官方网站首页入口 中国移动官网网页登录  Laravel定时任务怎么设置_Laravel Crontab调度器配置  原生JS实现图片轮播切换效果  如何快速查询网址的建站时间与历史轨迹?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中  Laravel如何为API编写文档_Laravel API文档生成与维护方法  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  用v-html解决Vue.js渲染中html标签不被解析的问题  javascript中的try catch异常捕获机制用法分析  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  如何用好域名打造高点击率的自主建站?  Laravel如何实现多对多模型关联?(Eloquent教程)  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  JS弹性运动实现方法分析  如何在服务器上配置二级域名建站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Python数据仓库与ETL构建实战_Airflow调度流程详解  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  无锡营销型网站制作公司,无锡网选车牌流程?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  如何快速搭建个人网站并优化SEO?  Laravel怎么使用Intervention Image库处理图片上传和缩放  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  Android仿QQ列表左滑删除操作  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  香港网站服务器数量如何影响SEO优化效果?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  如何快速登录WAP自助建站平台?  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  高防服务器租用首荐平台,企业级优惠套餐快速部署  北京的网站制作公司有哪些,哪个视频网站最好?  如何在阿里云虚拟服务器快速搭建网站?  如何在万网自助建站中设置域名及备案?  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】