多媒体(视频播放器)

视频播放器关键的一个类是SurfaceView,首先实例化MediaPlayer,设置类型,然后设置音源,

再得到视频文件的路径,接下来调用prepare方法,最后就是将媒体播放器捕捉的画面展示到SurfaceView

另一种方法就是首先在Activity中的到VideoView.给VideoView设置播放来源,同样地,获得视频文件的路径

实例化MediaController,让它们互相设置。拍照实现的步骤就是:第一步,界面使用SurfaceView控件,显示照相机的画面

第二步:SurfaceView接受摄像头界面变化的信息,surfaceView.getHolder().addCallback(),第三步,重写3个方法,预览界面被创建时,调用一般在这里打开照相机和设置照相机的一些参数。1.打开照相机和设置照相机的一些参数

//打开摄像头

camer=Camera.open();

//给摄像头设置参数

Parameters parameters=camera.getParameters();

// 设置照片的输出格式
parameters.setPictureFormat(PixelFormat.JPEG);
// 设置照片的质量
parameters.set("jpeg-quality", 85);
// 给照相机设置参数
camera.setParameters(parameters);
//将摄像头的画面显示到SurfaceView控件上
camera.setPreviewDisplay(sv_main_camera.getHolder());

// 开始预览
camera.startPreview();
surfaceChanged----->当预览界面的格式和大小发生改变时,触发

<4>保存
camera.takePicture





将照片保存到内存卡(压缩)



package com.demo.pr5; import java.io.File; import java.util.Vector; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.KeyEvent; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; import android.widget.AdapterView.OnItemClickListener; public class MyFileActivity extends Activity { // 支持的媒体格式 private final String[]FILE_MapTable = { ".3gp",".mov",".avi", ".rmvb", ".wmv", ".mp3", ".mp4" }; private Vector<String> items = null; // items:存放显示的名称 private Vector<String> paths = null; // paths:存放文件路径 private Vector<String> sizes = null; // sizes:文件大小 private String rootPath = "/mnt/sdcard"; //起始文件夹 private EditText pathEditText; // 路径 private Button queryButton; //查询按钮 private ListView fileListView;//文件列表 @Override protected void onCreate(Bundle icicle) { super.onCreate(icicle); this.setTitle("多媒体文件浏览"); setContentView(R.layout.myfile); //从myfile.xml找到对应的元素 pathEditText = (EditText) findViewById(R.id.path_edit); queryButton = (Button) findViewById(R.id.qry_button); fileListView= (ListView) findViewById(R.id.file_listview); //查询按钮事件 queryButton.setOnClickListener( new Button.OnClickListener() { public void onClick(View arg0) { File file = new File(pathEditText.getText().toString()); if (file.exists()) { if (file.isFile()) { //如果是媒体文件直接打开播放 openFile(pathEditText.getText().toString()); } else { //如果是目录打开目录下文件 getFileDir(pathEditText.getText().toString()); } } else { Toast.makeText(MyFileActivity.this, "找不到该位置,请确定位置是否正确!", Toast.LENGTH_SHORT).show(); } } }); //设置ListItem被点击时要做的动作 fileListView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) { fileOrDir(paths.get(position)); } }); //打开默认文件夹 getFileDir(rootPath); } /** * 重写返回键功能:返回上一级文件夹 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // 是否触发按键为back键 if (keyCode == KeyEvent.KEYCODE_BACK) { pathEditText = (EditText) findViewById(R.id.path_edit); File file = new File(pathEditText.getText().toString()); if (rootPath.equals(pathEditText.getText().toString().trim())) { return super.onKeyDown(keyCode, event); } else { getFileDir(file.getParent()); return true; } //如果不是back键正常响应 } else { return super.onKeyDown(keyCode, event); } } /** * 处理文件或者目录的方法 */ private void fileOrDir(String path) { File file = new File(path); if (file.isDirectory()) { getFileDir(file.getPath()); } else { openFile(path); } } /** * 取得文件结构的方法 */ private void getFileDir(String filePath) { /* 设置目前所在路径 */ pathEditText.setText(filePath); items = new Vector<String>(); paths = new Vector<String>(); sizes = new Vector<String>(); File f = new File(filePath); File[] files = f.listFiles(); if (files != null) { /* 将所有文件添加ArrayList中 */ for (int i = 0; i < files.length; i++) { if (files[i].isDirectory()) { items.add(files[i].getName()); paths.add(files[i].getPath()); sizes.add(""); } } for (int i = 0; i < files.length; i++) { if (files[i].isFile()) { String fileName = files[i].getName(); int index = fileName.lastIndexOf("."); if (index > 0) { String endName = fileName.substring(index, fileName.length()).toLowerCase(); String type = null; for (int x = 0; x < FILE_MapTable.length; x++) { // 支持的格式,才会在文件浏览器中显示 if (endName.equals(FILE_MapTable[x])) { type = FILE_MapTable[x]; break; } } if (type != null) { items.add(files[i].getName()); paths.add(files[i].getPath()); sizes.add(files[i].length()+""); } } } } } /* 使用自定义的FileListAdapter来将数据传入ListView */ fileListView.setAdapter(new FileListAdapter(this, items)); } /** * 打开媒体文件 * @param f */ private void openFile(String path) { //打开媒体播放器 Intent intent = new Intent(MyFileActivity.this, MediaPlayerActivity.class); intent.putExtra("path",path); startActivity(intent); finish(); } /** *ListView列表适配器 */ class FileListAdapter extends BaseAdapter { private Vector<String> items = null; // items:存放显示的名称 private MyFileActivity myFile; public FileListAdapter(MyFileActivity myFile, Vector<String> items) { this.items=items; this.myFile=myFile; } @Override public int getCount() { // TODO Auto-generated method stub return items.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub return items.elementAt(position); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return items.size(); } @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub if(convertView==null) { //加载列表项布局file_item.xml convertView = myFile.getLayoutInflater() .inflate(R.layout.file_item, null); } //文件名称 TextView name = (TextView) convertView.findViewById(R.id.name); //媒体文件类型 ImageView music=(ImageView)convertView.findViewById(R.id.music); //文件夹类型 ImageView folder=(ImageView)convertView.findViewById(R.id.folder); name.setText(items.elementAt(position)); if(sizes.elementAt(position).equals("")) { //隐藏媒体图标,显示文件夹图标 music.setVisibility(View.GONE); folder.setVisibility(View.VISIBLE); }else { //隐藏文件夹图标,显示媒体图标 folder.setVisibility(View.GONE); music.setVisibility(View.VISIBLE); } return convertView; } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值