『壹』 android實現視頻播放的幾種方式
Android提供了常見的視頻編碼,解碼機制,使用Android自帶的MediaPlayer,MediaController等類可以很方便的實現視頻播放的功能。支持的視頻格式有MP4和3GP等。這些多媒體數據可以來自於Android應用的資源文件,也可以來自於外部存儲器上的文件,甚至可以是來自於網路上的文件流。
1、MediaController+VideoView實現方式
這種方式是最簡單的實現方式。VideoView繼承了SurfaceView同時實現了MediaPlayerControl介面,MediaController則是安卓封裝的輔助控制器,帶有暫停,播放,停止,進度條等控制項。通過VideoView+MediaController可以很輕松的實現視頻播放、停止、快進、快退等功能。
布局文件如下:
使用此實現方式的步驟:
1.載入指定的視頻文件
2.建立VideoView和MediaController之間的關聯,這樣就不需要自己去控制視頻的播放、暫停等。讓MediaController控制即可。
3.VideoView獲取焦點。
2、MediaPlayer+SurfaceView+自定義控制器
雖然VideoView的實現方式很簡單,但是由於是自帶的封裝好的類,所以無論是播放器的大小、位置以及控制都不受我們控制。
這種實現方式步驟如下:
1.創建MediaPlayer對象,並讓它載入指定的視頻文件。可以是應用的資源文件、本地文件路徑、或者URL。
2.在界面布局文件中定義SurfaceView組件,並為SurfaceView的SurfaceHolder添加Callback監聽器。
3.調用MediaPlayer對象的setDisplay(SurfaceHolder sh)將所播放的視頻圖像輸出到指定的SurfaceView組件。
4.調用MediaPlayer對象的prepareAsync()或prepare()方法裝載流媒體文件
5.調用MediaPlayer對象的start()、stop()和pause()方法來控制視頻的播放。
在實現第二步之前需要先給surfaceHolder設置一個callback,callback的3個回調函數如下:
3、MediaPlayer+SurfaceView+MediaController
第二種實現方式使用的是自定義控制項,MediaPlayer+SurfaceView也可以使用系統自帶的MediaController控制器。
使用這個方式實現,布局文件只需一個SurfaceView即可,其他的控制項都交給MediaController控制器,布局文件如下:
實際過程中推薦大家使用B站的播放器ijkplayer非常好用!
『貳』 android activity 按back鍵 執行什麼過程
進程只是APP的一個容器而已,這個容器空了不代表這個容器沒了,但是你把容器銷毀了,容器里的東西一樣會被銷毀,按back鍵就是後退棧做pop操作的過程(回調onbackpressed,默認實現是調用finish(),finish()方法又會去調用OnDestroy),棧頂Activity就被銷毀,所以會回調Activity的OnDestroy方法;而按home鍵是把整個任務棧掛起到後台,回到啟動器首頁,Activity並沒有銷毀。所以不會回調Activity的OnDestroy。
至於長按home鍵啟動任務管理器結束應用,進程還是存在,這個因手機而異。有些手機是銷毀這個應用(Application類的實例),進程這個容器還在,只是空了(空進程),發現進程不見了多數是因為系統回收空進程;有些手機是直接結束進程。
『叄』 Android 中如何監聽到Back鍵和Home鍵
繼承Activity
重寫OnKeyDown()
在裡面列印下鍵 值。
似乎在不同手機上。它對應的鍵值是不相同的。
得到Back和Home的鍵值
然後再匹配鍵值。寫自己要做的事就可以了
Back的可以這樣寫:
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
if (keyCode == KeyEvent.KEYCODE_BACK) {
}
return super.onKeyDown(keyCode, event);
}
『肆』 unity3d程序android下響應back按鍵
如果你的activity啟動模式方面是默認的話,新的activity調用finish方法之後,應該會自動回到上一個activity的啊.
『伍』 Android監聽Home鍵和Back鍵的區別介紹
一:Android 中Home鍵監聽和Back鍵監聽的區別:
(1).在Android中,當按下Home鍵的時候,默認情況下Stop前台的Activity,即Activity設置成停止狀態【onStop()】,而不是銷毀狀態【onDestory()】。如果再次啟動該Activity,不是調用onCreate()方法,而是調用onSavedInstanceState方法。則是從onRestart()開始-onStart()-onResume()。
(2).當按下back鍵則不同,back鍵默認finish前台的activity,即activity的狀態為onDestory為止,再次啟動該activity則從onCreate開始,不會調用onSavedInstanceState方法。
總而言之:按下Home鍵會返回桌面,而back則會返回前一個activity。
在這里Back鍵的實現方法就不贅述了,主要講解一下Home鍵的實現方式吧。以下是我找的參考資料自己思考的。請大家給出建議。
Home鍵監聽的實現方法:
(1).在onResum裡面注冊廣播,OnPause裡面注銷廣播。
(2).在廣播中攔截Intent.ACTION_CLOSE_SYSTEM_DIALOGS 這個Action ,通過獲取Reason欄位 來判斷長按 還是單擊Home鍵。
代碼如下:
(1).Home鍵監聽封裝類:
package com.scd.homewatcher.util;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.util.Log;
/**
* Home鍵監聽封裝
*
* @author way
*
*/
public class HomeWatcher {
// 回調介面
public interface OnHomePressedListener {
public void onHomePressed();
public void onHomeLongPressed();
}
private static final String TAG = "HomeWatcher";
/** 上下文 */
private Context mContext;
/** 過濾器 */
private IntentFilter mFilter;
/** 介面 */
private OnHomePressedListener mListener;
/** 廣播接收者 */
private InnerRecevier mRecevier;
public HomeWatcher(Context context) {
mContext = context;
mRecevier = new InnerRecevier();
mFilter = new IntentFilter(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);
}
/**
* 設置監聽
*
* @param listener
*/
public void setOnHomePressedListener(OnHomePressedListener listener) {
mListener = listener;
}
/**
* 開始監聽,注冊廣播
*/
public void startWatch() {
if (mRecevier != null) {
mContext.registerReceiver(mRecevier, mFilter);
}
}
/**
* 停止監聽,注銷廣播
*/
public void stopWatch() {
if (mRecevier != null) {
mContext.unregisterReceiver(mRecevier);
}
}
/**
* 廣播接收者
*/
private class InnerRecevier extends BroadcastReceiver {
final String SYSTEM_DIALOG_REASON_KEY = "reason";
final String SYSTEM_DIALOG_REASON_GLOBAL_ACTIONS = "globalactions";
final String SYSTEM_DIALOG_REASON_RECENT_APPS = "recentapps";
final String SYSTEM_DIALOG_REASON_HOME_KEY = "homekey";
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (action.equals(Intent.ACTION_CLOSE_SYSTEM_DIALOGS)) {
String reason = intent.getStringExtra(SYSTEM_DIALOG_REASON_KEY);
if (reason != null) {
Log.i(TAG, "action:" + action + ",reason:" + reason);
if (mListener != null) {
if (reason.equals(SYSTEM_DIALOG_REASON_HOME_KEY)) {
// 短按home鍵
mListener.onHomePressed();
} else if (reason
.equals(SYSTEM_DIALOG_REASON_RECENT_APPS)) {
// 長按home鍵
mListener.onHomeLongPressed();
}
}
}
}
}
}
}
(2).MainActivity類:
package com.scd.homewatcher;
import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.widget.Toast;
import com.scd.homewatcher.util.HomeWatcher;
import com.scd.homewatcher.util.HomeWatcher.OnHomePressedListener;
public class MainActivity extends Activity implements OnHomePressedListener {
private HomeWatcher mHomeWatcher;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
protected void onResume() {
mHomeWatcher = new HomeWatcher(this);
mHomeWatcher.setOnHomePressedListener(this);
// 注冊廣播
mHomeWatcher.startWatch();
super.onResume();
}
@Override
protected void onPause() {
mHomeWatcher.setOnHomePressedListener(null);
// 注銷廣播
mHomeWatcher.stopWatch();
super.onPause();
}
@Override
public void onHomePressed() {
// TODO
Toast.makeText(this, "短按Home鍵,實現自己的邏輯", Toast.LENGTH_SHORT).show();
}
@Override
public void onHomeLongPressed() {
// TODO
Toast.makeText(this, "長按Home鍵,實現自己的邏輯", Toast.LENGTH_SHORT).show();
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_BACK)) {
System.out.println("按下了back鍵 onKeyDown()");
return false;
} else {
return super.onKeyDown(keyCode, event);
}
}
@Override
public void onBackPressed() {
// super.onBackPressed()會自動調用finish()方法,關閉
super.onBackPressed();
}
}
『陸』 android 怎麼調用鍵盤的back鍵
android 監聽鍵盤的back鍵的話,activity裡面提供了方法,onbackpress這樣類似的方法,復寫就可以了。