温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

在Android 中利用Seekbar可以实现哪些功能

发布时间:2020-12-02 15:48:04 来源:亿速云 阅读:143 作者:Leah 栏目:移动开发

在Android 中利用Seekbar可以实现哪些功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

Android 中Seekbar详解及简单实例

做到音频播放和音乐播放时,大多数都要用到Seekbar。现在我先简单介绍下Seekbar的几个重要属性。

  • android:max 设置值的大小 .
  • android:thumb=”@drawable/” 显示的那个可拖动图标,如果没有设置该参数则为系统默认,如果自己需要重新定义,则将自己需要的图标存放在资源目录 /res/drawable下,然后调用即可.
  • android:thumbOffset 拖动图标的偏量值,可以让拖动图标超过bar的长度.
  • android:progress 设置seekbar当前的默认值,范围0到max之间.
  • android:secondaryProgress 用过的迅雷的都知道拖动图标随着当前的播放时间的走动而走动,同时我们也注意到了也有个缓冲看到的进度条,这个属性就是用来设置默认显示的值为多少,范围为0到max.
  • android:progressDrawable 当我们不想使用系统默认的SeekBar时可以自己定义一个,这个资源文件就是用来调用我们自己定义的Seekbar图标的一般是在drawable下建立一个.xml文件s用layer-list来组织这些图标.
     

一般情况下,Seekbar的所有配置是写在style里的,而不是xml里。下面贴出我的代码:

<SeekBar
            android:id="@+id/sb"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:max="100"
            />

style的代码:

<style name="Widget.SeekBar.Normal" parent="@android:style/Widget.SeekBar">
    <item name="android:thumbOffset">8dip</item>
    <item name="android:maxHeight">8dip</item>
    <item name="android:indeterminateOnly">false</item>
    <item name="android:indeterminateDrawable">@android:drawable/progress_indeterminate_horizontal</item>
    <item name="android:progressDrawable">@drawable/po_seekbar</item>
    <item name="android:minHeight">8dip</item>
    <item name="android:thumb">@mipmap/cricle</item>
  </style>

progressdrawable的代码:

<&#63;xml version="1.0" encoding="utf-8"&#63;>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:id="@android:id/background">
    <shape>
      <solid android:color="#E6E6E6" />
      <stroke
        android:width="1dp"
        android:color="#cccccc" />
      <corners android:radius="5dp" />
    </shape>
  </item>
  <item android:id="@android:id/secondaryProgress">
    <clip>
      <shape>
        <corners android:radius="5dp" />
        <solid android:color="#E6E6E6" />
      </shape>
    </clip>
  </item>
  <item android:id="@android:id/progress">
    <clip>
      <shape>
        <corners android:radius="5dp" />
        <solid android:color="#7DBF60" />
      </shape>
    </clip>
  </item>

</layer-list>

这样一个Seekbar就解决了。

Seekbar有的监听,就是你拖动到哪播放到哪(差不多这个意思)。

代码很简单:

 sb.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {

      public void onProgressChanged(SeekBar seekBar, int i, boolean b) {
        int process = seekBar.getProgress();
        if (player != null) {
          player.seekTo(process);
        }
      }

      public void onStartTrackingTouch(SeekBar seekBar) {

      }

      public void onStopTrackingTouch(SeekBar seekBar) {

      }
    });

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI