手機影音5--視頻播放器的基本功能(2)

来源:http://www.cnblogs.com/ganchuanpu/archive/2016/11/13/6059746.html
-Advertisement-
Play Games

1.設置電池狀態 1_監聽電量變化廣播 2_電量刷新方法 2.得到系統時間並且更新顯示 1_得到系統時間 2_在hanlder設置更新 3.傳遞播放列表 序列化 4.監聽播放完成和播放上一個視頻 1_設置監聽播放完成 2_點擊下一個按鈕 5.播放器控制面板控制面 1_手勢識別器 2_隱藏和顯示控制面 ...


1.設置電池狀態

1_監聽電量變化廣播

private void initData() {
	utils = new Utils();
	//註冊監聽電量變化廣播
	IntentFilter filter = new IntentFilter();
	filter.addAction(Intent.ACTION_BATTERY_CHANGED);//監聽電量變化
	receiver = new MyBatterReceiver();
	registerReceiver(receiver, filter);
}

private class MyBatterReceiver extends BroadcastReceiver{

	@Override
	public void onReceive(Context context, Intent intent) {
	  //電量值,設置預設為0
	  level = intent.getIntExtra("level", 0);
     } }

2_電量刷新方法

/**
 * 設置電量的狀態
*/
protected void setBatterStatus() {
	if(level <=0){
		iv_battery_status.setImageResource(R.drawable.ic_battery_0);
	}else if(level >0&& level <=10){
		iv_battery_status.setImageResource(R.drawable.ic_battery_10);
	}else if(level >10&&level <=20){
		iv_battery_status.setImageResource(R.drawable.ic_battery_20);
	}else if(level >20&&level <=40){
		iv_battery_status.setImageResource(R.drawable.ic_battery_40);
	}else if(level >40&&level <=60){
		iv_battery_status.setImageResource(R.drawable.ic_battery_60);
	}else if(level >60&&level <=80){
		iv_battery_status.setImageResource(R.drawable.ic_battery_80);
	}else if(level >80&&level <=100){
		iv_battery_status.setImageResource(R.drawable.ic_battery_100);
	}else{
		iv_battery_status.setImageResource(R.drawable.ic_battery_100);
	}
}

 

2.得到系統時間並且更新顯示

1_得到系統時間

public String getSystemTime(){
	SimpleDateFormat format = new SimpleDateFormat("HH:mm:ss");
	String systemTime = format.format(new Date());
	return systemTime;
}

2_在hanlder設置更新

//設置系統時間
tv_system_time.setText(utils.getSystemTime());

 

3.傳遞播放列表  

//傳遞列表數據-對象-序列化
Intent intent = new Intent(context,SystemVideoPlayer.class);
Bundle bundle = new Bundle();
bundle.putSerializable("videolist",mediaItems);
intent.putExtras(bundle);
intent.putExtra("position",position);
context.startActivity(intent);

序列化 

import java.io.Serializable;
/**
 * 作用:代表一個視頻和音頻
 */
public class MediaItem implements Serializable {
    ..............
}

 

4.監聽播放完成和播放上一個視頻  

1_設置監聽播放完成

//當一個視頻播放完成時候,將會回調這個方法
videoview.setOnCompletionListener(new OnCompletionListener() {
   
   @Override
   public void onCompletion(MediaPlayer mp) {
	  setPlayNext();
   }
});

 

/**
 * 播放下一個視頻
 */
private void setPlayNext() {
	if (mediaItems != null && mediaItems.size() > 0) {
		//播放下一個
		position++;
		if (position < mediaItems.size()) {
			ll_loading.setVisibility(View.VISIBLE);
			MediaItem mediaItem = mediaItems.get(position);
			tvName.setText(mediaItem.getName());
			videoview.setVideoPath(mediaItem.getData());
			//設置按鈕狀態
			setButtonState();
		}
	} else if (uri != null) {
		//設置按鈕狀態-上一個和下一個按鈕設置灰色並且不可以點擊
		setButtonState();
	}
}

