日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android学习笔记18:自定义Seekbar拖动条式样

發布時間:2025/7/14 Android 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android学习笔记18:自定义Seekbar拖动条式样 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

  SeekBar拖動條可以由用戶控制,進行拖動操作。比如,應用程序中用戶需要對音量進行控制,就可以使用拖動條來實現。

1.SeekBar控件的使用

1.1SeekBar常用屬性

  SeekBar的常用屬性有以下一些:

android:max[integer]//設置拖動條的最大值

android:progress[integer]//設置當前的進度值

android:secondaryProgress[integer]//設置第二進度,通常用做顯示視頻等的緩沖效果

android:thumb[drawable]//設置滑塊的圖樣

android:progressDrawable[drawable]//設置進度條的圖樣

1.2SeekBar事件監聽器

  在使用SeekBar時,我們可以通過設置事件監聽器setOnSeekBarChangeListener來獲取SeekBar的當前狀態。在SeekBar中通常需要監聽以下3個事件:

public?void?onProgressChanged(SeekBar?seekBar,?int?progress,?boolean?fromUser);

public?void?onStartTrackingTouch(SeekBar?seekBar);

public?void?onStopTrackingTouch(SeekBar?seekBar);

  其中,onProgressChanged()用于監聽SeekBar進度值的改變;onStartTrackingTouch()用于監聽SeekBar開始拖動;onStopTrackingTouch()用于監聽SeekBar停止拖動。

1.3實例

  在本實例中,實現了一個簡單的SeekBar案例,設置了拖動條的最大值為100,當前進度值為30,第二進度為50。設置了SeekBar的事件監聽器,對SeekBar進度值的改變、SeekBar開始拖動、SeekBar停止拖動進行了監聽,并將結果分別顯示在兩個TextView控件中。

  在xml布局文件中,實現了對一個SeekBar控件和兩個TextView控件的布局設置,具體源代碼如下:

xml布局文件 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.com/tools" 3 android:orientation="vertical" 4 android:layout_width="match_parent" 5 android:layout_height="match_parent" > 6 7 <SeekBar 8 android:id="@+id/seekbar" 9 android:layout_width="match_parent" 10 android:layout_height="wrap_content" 11 android:max="100" 12 android:progress="30" 13 android:secondaryProgress="50"> 14 </SeekBar> 15 16 <TextView 17 android:id="@+id/textview1" 18 android:layout_width="match_parent" 19 android:layout_height="wrap_content" > 20 </TextView> 21 22 <TextView 23 android:id="@+id/textview2" 24 android:layout_width="match_parent" 25 android:layout_height="wrap_content" > 26 </TextView> 27 </LinearLayout>

  在java代碼中,實現了對SeekBar進度值的改變、SeekBar開始拖動、SeekBar停止拖動的監聽,具體源代碼如下:

