当前位置:   article > 正文

水平进度条:解决系统SeekBar宽度不准确、滑动颜色显示不准的问题_安卓设置seekbar宽度不准确

安卓设置seekbar宽度不准确

水平进度条:自定义SeekBar背景
水平进度条:解决系统SeekBar宽度不准确、滑动颜色显示不准的问题
水平进度条:RangeSeekBar具体使用

  • 上篇文章:水平进度条:自定义SeekBar背景 发现, 系统自带的SeekBar,设置android:layout_width="120dp",实际宽度并不是120dp, 存在padding。

    • 有人说设置findViewById(R.id.seekbar).setPadding(0,0,0,0); 可以解决。实测发现,这中设置只在简单界面上起作用。在复杂布局界面仍然无效。
    • 如果在背景xml中的item标签内部设置宽度,又会出现,滑动位置与颜色显示不对应的问题。
  • 只能用两个第三方库,看效果图:

  • RangeSeekBar ,

 maven { url 'https://jitpack.io' }
 
 implementation 'com.github.Jay-Goo:RangeSeekBar:v3.0.0'
  • 1
  • 2
  • 3
implementation 'com.xw.repo:bubbleseekbar:3.20-lite'
  • 1
  • 完整布局代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#80000000"
    tools:context=".MainActivity">
    <SeekBar
        android:id="@+id/seekbar"
        android:layout_width="120dp"
        android:layout_height="20dp"
        android:layout_centerInParent="true"
        android:progressDrawable="@drawable/selector_seek_bar_rect"
        android:thumb="@drawable/seek_bar"
        android:thumbOffset="-1dp"
        />


    <com.jaygoo.widget.RangeSeekBar
        android:id="@+id/rsb"
        android:layout_width="120dp"
        android:layout_height="wrap_content"
        android:layout_below="@id/seekbar"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        app:rsb_gravity="center"
        app:rsb_mode="single"
        app:rsb_progress_drawable="@drawable/shape_seekbar_progress"
        app:rsb_progress_drawable_default="@drawable/shape_seekbar_progress_default"
        app:rsb_progress_height="5dp"
        app:rsb_thumb_drawable="@drawable/seek_bar"
        app:rsb_thumb_height="15dp"
        app:rsb_thumb_width="15dp" />

    <com.xw.repo.BubbleSeekBar
        android:id="@+id/bsb"
        android:layout_width="120dp"
        android:layout_height="wrap_content"
        android:layout_below="@id/rsb"
        android:layout_centerHorizontal="true"
        app:bsb_hide_bubble="true"
        app:bsb_max="100"
        app:bsb_min="0"
        app:bsb_progress="0"
        app:bsb_second_track_color="#00391F"
        app:bsb_thumb_color="#ffffff"
        app:bsb_track_color="#D8D8D8" />


</RelativeLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • thumb图片:
    在这里插入图片描述
  • 默认SeekBar背景selector_seek_bar_rect.xml代码:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@android:id/background" android:height="5dp" android:gravity="center">
        <shape>
            <solid android:color="#ffffff" />
            <corners android:radius="2.5dp" />
        </shape>
    </item>
    <item android:id="@android:id/progress" android:height="5dp" android:gravity="center">
        <clip>
            <shape>
                <solid android:color="#ff4f9aff" />
                <corners android:radius="2.5dp" />
            </shape>
        </clip>
    </item>
</layer-list>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • RangeSeekBar进度条:shape_seekbar_progress.xml代码:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners android:radius="2.5dp" />
    <solid android:color="#4f9aff" />
</shape>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • RangeSeekBar滑道背景:shape_seekbar_progress_default.xml代码:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid android:color="#ffffff"/>
    <corners android:radius="2.5dp" />
</shape>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/384649
推荐阅读
相关标签
  

闽ICP备14008679号