`

自定义开关按钮

 
阅读更多
package com.unifease.component;



import android.content.Context;
import android.content.SharedPreferences;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff.Mode;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

import com.unifease.baoyutong.R;
  
public class SwitchButton extends View implements android.view.View.OnClickListener{  
    private Bitmap mSwitchBottom, mSwitchThumb, mSwitchFrame, mSwitchMask;  
    private float mCurrentX = 0;  
    private boolean mSwitchOn=true;//开关默认是开着的  
    private int mMoveLength;//最大移动距离  
    private float mLastX = 0;//第一次按下的有效区域  
      
    private Rect mDest = null;//绘制的目标区域大小  
    private Rect mSrc = null;//截取源图片的大小  
    private int mDeltX = 0;//移动的偏移量  
    private Paint mPaint = null;  
    private OnChangeListener mListener = null;  
    private boolean mFlag = false;  
    private String FILE = "saveSetting";
    SharedPreferences sp;
    public SwitchButton(Context context) {  
        this(context, null);  

        // TODO Auto-generated constructor stub  
    }  
  
    public SwitchButton(Context context, AttributeSet attrs) {  
        this(context, attrs, 0);  
        // TODO Auto-generated constructor stub  
    }  
  
    public SwitchButton(Context context, AttributeSet attrs, int defStyle) {  
        super(context, attrs, defStyle);  
        // TODO Auto-generated constructor stub  
        sp =  context.getSharedPreferences(FILE, context.MODE_PRIVATE);
        init();  
    }  
  
    /** 
     * 初始化相关资源 
     */  
    public void init() {  
        mSwitchBottom = BitmapFactory.decodeResource(getResources(),  
                R.drawable.switch_bottom);  
        mSwitchThumb = BitmapFactory.decodeResource(getResources(),  
                R.drawable.switch_btn_pressed);  
        mSwitchFrame = BitmapFactory.decodeResource(getResources(),  
                R.drawable.switch_frame);  
        mSwitchMask = BitmapFactory.decodeResource(getResources(),  
                R.drawable.switch_mask);  
        if(sp.getString("duty", "").equals("1") ){
            mSwitchOn = true;
        }else if(sp.getString("duty", "").equals("2")){
            mSwitchOn = false;
        }
        
        
       setOnClickListener(this);  
        
        setOnTouchListener(new OnTouchListener() {  
              
            @Override  
            public boolean onTouch(View v, MotionEvent event) {  
                // TODO Auto-generated method stub  
                return false;  
            }  
        });  
          
        mMoveLength = mSwitchBottom.getWidth() - mSwitchFrame.getWidth();  
        mDest = new Rect(0, 0, mSwitchFrame.getWidth(), mSwitchFrame.getHeight());  
        mSrc = new Rect();  
        mPaint = new Paint();  
        mPaint.setAntiAlias(true);  
        mPaint.setAlpha(255);  
        mPaint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));  
    }  
  
    @Override  
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  
        // TODO Auto-generated method stub  
        setMeasuredDimension(mSwitchFrame.getWidth(), mSwitchFrame.getHeight());  
    }  
  
    @Override  
    protected void onDraw(Canvas canvas) {  
        // TODO Auto-generated method stub  
        super.onDraw(canvas);  
        if (mDeltX > 0 || mDeltX == 0 && mSwitchOn) {  
            if(mSrc != null) {  
                mSrc.set(mMoveLength - mDeltX, 0, mSwitchBottom.getWidth()  
                    - mDeltX, mSwitchFrame.getHeight());  
            }   
        } else if(mDeltX < 0 || mDeltX == 0 && !mSwitchOn){  
            if(mSrc != null) {  
                mSrc.set(-mDeltX, 0, mSwitchFrame.getWidth() - mDeltX,  
                    mSwitchFrame.getHeight());  
            }  
        }   
 
        int count = canvas.saveLayer(new RectF(mDest), null, Canvas.MATRIX_SAVE_FLAG  
                | Canvas.CLIP_SAVE_FLAG | Canvas.HAS_ALPHA_LAYER_SAVE_FLAG  
                | Canvas.FULL_COLOR_LAYER_SAVE_FLAG  
                | Canvas.CLIP_TO_LAYER_SAVE_FLAG);  
  
        canvas.drawBitmap(mSwitchBottom, mSrc, mDest, null);  
        canvas.drawBitmap(mSwitchThumb, mSrc, mDest, null);  
        canvas.drawBitmap(mSwitchFrame, 0, 0, null);  
        canvas.drawBitmap(mSwitchMask, 0, 0, mPaint);  
        canvas.restoreToCount(count);  
    }  
      
    @Override  
    public boolean onTouchEvent(MotionEvent event) {  
        // TODO Auto-generated method stub  
        switch (event.getAction()) {  
        case MotionEvent.ACTION_DOWN:  
            mLastX = event.getX();  
            break;  
        case MotionEvent.ACTION_MOVE:  
            mCurrentX = event.getX();  
            mDeltX = (int) (mCurrentX - mLastX);  
            // 如果开关开着向左滑动,或者开关关着向右滑动(这时候是不需要处理的)  
            if ((mSwitchOn && mDeltX < 0) || (!mSwitchOn && mDeltX > 0)) {  
                mFlag = true;  
                mDeltX = 0;  
            }  
              
            if (Math.abs(mDeltX) > mMoveLength) {  
                mDeltX = mDeltX > 0 ? mMoveLength : - mMoveLength;  
            }  
            invalidate();  
            return true;  
        case MotionEvent.ACTION_UP:  
            if (Math.abs(mDeltX) > 0 && Math.abs(mDeltX) < mMoveLength / 2) {  
                mDeltX = 0;  
                invalidate();  
                return true;  
            } else if (Math.abs(mDeltX) > mMoveLength / 2 && Math.abs(mDeltX) <= mMoveLength) {  
                mDeltX = mDeltX > 0 ? mMoveLength : -mMoveLength;  
                mSwitchOn = !mSwitchOn;  
                if(mListener != null) {  
                    mListener.onChange(this, mSwitchOn);  
                }  
                invalidate();  
                mDeltX = 0;  
                return true;  
            } else if(mDeltX == 0 && mFlag) {  
                //这时候得到的是不需要进行处理的,因为已经move过了  
                mDeltX = 0;  
                mFlag = false;  
                return true;  
            }  
            return super.onTouchEvent(event);  
        default:  
            break;  
        }  
        invalidate();  
        return super.onTouchEvent(event);  
    }  
      
    public void setOnChangeListener(OnChangeListener listener) {  
        mListener = listener;  
    }  
      
    public interface OnChangeListener {  
        public void onChange(SwitchButton sb, boolean state);  
    }  
  
    @Override  
    public void onClick(View v) {  
        // TODO Auto-generated method stub  
        mDeltX = mSwitchOn ? mMoveLength : -mMoveLength;  
        mSwitchOn = !mSwitchOn;  
        if(mListener != null) {  
            mListener.onChange(this, mSwitchOn);  
        }  
        invalidate();  
        mDeltX = 0;  
    }  
}  

 在引用Activity里边,先实例化,然后再引用

    SwitchButton sb;
        

sb = (SwitchButton) view.findViewById(R.id.wiperSwitch1);


        sb.setOnChangeListener(new OnChangeListener() {

            @Override
            public void onChange(SwitchButton sb, boolean state) {
                Log.d("switchButton", state ? "开" : "关");
                Toast.makeText(activity, state ? "开" : "关", Toast.LENGTH_SHORT)
                        .show();
                if (state) {
                    Toast.makeText(activity, "我是值日生,呵呵呵", Toast.LENGTH_SHORT)
                            .show();

                    editor.putString("duty", "1");
                    editor.commit();
                    if (mHandler != null) {
                        // 是值日生
                        mHandler.sendEmptyMessageDelayed(1, 1 * 200);
                    }
                } else {
                    Toast.makeText(activity, "我不是值日生,哈哈哈", Toast.LENGTH_SHORT)
                            .show();
                    editor.putString("duty", "2");
                    editor.commit();
                    if (mHandler != null) {
                        mHandler.sendEmptyMessageDelayed(2, 1 * 200);
                    }
                }
            }

        });

 

  • 大小: 2 KB
  • 大小: 3.1 KB
  • 大小: 2.7 KB
  • 大小: 587 Bytes
分享到:
评论

相关推荐

    c#自定义开关按钮,很实用

    在这个场景中,我们关注的是“自定义开关按钮”的实现,这是一个在用户界面设计中经常会遇到的需求,特别是在创建具有个性化交互体验的应用时。 自定义按钮通常涉及到对系统默认控件的扩展或完全重新设计,以满足...

    C#自定义开关按钮控件,c#自定义控件方法,C#

    在这个案例中,我们将基于`Button`控件来创建我们的自定义开关按钮。 1. **创建自定义控件类** 首先,创建一个新的类并让它继承自`Button`控件: ```csharp public class MySwitchButton : Button { // ... ...

    android 自定义开关按钮

    "android 自定义开关按钮"这个主题就是关于如何在Android应用中创建一个独特且吸引人的开关控件,通常这种开关按钮用于切换功能的开启或关闭,如静音、Wi-Fi等设置。下面我们将深入探讨这一话题。 首先,Android...

    自定义开关按钮控件

    在项目中,你可以通过RadioButtonTest这个测试类来尝试上述操作,逐步完善自定义开关按钮的功能和样式。记住,自定义控件的关键在于理解基础组件的工作原理,然后通过编程技巧和设计思维来满足特定需求。 总结来说...

    Android自定义开关按钮实现示例

    本文将深入探讨如何在Android中实现一个自定义开关按钮,基于提供的链接,我们可以通过以下步骤来创建这样的功能。 1. **理解开关按钮的基本结构** 开关按钮(Switch)在Android中是一种ToggleButton,通常用于在...

    Qt之自定义控件(开关按钮)自记

    首先,`switchbutton.cpp`和`switchbutton.h`是自定义开关按钮的核心代码。在`switchbutton.h`中,你需要声明一个继承自QAbstractButton的类,例如`SwitchButton`,并添加必要的属性和方法来控制开关状态和颜色。在`...

    Android 自定义开关按钮

    对于自定义开关按钮,我们可能不会在这里做特别的配置,但确保你的应用有足够的权限来处理可能的交互和事件。 接着,我们需要在src目录下创建一个新的Java类,作为自定义开关按钮的实现。这个类通常会继承自Android...

    Android自定义开关按钮(滑动,点击)

    本教程将聚焦于自定义开关按钮(Switch Button),一种在移动应用中常见的交互控件,用于切换两种状态,如开启和关闭。我们将讨论如何通过滑动和点击事件来实现这个功能。 首先,自定义开关按钮的基础是继承自`View...

    c#自定义开关按钮

    本主题将深入探讨如何在C#中实现一个自定义开关按钮,无需依赖任何第三方库,确保代码的安全性和可维护性。 首先,我们需要了解.NET Framework或.NET Core中的控件基础。在C#中,我们可以继承`System.Windows.Forms...

    安卓开关效果相关-自定义开关按钮.zip

    "安卓开关效果相关-自定义开关按钮.zip"这个压缩包文件显然包含了关于如何在Android平台上创建自定义开关按钮的知识点。开关按钮(ToggleButton)是用户界面中常见的一种控件,通常用于切换两个状态,如开/关、启用/...

    Android技术知识点:如何实现自定义开关按钮

    本教程将深入探讨如何在Android环境中创建一个自定义开关按钮。开关按钮(Switch Button)通常用于在两种状态之间切换,例如开启/关闭某个功能或设置。 首先,我们需要了解Android中的开关按钮基础。原生Android ...

    WPF等待和开关按钮

    在提供的压缩包文件中,可能包含了一个名为`WPFSpark`的项目,它可能是一个第三方库,提供了丰富的UI元素,包括等待指示器和自定义开关按钮。`from.gif`可能是展示效果的动图,而`WPFSpark.sln`和`WPFSpark.suo`是...

    C#自定义开关按钮控件,c#自定义控件方法,C#源码.zip.zip

    要创建一个自定义开关按钮,我们首先要继承一个基础控件类,如`System.Windows.Forms.Control`。然后,我们可以添加必要的属性来设置开关的状态(开或关)、颜色、尺寸等。例如,可以创建一个`IsOn`属性来表示开关...

    switchView自定义开关按钮demo

    所谓的开关按钮,就是只有2个状态:on和off,下图就是系统IOS 7上开关按钮效果。 起初我在android上我只会使用CheckBox去满足对应的功能。后来,查看开发文档发现,android也有了自己的原生态开关控件,并且在4.0...

Global site tag (gtag.js) - Google Analytics