private void setButtonState() {
	if (mediaItems != null && mediaItems.size() > 0) {
		if (mediaItems.size() == 1) {
			setEnable(false);
		} else if (mediaItems.size() == 2) {
			if (position == 0) {
				btnVideoPre.setBackgroundResource(R.drawable.btn_pre_gray);
				btnVideoPre.setEnabled(false);
				btnVideoNext.setBackgroundResource(R.drawable.btn_video_next_selector);
				btnVideoNext.setEnabled(true);
			} else if (position == mediaItems.size() - 1) {
				btnVideoNext.setBackgroundResource(R.drawable.btn_next_gray);
				btnVideoNext.setEnabled(false);
				btnVideoPre.setBackgroundResource(R.drawable.btn_video_pre_selector);
				btnVideoPre.setEnabled(true);
			}
		} else {
			if (position == 0) {
				btnVideoPre.setBackgroundResource(R.drawable.btn_pre_gray);
				btnVideoPre.setEnabled(false);
			} else if (position == mediaItems.size() - 1) {
				btnVideoNext.setBackgroundResource(R.drawable.btn_next_gray);
				btnVideoNext.setEnabled(false);
			} else {
				setEnable(true);
			}
		}
	} else if (uri != null) {
		//兩個按鈕設置灰色
		setEnable(false);
	}
}

private void setEnable(boolean isEnable) {
	if (isEnable) {
		btnVideoPre.setBackgroundResource(R.drawable.btn_video_pre_selector);
		btnVideoPre.setEnabled(true);
		btnVideoNext.setBackgroundResource(R.drawable.btn_video_next_selector);
		btnVideoNext.setEnabled(true);
	} else {
		//兩個按鈕設置灰色
		btnVideoPre.setBackgroundResource(R.drawable.btn_pre_gray);
		btnVideoPre.setEnabled(false);
		btnVideoNext.setBackgroundResource(R.drawable.btn_next_gray);
		btnVideoNext.setEnabled(false);
	}
} 

2_點擊下一個按鈕

btn_next.setOnClickListener(mClickListener);

  

5.播放器控制面板控制面

1_手勢識別器

//1.定義一個手勢識別器
private GestureDetector detector;
  
//2.實例化手勢識別器
detector = new GestureDetector(this, new GestureDetector.SimpleOnGestureListener(){

	@Override
	public void onLongPress(MotionEvent e) {
		super.onLongPress(e);
		setPlayOrPauseStatus();
		isPlaying = !isPlaying;
		//Toast.makeText(getApplicationContext(), "長按屏幕", 0).show();
	}

	@Override
	public boolean onDoubleTap(MotionEvent e) {
		Toast.makeText(getApplicationContext(), "雙擊屏幕", 0).show();
		return super.onDoubleTap(e);
	}

	@Override
	public boolean onSingleTapConfirmed(MotionEvent e) {
		//Toast.makeText(getApplicationContext(), "單擊屏幕", 0).show();
		if(isShowControlPlayer){
			hideControlPlayer();
		}else{
			showControlPlayer();
			sendDelayedHideControlPlayerMessage();
		}
		return super.onSingleTapConfirmed(e);
		}
	});
}

//3.把點擊事件傳入手勢識別器中
@Override
public boolean onTouchEvent(MotionEvent event) {
	detector.onTouchEvent(event);
	return super.onTouchEvent(event);
}

2_隱藏和顯示控制面板方法

/**
* 顯示控制面板
*/
protected void showControlPlayer() {
	fl_control_player.setVisibility(View.VISIBLE);
	isShowControlPlayer = true;
}

/**
* 隱藏控制面板
*/
protected void hideControlPlayer() {
	fl_control_player.setVisibility(View.GONE);
	isShowControlPlayer = false;
}

3_過段時間自動隱藏方法和移除消息

