本文简单介绍下Android之自定义ProgressBar。
多的不说,先上图
布局文件
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" android:orientation="vertical" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello_world" android:padding="5dp" /> <ProgressBar android:id="@+id/progress1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5dp" /> <ProgressBar android:id="@+id/progress2" style="?android:attr/progressBarStyleHorizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:max="100" android:progress="60" android:secondaryProgress="80" android:padding="5dp"/> <ProgressBar android:id="@+id/progress3" style="?android:attr/progressBarStyleHorizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:max="100" android:progress="60" android:secondaryProgress="80" android:progressDrawable="@drawable/progress_horizontal" android:padding="5dp"/> <ProgressBar android:id="@+id/progress4" style="?android:attr/progressBarStyleHorizontal" android:layout_width="fill_parent" android:layout_height="25dp" android:max="100" android:progress="80" android:paddingLeft="1dp" android:paddingRight="1dp" android:progressDrawable="@drawable/progressbar_layer_list" android:padding="5dp"/> <ProgressBar android:id="@+id/progress5" android:layout_width="30dip" android:layout_height="30dip" android:indeterminateDrawable="@drawable/progress_selector" android:visibility="visible" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="progress value" android:padding="5dp" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/btn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="value -"/> <Button android:id="@+id/btn2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="value +"/> </LinearLayout> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="second progress value" android:padding="5dp" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/btn3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="value -"/> <Button android:id="@+id/btn4" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="value +"/> </LinearLayout> </LinearLayout>
布局文件关联的文件
progress_horizontal.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:drawable="@color/red"> </item> <item android:id="@android:id/secondaryProgress"> <scale android:drawable="@color/green" android:scaleWidth="100%" /> </item> <item android:id="@android:id/progress"> <scale android:drawable="@color/blue" android:scaleWidth="100%" /> </item> </layer-list>
progressbar_layer_list.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:drawable="@drawable/pic2"> </item> <item android:id="@android:id/progress" android:drawable="@drawable/pic1"> </item> </layer-list>
progress_selector.xml
<?xml version="1.0" encoding="UTF-8"?> <rotate xmlns:android="http://schemas.android.com/apk/res/android" android:pivotX="50%" android:pivotY="50%" android:fromDegrees="0" android:toDegrees="360"> <shape android:shape="ring" android:innerRadiusRatio="3" android:thicknessRatio="8" android:useLevel="false"> <gradient android:type="sweep" android:useLevel="false" android:startColor="#871318" android:centerColor="#D5202A" android:centerY="0.50" android:endColor="#FFEEEE"/> </shape> </rotate>
主程序
package com.sl.progressbardemo; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.view.Window; import android.widget.Button; import android.widget.ProgressBar; import android.app.Activity; public class MainActivity extends Activity { private ProgressBar mProgressBar2; private ProgressBar mProgressBar3; private ProgressBar mProgressBar4; private Button mButton1; private Button mButton2; private Button mButton3; private Button mButton4; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_PROGRESS); setContentView(R.layout.activity_main); setProgressBarVisibility(true); mProgressBar2 = (ProgressBar)findViewById(R.id.progress2); mProgressBar3 = (ProgressBar)findViewById(R.id.progress3); mProgressBar4 = (ProgressBar)findViewById(R.id.progress4); mButton1 = (Button)findViewById(R.id.btn1); mButton2 = (Button)findViewById(R.id.btn2); mButton3 = (Button)findViewById(R.id.btn3); mButton4 = (Button)findViewById(R.id.btn4); mButton1.setOnClickListener(listener); mButton2.setOnClickListener(listener); mButton3.setOnClickListener(listener); mButton4.setOnClickListener(listener); } Button.OnClickListener listener = new OnClickListener() { @Override public void onClick(View v) { Button button = (Button)v; switch (button.getId()) { case R.id.btn1: mProgressBar2.incrementProgressBy(-5); mProgressBar3.incrementProgressBy(-5); mProgressBar4.incrementProgressBy(-5); break; case R.id.btn2: mProgressBar2.incrementProgressBy(5); mProgressBar3.incrementProgressBy(5); mProgressBar4.incrementProgressBy(5); break; case R.id.btn3: mProgressBar2.incrementSecondaryProgressBy(-5); mProgressBar3.incrementSecondaryProgressBy(-5); break; case R.id.btn4: mProgressBar2.incrementSecondaryProgressBy(5); mProgressBar3.incrementSecondaryProgressBy(5); break; default: break; } } }; }
时间: 2024-10-08 09:12:29