java代碼 1 package com.example.android_seekbar; 2 3 import android.os.Bundle; 4 import android.widget.SeekBar; 5 import android.widget.SeekBar.OnSeekBarChangeListener; 6 import android.widget.TextView; 7 import android.app.Activity; 8 9 public class MainActivity extends Activity implements OnSeekBarChangeListener { 10 11 SeekBar mSeekBar; //SeekBar對象,用于顯示進度條 12 TextView mTextView1; //TextView對象,用于顯示當前進度值 13 TextView mTextView2; //TextView對象,用于顯示拖動狀態 14 15 @Override 16 public void onCreate(Bundle savedInstanceState) { 17 super.onCreate(savedInstanceState); 18 setContentView(R.layout.activity_main); //加載布局文件 19 20 //加載控件 21 mSeekBar = (SeekBar)this.findViewById(R.id.seekbar); 22 mTextView1 = (TextView)this.findViewById(R.id.textview1); 23 mTextView2 = (TextView)this.findViewById(R.id.textview2); 24 25 mSeekBar.setOnSeekBarChangeListener(this); //設置SeekBar的監聽器 26 } 27 28 //進度值改變事件監聽 29 public void onProgressChanged(SeekBar seekBar, int progress, 30 boolean fromUser) { 31 mTextView1.setText("當前值:" + progress); 32 } 33 34 //開始拖動事件監聽 35 public void onStartTrackingTouch(SeekBar seekBar) { 36 mTextView2.setText("正在調節"); 37 } 38 39 //停止拖動事件監聽 40 public void onStopTrackingTouch(SeekBar seekBar) { 41 mTextView2.setText("停止調節"); 42 } 43 }

  實例運行后的效果如圖1所示。

?

1 Seekbar效果圖

2.自定義SeekBar式樣

  Android提供的默認SeekBar式樣很單一,并不能完全滿足開發的需要,如何來定制自己的SeekBar式樣呢?

  不難看出,一個SeekBar是由滑塊和滑竿兩部分組成的。所以,要實現自定義的SeekBar式樣,只需要分別實現自定義的滑塊和滑竿就可以了。

2.1自定義滑塊的實現

  通過觀察可以看出,滑塊有兩種狀態:押下狀態和未押下狀態。當押下滑塊時,滑塊為高亮顯示狀態;當未押下滑塊時,滑塊為置灰狀態。

  所以,在我們自定義的Seekbar中,可以使用兩張圖片來分別表示滑塊的押下和未押下狀態。具體可以在工程的res/drawable目錄下新建thumb.xml文件,來加載這兩種張圖片,并通過設置android:state_pressed屬性來選擇顯示哪張圖片。

  具體的thumb.xml源代碼如下:

thumb.xml源代碼 1 <?xml version="1.0" encoding="utf-8"?> 2 <selector xmlns:android="http://schemas.android.com/apk/res/android"> 3 4 <!-- 滑塊未壓下時 --> 5 <item 6 android:state_pressed="false" 7 android:drawable="@drawable/thumb_grey" > 8 </item> 9 10 <!-- 滑塊壓下時 --> 11 <item 12 android:state_pressed="true" 13 android:drawable="@drawable/thumb_green" > 14 </item> 15 16 </selector>

2.2自定義滑竿的實現

  要實現自定義的滑竿式樣,可以通過設置滑竿背景、進度條式樣以及第二進度條式樣來實現。具體可以在工程的res/drawable目錄下新建seekbarbackground.xml文件,并通過設置android:drawable屬性來加載三張圖片分別表示滑竿背景、進度條式樣以及第二進度條式樣。

  具體的seekbarbackground.xml源代碼如下:

seekbarbackground.xml源代碼 1 <?xml version="1.0" encoding="utf-8"?> 2 <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> 3 4 <!-- 滑竿背景 --> 5 <item 6 android:id="@android:id/background" 7 android:drawable="@drawable/seekbar_background" > 8 </item> 9 10 <!-- 第二進度條式樣 --> 11 <item 12 android:id="@android:id/secondaryProgress" 13 android:drawable="@drawable/seekbar_secondaryprogress" > 14 </item> 15 16 <!-- 進度條式樣 --> 17 <item 18 android:id="@android:id/progress" 19 android:drawable="@drawable/seekbar_progress" > 20 </item> 21 </layer-list>

2.3自定義SeekBar式樣的效果

  定義好了自己的滑塊和滑竿式樣之后,就可以在main.xml文件中加載自己定義的滑塊和滑竿式樣了。加載方法如下:

android:thumb="@drawable/thumb"

android:progressDrawable="@drawable/seekbarbackground"

  運行后就可以看到自己定義的Seekbar式樣了,如圖2和圖3所示。其中,圖2是滑塊未押下時的Seekbar式樣,圖3是滑塊押下并滑動時的Seekbar式樣。

2?自定義SeekBar效果圖1

3?自定義SeekBar效果圖2

?

?

?

轉載于:https://www.cnblogs.com/menlsh/archive/2013/01/11/2857213.html

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的Android学习笔记18:自定义Seekbar拖动条式样的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。