ProgressBar,SeekBar的美化

进度条类控件ProgressBar作为某些操作进度的可视指示器,为用户呈现操作的进度,它还有一个次要的进度条,用来显示中间进度,如在流媒体播放时视频缓冲的进度。进度条有两种模式确定模式和不确定模式,在不确定模式下,进度条显示循环动画,这种模式常用于应用程序使用任务的长度是未知的。


QQ截图20150709153649

ProgressBar的样式设定其实有两种方式如下:

Widget.ProgressBar.Horizontal
Widget.ProgressBar.Small
Widget.ProgressBar.Large
Widget.ProgressBar.Inverse
Widget.ProgressBar.Small.Inverse
Widget.ProgressBar.Large.Inverse
使用的时候可以这样:style=”@android:style/Widget.ProgressBar.Small”,另外还有一种方式就是使用系统的attr,下面的方式是系统的style:

style=”?android:attr/progressBarStyle”
style=”?android:attr/progressBarStyleHorizontal”
style=”?android:attr/progressBarStyleInverse”
style=”?android:attr/progressBarStyleLarge”
style=”?android:attr/progressBarStyleLargeInverse”
style=”?android:attr/progressBarStyleSmall”
style=”?android:attr/progressBarStyleSmallInverse”
style=”?android:attr/progressBarStyleSmallTitle”

1 <ProgressBar
2         android:id="@+id/progressBar1"
3         style="?android:attr/progressBarStyleHorizontal" <==> style="@android:style/Widget.ProgressBar.Horizontal"
4         android:layout_width="match_parent"
5         android:layout_height="wrap_content" />

ProgressBar中几个

1.重要方法:
setProgress() // 设置当前进度值
incrementProgressBy() // 设置进度增量

2.常用属性:
progressDrawable        // 设置进度条的轨道的绘制情况
indeterminateDrawable   // 设置绘制不显示进度的进度条的Drawable对象

自定义ProgressBar不确定模式进度条
progressbar
实现方式:

1 <!--系统-->
2   <ProgressBar
3       android:id="@+id/progressBar3"
4       style="@android:attr/progressBarStyleLarge"
5       android:layout_width="wrap_content"
6       android:layout_height="wrap_content"
7       android:layout_marginTop="10dp" />
8   <!--通过样式自定义-->
9   <ProgressBar
10       style="@style/mProgress_circle"
11       android:layout_width="wrap_content"
12       android:layout_height="wrap_content"
13       android:layout_marginTop="10dp" />
14 <!--通过shape自定义-->
15   <ProgressBar
16       style="@style/mProgress_circle_shape_loading"
17       android:layout_width="wrap_content"
18       android:layout_height="wrap_content"
19       android:layout_marginTop="10dp" />

mProgress_circle.xml

1 <style name="mProgress_circle">
2     <item name="android:indeterminateDrawable">@drawable/progressbar_circle</item>
3     <item name="android:minWidth">25dp</item>
4     <item name="android:minHeight">25dp</item>
5     <item name="android:maxWidth">60dp</item>
6     <item name="android:maxHeight">60dp</item>
7 </style>

progressbar_circle.xml

1 <?xml version="1.0" encoding="utf-8"?>
2 <!-- android:drawable 自定义的菊花图片  -->
3 <rotate xmlns:android="http://schemas.android.com/apk/res/android"
4     android:drawable="@drawable/voice_loading"
5     android:fromDegrees="0"
6     android:pivotX="50%"
7     android:pivotY="50%"
8     android:toDegrees="360" >
9 </rotate>

mProgress_circle_shape_loading.xml

1 <style name="mProgress_circle_shape_loading">
2       <item name="android:indeterminateDrawable">@drawable/progress_circle_shape</item>
3  
4   </style>

progress_circle_shape.xml

1 <?xml version="1.0" encoding="utf-8"?>
2 <rotate xmlns:android="http://schemas.android.com/apk/res/android"
3     android:fromDegrees="0"
4     android:pivotX="50%"
5     android:pivotY="50%"
6     android:toDegrees="360" >
7  
8     <shape
9         android:innerRadiusRatio="3"
10         android:shape="ring"
11         android:thicknessRatio="8"
12         android:useLevel="false" >
13  
14     
15         <gradient
16             android:centerColor="#FFFFFF"
17             android:centerY="0.50"
18             android:endColor="#1E90FF"
19             android:startColor="#000000"
20             android:type="sweep"
21             android:useLevel="false" />
22  
23   
24     </shape>
25  
26 </rotate>

