【转】 为SeekBar滑块设置固定值以及自定义Seekbar,progressbar样式--不错

原文网址:http://blog.csdn.net/jdsjlzx/article/details/7804080

最近在项目中使用到了seekbar和progressbar,且必须按照设计要求来进行设置,如下图。要实现这个效果就必须对这两个控件进行自定义。
 
 一,SeekBar
  
   一开始要实现这个效果参考网上的自定义方法根本无法达到这个效果,没办法只能投机取巧了。

1,背景刻度的图片我是用了一个ImageView,然后在ImageView上放一个SeekBar。因为是个定制的平板应用,分辨率是限定的1280*768,所以我使用的是AbsoluteLayout这样ImageView和SeekBar的位置和大小都是固定的了,估计在其他布局中这样使用会有问题。

2,在布局文件中的代码如下:

[html] view plaincopy

  1. <ImageView
  2. android:layout_width="400dip"
  3. android:layout_height="95dip"
  4. android:layout_x="830dip"
  5. android:layout_y="484dip"
  6. android:src="@drawable/seekbar_background_5" //刻度图片
  7. android:scaleType="centerCrop"
  8. android:background="@null"
  9. />
  10. <SeekBar
  11. android:id="@+id/sensor_sensitivity"
  12. android:layout_width="360dip"
  13. android:layout_height="64dip"
  14. android:layout_x="850dip"
  15. android:layout_y="498dip"
  16. android:progressDrawable="@drawable/suretouch_seekbar_img"
  17. android:thumb="@drawable/suretouch_seekbar_thumb"
  18. style="?android:attr/progressBarStyleHorizontal"
  19. android:paddingLeft="5dip"
  20. android:paddingRight="5dip"
  21. android:paddingBottom="2dip"
  22. android:maxHeight="1dip"  //注意:一定得设置进度条的高度,不然进度条会很高。
  23. android:minHeight="1dip"
  24. android:max="100"
  25. android:progress="0"
  26. />

[html] view plain copy

  1. <ImageView
  2. android:layout_width="400dip"
  3. android:layout_height="95dip"
  4. android:layout_x="830dip"
  5. android:layout_y="484dip"
  6. android:src="@drawable/seekbar_background_5" //刻度图片
  7. android:scaleType="centerCrop"
  8. android:background="@null"
  9. />
  10. <SeekBar
  11. android:id="@+id/sensor_sensitivity"
  12. android:layout_width="360dip"
  13. android:layout_height="64dip"
  14. android:layout_x="850dip"
  15. android:layout_y="498dip"
  16. android:progressDrawable="@drawable/suretouch_seekbar_img"
  17. android:thumb="@drawable/suretouch_seekbar_thumb"
  18. style="?android:attr/progressBarStyleHorizontal"
  19. android:paddingLeft="5dip"
  20. android:paddingRight="5dip"
  21. android:paddingBottom="2dip"
  22. android:maxHeight="1dip"  //注意:一定得设置进度条的高度,不然进度条会很高。
  23. android:minHeight="1dip"
  24. android:max="100"
  25. android:progress="0"
  26. />

3,自定义滑块,在drawable文件中加入自定义的xml文件。

[html] view plaincopy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <!-- 按下状态 -->
  4. <item
  5. android:state_pressed="true"
  6. android:drawable="@drawable/seekbar_block" />
  7. <!-- 普通无焦点状态 -->
  8. <item
  9. android:state_focused="false"
  10. android:state_pressed="false"
  11. android:drawable="@drawable/seekbar_block" />
  12. </selector>

[html] view plain copy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <!-- 按下状态 -->
  4. <item
  5. android:state_pressed="true"
  6. android:drawable="@drawable/seekbar_block" />
  7. <!-- 普通无焦点状态 -->
  8. <item
  9. android:state_focused="false"
  10. android:state_pressed="false"
  11. android:drawable="@drawable/seekbar_block" />
  12. </selector>

