欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

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

程序员文章站 2024-02-11 23:45:04
本文实例讲述了android编程实现滑动按钮功能。分享给大家供大家参考,具体如下: 首先效果图: 然后是分别建立三个文件,第一个是main.class,第二个是sl...

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

首先效果图:

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程序设计有所帮助。