/**
* 發一個延遲600才隱藏控制面板的消息
*/
private void sendDelayedHideControlPlayerMessage() {
	handler.sendEmptyMessageDelayed(DELAYED_HIDECONTROL_MESSAGE, 6000);
}

/**
* 在消息隊列中移除隱藏控制面板的消息
*/
private void removeDelayedHideControlPlayerMessage() {
	handler.removeMessages(DELAYED_HIDECONTROL_MESSAGE);
}

4_拖動視頻的時候也要隱藏

video_seekBar.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {
       
   //手指停止滑動的時候回調
   @Override
   public void onStopTrackingTouch(SeekBar seekBar) {
	  sendDelayedHideControlPlayerMessage();
   }
   //手指剛開始滑動的時候回調
   @Override
   public void onStartTrackingTouch(SeekBar seekBar) {
	  removeDelayedHideControlPlayerMessage();
   }
   //手指滑動狀態發送變化的時候回調
   @Override
   public void onProgressChanged(SeekBar seekBar, int progress,
		boolean fromUser) {
	  if(fromUser){
             //seekBar.setProgress(progress);
	      videoview.seekTo(progress);
	  }  
   }
});

  

  

  

  

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 通常我們在處理耗時任務時候都會通過新建線程來處理,當任務處理完後通過Handler將結果發送回主線程。比如下麵示例: 那麼,我們能不能通過Handler從主線程發送消息給子線程呢?答案是肯定的,需要用到Looper.prepare()和Looper.loop()。如下麵的代碼: ...
  • 一、概要: 本文主要以Android的渲染機制、UI優化、多線程的處理、緩存處理、電量優化以及代碼規範等幾方面來簡述Android的性能優化 二、渲染機制的優化: 大多數用戶感知到的卡頓等性能問題的最主要根源都是因為渲染性能。 Android系統每隔16ms發出VSYNC信號,觸發對UI進行渲染, ...
  • AsyncTask,是android提供的輕量級的非同步類,可以直接繼承AsyncTask,在類中實現非同步操作,並提供介面反饋當前非同步執行的程度(可以通過介面實現UI進度更新),最後反饋執行的結果給UI主線程. 本文不分析AsyncTask的使用,它的使用教程網上一搜一大堆,本文主要分析它的內部邏輯和 ...
  • iOS開發中,發現UITextView沒有像UITextField中textFieldShouldReturn:這樣的方法,那麼要實現UITextView關閉鍵盤,就必須使用其他的方法,下麵是可以使用的幾種方法。 1.如果你程式是有導航條的,可以在導航條上面加多一個Done的按鈕,用來退出鍵盤,當然 ...
  • 綜上所述:這就是一個標準的的非同步操作,就像我們寄信一樣,我們只負責寫好信(Message)通過郵遞員(Handler)放入到郵箱(MessageQueue)中,由工作人員(Looper)去迴圈查詢,再由郵遞員處理(Handler)處理這些消息; //延遲兩秒跳轉 newHandler().postD ...
  • 1.自定義VideoView 1_自定義VideoView-增加設置視頻大小方法 2_得到屏幕高和寬方法 在播放器中 3_視頻預設和全屏 一播放起來,在準備好了中設置視頻播放預設 4_屏幕保持不鎖屏 5_點擊按鈕的時候實現切換播放模式 ...
  • retrofit 英文名字是改裝的意思,也就是說他是對網路請求的一種改裝,他不負責進行網路請求,他是對請求方式的一種封裝。真正進行網路請求的是okhttp。 以下所有內容在Android Studio已經導入retrofit為基礎。導入方式如下: 利用Retrofit進行簡單的GET請求 retro ...
  • 現在的cocoapods與之前比較。有很多不一樣的地方。自己試了一試,終於搞定。現在大概紀錄一下。 1.首先查看ruby是否是最新版的。 ruby是通過rvm安裝的所以需要先安裝rvm後查看ruby是否是最新的(通過查看ruby版本列表來判斷),在終端需要中輸入以下命令: (1)安裝RVM.RVM: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...