android 竖向SeekBar控件的自定义

我们都知道seekBar是个横向的拖动条,也有的的时候我们需要竖向的拖动条,有两种方式:1是自己定义控件用画笔画,这样这几的问题很多也很麻烦;2.是在seekBar基础上稍作修改。无疑是后者简单的多,我们只要改变绘制的方向就好,代码如下:

@Override

protected synchronized void onDraw(Canvas canvas) {

    canvas.rotate(90);//将画布旋转90度

    canvas.translate(0,-getWidth());//将绘制原点移至 0,-getWidth()

   super.onDraw(canvas);

 }

上面代码涉及到了画布的旋转和原点的转移如下图:



如果只是旋转画布,那么控件位置就会出现在xy的负方向,也就是画布外,导致看不到控件。这时候我们就需要canvas.translate(0,-getWidth());将绘制原点移到0,-getWidth()位置,使控件处于画布上。以上我们基本配置好了画布和原点,接下来为了不然控件显示不全我们还要处理控件的宽高。代码如下:

@Override

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SeekBarAndroid中的一个自定义控件,它允许用户通过滑动来选择一个数值。你可以在XML布局文件中声明一个SeekBar控件,并通过代码来获取和设置其值。 要创建一个自定义SeekBar控件,你可以继承SeekBar类,并重写一些方法来实现自定义的行为。以下是一个示例: ```java public class CustomSeekBar extends SeekBar { public CustomSeekBar(Context context) { super(context); } public CustomSeekBar(Context context, AttributeSet attrs) { super(context, attrs); } public CustomSeekBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override public synchronized void setProgress(int progress) { // 在设置进度之前进行一些自定义操作 // 例如限制进度的范围或者改变进度条的外观 super.setProgress(progress); } @Override public synchronized void onProgressChanged(int progress, boolean fromUser) { super.onProgressChanged(progress, fromUser); // 当进度发生改变时的处理逻辑 // 可以根据进度值做出相应的响应 } } ``` 在这个示例中,我们重写了`setProgress()`方法和`onProgressChanged()`方法来实现自定义行为。你可以根据自己的需求进行修改和扩展。 在布局文件中使用自定义SeekBar控件时,需要指定完整的自定义控件的类名,例如: ```xml <com.example.app.CustomSeekBar android:id="@+id/customSeekBar" android:layout_width="match_parent" android:layout_height="wrap_content" /> ``` 这样就可以在代码中获取到这个自定义SeekBar控件,并对其进行操作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值