Android 自定義SeekBar動態(tài)改變硬件音量大小實現(xiàn)和音量鍵的同步(推薦)
1,上圖:
2,代碼:
MainActivity.Java
package com.hero.zhaoq.seekbarchangeddemo; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.database.ContentObserver; import android.media.AudioManager; import android.os.Handler; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.widget.SeekBar; /** * Android實現(xiàn) SeekBar更新音量 并實現(xiàn) 和硬件同步 */ public class MainActivity extends AppCompatActivity { private SeekBar seekbar_video; private ContentObserver mVoiceObserver; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); AudioManager audioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE);//獲取媒體系統(tǒng)服務(wù) seekbar_video= (SeekBar) findViewById(R.id.seekbar_video);//注冊ID seekbar_video.setMax(15);//設(shè)置最大音量 seekbar_video.setProgress(audioManager.getStreamVolume(AudioManager.STREAM_MUSIC));// 當(dāng)前的媒體音量 myRegisterReceiver();//注冊同步更新的廣播 Log.i("lyj_ring", "mVoiceSeekBar max voluem = "+audioManager.getStreamMaxVolume(AudioManager.STREAM_SYSTEM)); seekbar_video.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { public void onStopTrackingTouch(SeekBar arg0) { } public void onStartTrackingTouch(SeekBar arg0) { } public void onProgressChanged(SeekBar arg0, int arg1, boolean arg2) { AudioManager audioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE); Log.v("lyj_ring", "mVoiceSeekBar max progress = "+arg1); //系統(tǒng)音量和媒體音量同時更新 audioManager.setStreamVolume(AudioManager.STREAM_SYSTEM, arg1, 0); audioManager.setStreamVolume(3, arg1, 0);// 3 代表 AudioManager.STREAM_MUSIC } }); mVoiceObserver = new ContentObserver(new Handler()) { @Override public void onChange(boolean selfChange) { super.onChange(selfChange); AudioManager audioManager = (AudioManager) getSystemService(Context.AUDIO_SERVICE); seekbar_video.setProgress(audioManager.getStreamVolume(AudioManager.STREAM_SYSTEM)); //或者你也可以用媒體音量來監(jiān)聽改變,效果都是一樣的。 //mVoiceSeekBar.setProgress(audioManager.getStreamVolume(AudioManager.STREAM_MUSIC)); } }; } private void myRegisterReceiver(){ MyVolumeReceiver mVolumeReceiver = new MyVolumeReceiver() ; IntentFilter filter = new IntentFilter() ; filter.addAction("android.media.VOLUME_CHANGED_ACTION") ; registerReceiver(mVolumeReceiver, filter) ; } /** * 處理音量變化時的界面顯示 * @author long */ private class MyVolumeReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //如果音量發(fā)生變化則更改seekbar的位置 if(intent.getAction().equals("android.media.VOLUME_CHANGED_ACTION")){ AudioManager mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE); int currVolume = mAudioManager.getStreamVolume(AudioManager.STREAM_MUSIC) ;// 當(dāng)前的媒體音量 seekbar_video.setProgress(currVolume) ; } } } }
main_activity.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/ringtone_seekbar_parent" android:layout_width="match_parent" android:layout_height="160px" android:layout_marginTop="0dip" android:layout_weight="1" android:gravity="center_vertical" android:orientation="horizontal" > <SeekBar android:id="@+id/seekbar_video" android:layout_width="match_parent" android:layout_height="25dp" android:max="0" android:progress="0" android:progressDrawable="@drawable/seekbar_progress_layer_list" android:thumb="@mipmap/play_seekbar_icon" android:layout_weight="18"/> </LinearLayout>
seekbar_progress_layer_list.xml
<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <!--未選中 狀態(tài)--> <item android:id="@android:id/background" android:drawable="@mipmap/volumn_bg" /> <!--<!–選中狀態(tài)–>--> <item android:id="@android:id/progress"> <scale android:drawable="@mipmap/volumn_primary" android:scaleWidth="100%" /> </item> </layer-list>
不是你不會只是你不知道而已……..
整個代碼實現(xiàn)很簡單。 筆者不在贅述。
注: 打開demo,打開歌曲?;瑒觭eekbar即可改音量大小。
maybe你更需要這個:
源碼:
https://github.com/229457269/SeekBarChangedVoiceDemo
參考:Android seekbar(自定義)控制音量同步更新
以上所述是小編給大家介紹的Android 自定義SeekBar動態(tài)改變硬件音量大小實現(xiàn)和音量鍵的同步(推薦),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android開發(fā)中使用Intent打開第三方應(yīng)用及驗證可用性的方法詳解
這篇文章主要介紹了Android開發(fā)中使用Intent打開第三方應(yīng)用及驗證可用性的方法,結(jié)合實例形式分析了Android使用Intent打開第三方應(yīng)用的三種常用方式及使用注意事項,需要的朋友可以參考下2017-11-11自定義Adapter并通過布局泵LayoutInflater抓取layout模板編輯每一個item實現(xiàn)思路
自定義Adapter并通過布局泵LayoutInflater抓取layout模板編輯每一個item,下面我們開始學(xué)習(xí)這一篇的內(nèi)容,感興趣的朋友可以了解下哈2013-06-06Android使用VideoView播放本地視頻和網(wǎng)絡(luò)視頻的方法
本文將講解如何使用Android視頻播放器VideoView來播放本地視頻和網(wǎng)絡(luò)視頻,實現(xiàn)起來還是比較簡單的,有需要的可以參考借鑒。2016-08-08android service實現(xiàn)循環(huán)定時提醒功能
這篇文章主要為大家詳細(xì)介紹了android service實現(xiàn)循環(huán)定時提醒功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01Kotlin基礎(chǔ)學(xué)習(xí)之位運(yùn)算
一提起位運(yùn)算,人們往往想到它的高效性,無論是嵌入式編程還是優(yōu)化系統(tǒng)的核心代碼,適當(dāng)?shù)倪\(yùn)用位運(yùn)算總是一種迷人的手段,下面這篇文章主要給大家介紹了關(guān)于Kotlin基礎(chǔ)學(xué)習(xí)之位運(yùn)算的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2017-11-11Android入門之ListView應(yīng)用解析(一)
這篇文章主要介紹了Android入門之ListView應(yīng)用,簡單說明了ListView的實現(xiàn),需要的朋友可以參考下2014-08-08Android Flutter實現(xiàn)圖片滑動切換效果
Flutter 為了簡化開發(fā),提供了不少轉(zhuǎn)換動畫組件,這類組件通常命名為 xxTransition。本篇要介紹的就是 SlideTransition,并用它實現(xiàn)圖片滑動切換效果,感興趣的可以了解一下2022-04-04Android計時器的三種實現(xiàn)方式(Chronometer、Timer、handler)
這篇文章主要介紹了Android計時器的三種實現(xiàn)方式,Chronometer、Timer、handler計時器的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11