自定义动画实现

progressbar3
主布局

1 <LinearLayout
2        android:id="@+id/progressbar_layout"
3        android:layout_width="match_parent"
4        android:layout_height="match_parent"
5        android:gravity="center"
6        android:orientation="vertical" >
7        <ProgressBar
8            android:id="@+id/my_progressbar"
9            android:layout_width="wrap_content"
10            android:layout_height="wrap_content"
11            android:paddingLeft="30dp"
12            android:minWidth="250dp"
13            android:minHeight="250dp"
14            android:indeterminateDrawable="@anim/progress_circle_loading_anim"/>
15    </LinearLayout>

动画资源

progress_loading_image_01                            progress_loading_image_02

progress_loading_image_01.png       progress_loading_image_02.png

动画资源文件 progress_circle_loading_anim.xml

1 <?xml version="1.0" encoding="utf-8"?>
2 <animation-list android:oneshot="false" xmlns:android="http://schemas.android.com/apk/res/android">
3   <item android:duration="100"android:drawable="@drawable/progress_loading_image_01" />
4   <item android:duration="100"android:drawable="@drawable/progress_loading_image_02" />
5 </animation-list>

 

SeekBar是一种特殊的进度条,其与ProgressBar的区别在于,SeekBar支持用户手动调整进度,可以实现进度条的个性化设置。

SeekBar的继承关系如下:
java.lang.Object
->android.view.View
->android.widget.ProgressBar
->android.widget.AbsSeekBar
->android.widget.SeekBar

监控SeekBar的进度变化的实现方法如下:

1 seekBar.setOnSeekBarChangeListener(new OnSeekBarChangeListener(){
2 @Override
3 public void onProgressChanged(SeekBar seekBar, int progress,booleanfromUser) {
4   ...//fromUser参数标识变化是否来自用户
5 }
6 @Override
7 public void onStartTrackingTouch(SeekBar seekBar) {
8   ...//开始触摸手势
9 }
10 @Override
11 public void onStopTrackingTouch(SeekBar seekBar) {
12     ...//结束触摸手势
13   }
14 });

SeekBar继续至ProgressBar拥有ProgressBar所有特性,区别在可以拖动展示.

我们来看下如何自定义一个SeekBar

1 <SeekBar
2         android:id="@+id/seekBar2"
3         android:layout_width="match_parent"
4         android:layout_height="wrap_content"
5         android:layout_margin="20dp"
6         android:progressDrawable="@drawable/seekbar_progress_drawable1"
7         android:thumb="@drawable/seekbar_progress_thum_selector" />

android:progressDrawable=”@drawable/seekbar_progress_drawable1″ //定义显示进度
android:thumb=”@drawable/seekbar_progress_thum_selector” //定义滑块
seekbar

seekbar_progress_drawable1.xml

1 <?xml version="1.0" encoding="UTF-8"?>
2 <layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
3  
4     <item
5         android:id="@android:id/background"
6         android:drawable="@drawable/progress_bar_n">
7     </item>
8     <item android:id="@android:id/progress">
9         <clip>
10             <nine-patch android:src="@drawable/progress_bar_p" />
11         </clip>
12     </item>
13  
14 </layer-list>

seekbar_progress_thum_selector.xml

1 <?xml version="1.0" encoding="utf-8"?>
2 <selector xmlns:android="http://schemas.android.com/apk/res/android">
3  
4     <item android:drawable="@drawable/eq_seekbar_thumb_press"android:state_pressed="true"></item>
5     <item android:drawable="@drawable/eq_seekbar_thumb_normal"></item>
6  
7 </selector>
1 <?xml version="1.0" encoding="UTF-8"?>
2 <layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
3     <item android:id="@android:id/background">
4             <shape>
5                 <corners android:radius="10dip" />
6  
7                 <gradient
8                         android:angle="270"
9                         android:centerColor="#ff000000"
10                         android:centerY="0.45"
11                         android:endColor="#ffAABD00"
12                         android:startColor="#ffffffff" />
13             </shape>
14     </item>
15     <item android:id="@android:id/progress">
16         <clip>
17             <shape>
18                 <corners android:radius="10dip" />
19  
20                 <gradient
21                     android:angle="270"
22                     android:centerColor="#ffFFFF00"
23                     android:centerY="0.45"
24                     android:endColor="#ff808A87"
25                     android:startColor="#ffffffff" />
26             </shape>
27         </clip>
28     </item>
29  
30 </layer-list>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值