Android SeekBar控制視頻播放進度實現(xiàn)過程講解
效果圖
簡介
使用VideoView
控件播放視頻時,我們希望能夠調(diào)節(jié)播放的進度,一種方法是使用自帶的控制器MediaController
進行控制,另一種方法是自己實現(xiàn)一個SeekBar
控制。
使用MediaController控制器
在播放視頻時使用自帶的控制器MediaController
進行進度控制。
MediaController mediaController = new MediaController(this); mVideoView.setMediaController(mediaController);
使用SeekBar
在播放視頻時使用自己實現(xiàn)一個SeekBar
控制播放進度。
自定義SeekBar
背景drawable/bg_rounded.xml
,實現(xiàn)圓角半透明效果。
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 背景顏色 --> <solid android:color="#20ffffff"/> <!-- 圓角背景 --> <corners android:topLeftRadius="12dp" android:topRightRadius="12dp" android:bottomLeftRadius="12dp" android:bottomRightRadius="12dp"/> </shape>
界面布局文件layout/activity_video.xml
,界面中有一個用于視頻播放的VideoView
控件和控制播放進度的SeekBar
控件。 其中SeekBar
使用第一步定義好的背景效果,android:background=“@drawable/bg_rounded”
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#000" android:keepScreenOn="true" tools:context=".activitys.VideoActivity"> <VideoView android:id="@+id/video_view" android:layout_width="wrap_content" android:layout_height="match_parent" app:layout_constraintTop_toTopOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent"/> <SeekBar android:id="@+id/seekbar" android:layout_width="500dp" android:layout_height="25dp" android:background="@drawable/bg_rounded" android:layout_marginBottom="45dp" android:progressTint="#7FFFD4" android:thumbTint="#7FFFD4" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintBottom_toBottomOf="parent"/> </androidx.constraintlayout.widget.ConstraintLayout>
VideoActivity
文件。
public class VideoActivity extends AppCompatActivity implements EdgeSensorView.MapDemo { private static final String TAG = "VideoActivity"; private VideoView mVideoView; private SeekBar mSeekBar; private float curProgress; private float MAX_PROGRESS; private boolean isSeekBarProgress = false; private Handler handler = new Handler(); // 播放過程,自動更新seekbar的進度 private Runnable runnable = new Runnable() { public void run() { if (mVideoView.isPlaying()) { if (!isSeekBarProgress) { int current = mVideoView.getCurrentPosition(); mSeekBar.setProgress(current); } } handler.postDelayed(runnable, 100); } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_video); mSeekBar = findViewById(R.id.seekbar); mVideoView = findViewById(R.id.video_view); mVideoView.setVideoURI(Uri.parse("android.resource://" + getApplicationContext().getPackageName() + "/" + R.raw.vid_bigbuckbunny)); // MediaController mediaController = new MediaController(this); // mVideoView.setMediaController(mediaController); mVideoView.requestFocus(); mVideoView.setOnPreparedListener(new MediaPlayer.OnPreparedListener() { @Override public void onPrepared(MediaPlayer mp) { mp.setLooping(true); MAX_PROGRESS = mVideoView.getDuration(); mSeekBar.setMax((int) MAX_PROGRESS); Log.i(TAG, "onCreate: " + MAX_PROGRESS + "," + curProgress + "," + bitmaps.length); // 開始線程,更新進度條的刻度 handler.postDelayed(runnable, 0); mVideoView.start(); } }); mVideoView.setOnCompletionListener(new MediaPlayer.OnCompletionListener() { @Override public void onCompletion(MediaPlayer mp) { curProgress = 0; mSeekBar.setProgress(0); } }); mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { } @Override public void onStartTrackingTouch(SeekBar seekBar) { isSeekBarProgress = true; if (mVideoView.isPlaying()) { mVideoView.pause(); } } @Override public void onStopTrackingTouch(SeekBar seekBar) { int pro = seekBar.getProgress(); mVideoView.seekTo(pro); if (!mVideoView.isPlaying()) { mVideoView.seekTo(pro); mVideoView.start(); } isSeekBarProgress = false; } }); } @Override protected void onResume() { super.onResume(); } @Override protected void onPause() { super.onPause(); } @Override protected void onDestroy() { super.onDestroy(); handler.removeCallbacks(runnable); } private void updateSeekBarStatus(final boolean b) { runOnUiThread(new Runnable() { @Override public void run() { mSeekBar.setPressed(b); } }); } }
拓展:
- 增加控制播放/暫停的按鈕;
- 增加播放視頻當前播放時間及總時長的文本顯示;
到此這篇關于Android SeekBar控制視頻播放進度實現(xiàn)過程講解的文章就介紹到這了,更多相關Android SeekBar控制視頻進度內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
android使用ExpandableListView控件實現(xiàn)小說目錄效果的例子
這篇文章主要介紹了android使用ExpandableListView控件實現(xiàn)小說目錄效果的例子,還可以實現(xiàn)二級列表展示效果,需要的朋友可以參考下2014-07-07Android編程實現(xiàn)為ListView創(chuàng)建上下文菜單(ContextMenu)的方法
這篇文章主要介紹了Android編程實現(xiàn)為ListView創(chuàng)建上下文菜單(ContextMenu)的方法,簡單分析了上下文菜單的功能及ListView創(chuàng)建上下文菜單(ContextMenu)的具體步驟與相關操作技巧,需要的朋友可以參考下2017-02-02Android開發(fā)之DatePickerDialog、TimePickerDialog時間日期對話框用法示例
這篇文章主要介紹了Android開發(fā)之DatePickerDialog、TimePickerDialog時間日期對話框用法,結(jié)合實例形式分析了Android使用DatePickerDialog、TimePickerDialog顯示日期時間相關操作技巧,需要的朋友可以參考下2019-03-03Flutter Widget開發(fā)Shortcuts快捷鍵實例
這篇文章主要為大家介紹了Flutter Widget開發(fā)Shortcuts快捷鍵實例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12分享安裝Android Studio3.6的經(jīng)驗教訓
這篇文章主要介紹了Android Studio3.6的安裝錯誤問題及解決方法,非常值得大家參考,現(xiàn)把整個過程分享到腳本之家平臺,需要的朋友參考下吧2020-02-02