4,自定义进度条的颜色,同样在drawable中加入自定义需要的xml文件。

[html] view plaincopy

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <layer-list
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <item android:id="@android:id/progress">
  5. <clip>
  6. <shape>
  7. <gradient
  8. android:startColor="@color/big_title"
  9. android:centerColor="@color/big_title"
  10. android:endColor="@color/big_title"
  11. />
  12. </shape>
  13. </clip>
  14. </item>
  15. </layer-list>

[html] view plain copy

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <layer-list
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <item android:id="@android:id/progress">
  5. <clip>
  6. <shape>
  7. <gradient
  8. android:startColor="@color/big_title"
  9. android:centerColor="@color/big_title"
  10. android:endColor="@color/big_title"
  11. />
  12. </shape>
  13. </clip>
  14. </item>
  15. </layer-list>

5,设置滑块的位置,也就是当滑动滑块后只能让其停在刻度上,要现实这个效果我采用的方法是当滑块停止的时候判断当前的值,比如第二个刻度是25,这里在0到25中去个中间数比如13,也就是当滑块滑到大于13小于25到50的中间数时就setProgress(25),这样就设定在25的位置也就是第二个刻度位置。后面的以此类推。seekbar的事件中有个OnStopTrackingTouch,代码如下:

[java] view plaincopy

  1. public void onStopTrackingTouch(SeekBar seekBar) {
  2. // TODO Auto-generated method stub
  3. int seekProgress = mSeekBar.getProgress();
  4. if(seekProgress<13){
  5. mSeekBar.setProgress(0);
  6. }else if(seekProgress>=13 && seekProgress<38){
  7. mSeekBar.setProgress(25);
  8. }else if(seekProgress>=38 && seekProgress<63){
  9. mSeekBar.setProgress(50);
  10. }else if(seekProgress>=63 && seekProgress<88){
  11. mSeekBar.setProgress(75);
  12. }else if(seekProgress>=88){
  13. mSeekBar.setProgress(100);
  14. }
  15. }

[java] view plain copy

  1. public void onStopTrackingTouch(SeekBar seekBar) {
  2. // TODO Auto-generated method stub
  3. int seekProgress = mSeekBar.getProgress();
  4. if(seekProgress<13){
  5. mSeekBar.setProgress(0);
  6. }else if(seekProgress>=13 && seekProgress<38){
  7. mSeekBar.setProgress(25);
  8. }else if(seekProgress>=38 && seekProgress<63){
  9. mSeekBar.setProgress(50);
  10. }else if(seekProgress>=63 && seekProgress<88){
  11. mSeekBar.setProgress(75);
  12. }else if(seekProgress>=88){
  13. mSeekBar.setProgress(100);
  14. }
  15. }

对于ProgressBar的设置同样是采用一个ImageView为背景(外围的黑框),在ImageView上放一个ProgressBar控件,然后自定义进度条的颜色。只是在调整它们之间的位置和大小的时候比较费时点,不管怎样已经达到了想要的效果。

时间: 2024-08-08 03:01:14

【转】 为SeekBar滑块设置固定值以及自定义Seekbar,progressbar样式--不错的相关文章

Jquery slider范围滑块,为两个滑块设置不同的setp值

