zoukankan      html  css  js  c++  java
  • Android自定义View——滑动按钮 (一)

    需要继承 View 或 ViewGroup

    需要了解自定义的类中,需实现三种方法(在MainActivity的onResume方法之后进行的)

    /**
     *   测量             摆放            绘制
     *  measure    ->   layout    ->    draw
     *  onMeasure      onLayout         onDraw
     *
     *  View
     *  onMeasure(指定自己宽高)   onDraw 绘制自己内容
     *
     *  ViewGroup
     *  onMeasure(指定自己宽高,所有子View宽高)  onLayout(摆放所有子View)  onDraw 绘制内容
     *
     */

    预先准备两张图片

    1)新建ToggleView类,继承 android.view.View

    public class ToggleView extends View {
    
        /**
         * 用于代码创建
         */
        public ToggleView(Context context) {
            super(context);
        }
    
        /**
         * 用于xml创建,可指定自定义属性
         */
        public ToggleView(Context context, AttributeSet attrs) {
            super(context, attrs);
        }
    
        /**
         * 用于xml创建,可指定自定义属性.(如果指定了样式)
         */
        public ToggleView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
        }
    }

    2)在MainActivity的layout:activity_main中加入自定义View

    <com.f.customeview.Custome.ToggleView
            android:id="@+id/toggleBtn"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content">
    </com.f.customeview.Custome.ToggleView>

    3)预想自定义的滑动按钮需要哪些方式进行属性设定,假设现在MainActivity自定义几个方法:

    private ToggleView toggle;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            toggle = findViewById(R.id.toggleBtn);
    
            toggle.setSwitchBackgroundResource(R.drawable.switch_bg);//设置按钮背景
            toggle.setSlideButtonResource(R.drawable.toggle);//设置滑动的图片
            toggle.setSwitchState(false);//设置按钮的状态
        }

    在ToggleView

    public void setSwitchBackgroundResource(int background){
            toggleBackgroundBitmap = BitmapFactory.decodeResource(getResources(),background);
    
        }
        public void setSlideButtonResource(int slideButton){
            slideButtonBitmap = BitmapFactory.decodeResource(getResources(),slideButton);
            
        }
    
        public void setSwitchState(boolean mSwitchState) {
        this.mSwitchState = mSwitchState;
    }

    通过  onMeasure  onDraw方法进行绘制

        private Bitmap toggleBackgroundBitmap;
        private Bitmap slideButtonBitmap;
        private Paint paint;
    private boolean mSwitchState;
    /**
         * 用于代码创建
         */
        public ToggleView(Context context) {
            super(context);
            init();
        }
    
        @Override
        protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
            setMeasuredDimension(toggleBackgroundBitmap.getWidth(),toggleBackgroundBitmap.getHeight());
    
        }
    
        private void init() {
            paint = new Paint();
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
        // 1、绘制背景
        canvas.drawBitmap(toggleBackgroundBitmap,0,0,paint);
        // 2、绘制滑块
        if(mSwitchState){
        int newLeft = toggleBackgroundBitmap.getWidth() - slideButtonBitmap.getWidth();
        canvas.drawBitmap(slideButtonBitmap,newLeft,0,paint);
        }else {
        canvas.drawBitmap(slideButtonBitmap,0,0,paint);
        }
      }

    到这里只要改变setSwitchState运行程序,就可以显示出自定义的滑动按钮开关状态了

      

    本文只通过设置bool值改变滑动块图片位置。

  • 相关阅读:
    markdown语法
    基于Vue 使用threejs导入gltf动画模型
    创建Vue项目
    一个简单的特效
    网页五--html插入表格
    网页四--按钮反应
    网页三
    简单的页面
    一个能实现超链接的最简单程序
    计算机基本配置和作用
  • 原文地址:https://www.cnblogs.com/Nora-F/p/10891184.html
Copyright © 2011-2022 走看看