今天要使用一个SeekBar控件,其实我觉得Android默认样式已经很不错了,无奈设计不同意,而且SeekBar左右两边也有图片,默认样式和图片也确实不协调,因此这里使用图片自定义SeekBar样式,首先上代码:

<SeekBar
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:max="100"
android:thumbOffset="10dp"
android:paddingLeft="10dp"
android:paddingRight="12dp"
android:thumb="@drawable/device_light_progress_thumb"
android:progressDrawable="@drawable/device_light_progressbar" />
android:thumb下的资源就是拖动条的滑块图片,android:thumbOffset的作用是防止thumb滑块不能完全显示,避免被遮挡;
android:progressDrawable下是自定义拖动条的样式,这里是两张图片,代码如下:
<?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:drawable="@drawable/progressbar_bg" /> <item android:id="@android:id/progress"
android:drawable="@drawable/progressbar_checked">
</item> </layer-list>

其中@android:id/background是指滑块未拖动时,拖动条显示的图片;

@android:id/progress是指拖动滑块后,滑块前面的部分所显示的图片;

SeekBar的使用大概就是这样,以后再遇到这方面的问题我再来补充,下面说说draw9patch。

之所以说draw9patch是因为progressbar_bg和progressbar_checked两张图片在配置SeekBar时,出现图片过长,右侧没有结束的圆弧,而直接是一个切面,因此可以看出图片的长度没有收缩,这里首先想到的就是使用SDK-tools中的draw9patch工具将两张图片制作成9图,主要过程包括两个阶段:

第一:

考虑到SeekBar的滚动条宽度较小,大约只有5-10个像素,因此第一次制作时只是将图片在横向上做成可以拉伸和收缩,纵向未作处理。将图片导入drawable-h,经调试发现,图片在在上方显示有黑边,而且图片右侧还是切面,可以知道这张图片仍然没有收缩;

经过查找资料,发现是自己没有搞清楚draw9patch制作9图的机制,即上下左右约束的都是什么:

左边 是垂直方向可以伸缩的区域
上边 是水平方向可以伸缩的区域
右边 是垂直方向的内容区域
下边 是水平方向的内容区域

(下边和右边为图片内容的padding值)

必须高和宽都加上约束,如果只有高或者只有宽添加约束,仍然会有黑线。

另外,设置黑线时,点不能断,否则9patch图片会按照普通图片进行显示。

在弄清楚原理之后,将纵向也进行draw9patch处理,经调试,SeekBar右侧也显示了圆弧,即图片适配正常。

第二:

然后我将progressbar_checked这张图片也进行了同样的处理,即拖动滑块后的图片也制作成9图。导入应用后,SeekBar的显示反而出错了,即未拖动滑块时,整个SeekBar已经显示为progressbar_checked的图片样式,好像已经拖动到底一样。这个错误让我很不理解,progressbar_checked.png未改为9图时能够正常显示,在改为9图后反而出错了,在将progressbar_checked替换为原来的图片之后,应用又恢复正常。

这里猜测是9图自动适配控件导致的,具体原因还需要继续研究。

 

Android SeekBar 和 draw9patch 的使用的更多相关文章

  1. Android——SeekBar(拖动条)相关知识总结贴

    Android进度条(ProgressBar)拖动条(SeekBar)星级滑块(RatingBar)的例子 http://www.apkbus.com/android-51326-1-1.html A ...

  2. 自定义漂亮的Android SeekBar样式

    系统自带的SeekBar真是太难看了,不能容忍! 只能自己做了,先来张效果图 第1个Seekbar 背景是颜色,thumb是图片,上代码: <SeekBar android:id="@ ...

  3. Android --SeekBar的使用

    1. 效果图

  4. Android SeekBar自定义使用图片和颜色显示

    案例使用的图片如下:                            1.在res/drawable目录下新增一个xml风格文件,seekbar_define_style.xml ? 1 2 3 ...

  5. Android SeekBar实现音量调节

    SeekBar可以通过滑块的位置来标识数值----而且拖动条允许用户拖动滑块来改变值,因此拖动条通常用于对系统的某种数值进行调节,比如调节音量等. SeekBar允许用户改变拖动条的滑块外观,改变滑块 ...

  6. android SeekBar设置背景无法被填充满的bug

    在做一个播放进度的时候,用到了SeekBar,调用布局如下: <SeekBar android:id="@+id/example_audio_bar" android:lay ...

  7. android Seekbar 拖动按钮显示不全问题

    增加下面属性即可解决: android:thumbOffset="0dip" <SeekBar android:id="@+id/controller_progre ...

  8. Android SeekBar 自定义thumb,thumb旋转动画效果

    简介 某些音乐播放或者视频播放的界面上,资源还在加载时,进度条的原点(thumb)会显示一个转圈的效果. 资源加载完成后,又切换回静态效果.这个效果增强了用户体验. 一般来说有美术人员负责设计和切图. ...

  9. Android SeekBar的OnSeekBarChangeListener

    seekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { /** * 拖动中数值的时候 * @param f ...

随机推荐

  1. JS将时间戳转换为JS Date类型

    /*将JSON Date 格式转换为JavaScript 的Date 类型JSON Date 格式:"/Date(146471041000)/"*/function JSONDat ...

  2. PHP 文字,图片水印,缩略图,裁切成小图(大小变小)

    文字水印基本思路:1.用getimagesize()获取图片的信息(as:大小,属性等):2.根据图片信息用imagecreatefromjpeg ()/imagecreatefromgif/imag ...

  3. .NET异步操作学习之一:Async/Await中异常的处理

    以前的异常处理,习惯了过程式的把出现的异常全部捕捉一遍,然后再进行处理.Async/Await关键字出来之后的确简化了异步编程,但也带来了一些问题.接下来自己将对这对关键字进行学习.然后把研究结果放在 ...

  4. lnmp安装--php与nginx结合

    软件环境: linux:centos5. nginx:.tar.gz php:.tar.gz lnmp与lamp的区别? lnmp(linux+nginx+mysql+php)的提法相对于lamp(l ...

  5. php接收二进制数据流转换成图片

    <?php /** * 图片类 * @author Haroldphp@163.com * @version 1.0 * PHP默认只识别application/x-www.form-urlen ...

  6. 字符串匹配的python实现

    所有字符串匹配算法的核心问题是,当出现不匹配时,如何向后移动模式串 一.暴力匹配算法 如果要匹配一个字符串s 和一个模式串p,则从i=0开始依次匹配s[i:(i+len(p))],简单粗暴,代码如下: ...

  7. Scala的Option类型

    Scala的Option类型 为了让所有东西都是对象的目标更加一致,也为了遵循函数式编程的习惯,Scala鼓励你在变量和函数返回值可能不会引用任何值的时候使用Option类型.在没有值的时候,使用No ...

  8. 13个小技巧帮你征服Xcode

    本文由CocoaChina翻译组成员唧唧歪歪(博客)翻译自David McGraw的博客原文:13 Xcode Tips That Will Help You Conquer Xcode当谈论到iOS ...

  9. html+css篇

    一,html语义话标签 http://www.html5jscss.com/html5-semantics-section.html

  10. iOS Copy 和 MutableCopy的区别 深浅拷贝的区别-供参考

    概述 对于系统的非容器类对象,对一不可变对象复制,copy是指针复制(浅拷贝)和mutableCopy就是对象复制(深拷贝).如果是对可变对象复制,都是深拷贝,但是copy返回的对象是不可变的. 对于 ...