需求:slider范围滑块,当滑动初始滑块的时候一次要跳3步,滑动后面滑块的时候一次只跳一步 也就是要给两个滑块不同的setp值 设置setp值得方法是: $( "#English-slider" ).slider("option" ,"step",2); slider的start方法是当滑块开始滑动时,触发此事件. start:function( event, ui ){ //滑块开始滑动时触发 } 在start方法中console.log(&

Android课程---Android 如何用滑杆(SeekBar)组件设置图片颜色的透明度(转)

Android系统支持的颜色是由4个值组成的,前3个为RGB,也就是我们常说的三原色(红.绿.蓝),最后一个值是A,也就是Alpha.这4个值都在0~255之间.颜色值越小,表示该颜色越淡,颜色值越大,表示该颜色越深.如果RGB都是0,就是黑色,如果都为255,就是白色.Alpha也需要在0~255之间变化.Alpha的值越小,颜色就越透明,Alpha的值越大,颜色就不透明.当Alpha的值为0时,颜色完全透明,完全透明的位图或者图形从View上消失.当Alpha的值为255时,颜色不透明.从A

Android 设置alpha值来制作透明与渐变效果的实例

Android系统支持的颜色是由4个值组成的,前3个为RGB,也就是我们常说的三原色(红.绿.蓝),最后一个值是A,也就是Alpha.这4个值都在0~255之间.颜色值越小,表示该颜色越淡,颜色值越大,表示该颜色越深.如果RGB都是0,就是黑色,如果都为255,就是白色.Alpha也需要在0~255之间变化.Alpha的值越小,颜色就越透明,Alpha的值越大,颜色就不透明.当Alpha的值为0时,颜色完全透明,完全透明的位图或者图形从View上消失.当Alpha的值为255时,颜色不透明.从A

spring @Value 设置默认值

@Value 的作用不用说 大家都知道 注解模式下 读取配置文件 注入属性值 /** * MQ地址 */ @Value("${NamesrvAddr}") private String namesrvAddr;   上面的是一个标着的 @Value 注解 如果配置文件中没有设置 NamesrvAddr Spring 在启动的时候讲报错. 设置默认值很简单 @Value("${NamesrvAddr:192.168.0.1}") private String name

EF Core1.0 CodeFirst为Modell设置默认值!

当我们使用CodeFirst时,有时候需要设置默认值! 如下 public int Delete { get; set; } = 0; public string AdminName {get; set;} = "admin"; public bool CacheDbResults { get; set; } = true;

Ubuntu 16设置固定IP和DNS

ubuntu 16  设置固定ip地址和dns 1.设置ip地址 vi /etc/network/interfaces 添加如下内容: # The primary network interface # ens160是网卡,不知道自己是什么样的网卡,可以通过命令ip addr查看auto ens160iface ens160 inet static # 设置固定的ip地址,如下示例address 10.0.0.2 # 子网和网关可以通过route -n查看netmask 255.255.255.

Siebel 找字段、下拉菜单设置值、弹出新页面、弹出选择框、设置默认值 、按钮代码

产品缺陷太多,跟用户交互不人性化.例如搜索新建客户功能,用户输入后会自动保存数据,一旦保存后一. 找字段1.简单 CTRL+Q CTRL+Q 服务请求编号----对应的表.字段.长度: 客户编码-----对应的表.字段.长度(弹出新页面):- 点击上面的pick Applet会弹出“选取客户”对话框 有JOIN就不用TABLE:require代表必填 字段有两个值----项目编号 下图确定只有projectNum有用 3.表单中的字段(不在list column中,而是在control) 二.下

Linux系列:Ubuntu虚拟机设置固定IP上网(配置IP、网关、DNS、防止resolv.conf被重写)

虚拟机里设置上网方式为NAT最方便,因为无需手动设置即可上网,但是NAT的上网方式默认是DHCP动态分配IP的,这意味着你每次重启虚拟机都 有不一样的IP地址,这对一般用户没任何问题.但是如果你的机子有特殊用处,比如作为服务器,需要IP地址信息,亦或者像我一样,作为一个云计算的节点, 其IP都是在配置文件里配置好的,如果每次重启系统都要跑过去修改下配置文件里的IP,那简直是不可取的做法,因此为虚拟机设置固定IP上网非常的有必 要! 设置固定IP的方法很多,大家都知道虚拟机上网有三种模式:brid

SplendidCRM中给来自EditView中的listbox控件设置选中值或数据源

DropDownList list = this.findContol("aas") as DropDownList;list.DataSource = new DataTable() ------------------------------- Control ctl = this.FindControl("NAME");            if (ctl != null)            {                if (ctl is Dro