《移动应用开发》编码实现音频的播放及暂停功能_第1页
《移动应用开发》编码实现音频的播放及暂停功能_第2页
《移动应用开发》编码实现音频的播放及暂停功能_第3页
《移动应用开发》编码实现音频的播放及暂停功能_第4页
《移动应用开发》编码实现音频的播放及暂停功能_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

《移动应用开发》编码实现音频的播放及暂停功能编码实现音频的播放及暂停功能。(20分)实现音频的播放和暂停功能,就要弄清MediaPlayer,本代码初始化了MediaPlayer,并对MediaPlayer设置了按钮进行播放、暂停,具体细节如下:

MediaPlayer的初始化包括读取一个MP3格式的音乐文件并设置其为循环播放:publicvoidinitMediaPlayer(){try{//Stringfile_path="/storage/0123-4567/K.Will-Melt.mp3";Stringfile_path=Environment.getExternalStorageDirectory().getAbsolutePath()+"/K.Will-Melt.mp3";//Stringfile_path="/data/K.Will-Melt.mp3";mediaPlayer.setDataSource(file_path);mediaPlayer.prepare();mediaPlayer.setLooping(true);//设置循环播放}catch(Exceptione){e.printStackTrace();}}播放/暂停功能的实现放在Play/Pause按钮中,所以需要二选一判断MediaPlayer的状态来设置音乐的播放与暂停:publicvoidplayOrPause(){flag++;if(flag>=1000)flag=2;which="pause";if(mediaPlayer.isPlaying()){mediaPlayer.pause();animator.pause();}else{mediaPlayer.start();实现进度条功能。(30分)packagegress;importandroid.app.Activity;importandroid.os.Bundle;importandroid.os.Handler;importandroid.os.Message;importandroid.widget.ProgressBar;publicclassMainActivityextendsActivity{@OverrideprotectedvoidonCreate(BundlesavedInstanceState){super.onCreate(savedInstanceState);ProgressBarprogressBar=newProgressBar(this);//创建控件setContentView(progressBar);finalHandlerhandler=newHandler(){@OverridepublicvoidhandleMessage(Messagemsg){//线程内更新界面super.handleMessage(msg);progressBar.setProgress(msg.what);}};finalThreadthread=newThread(){//起一个线程@Overridepublicvoidrun(){super.run();intindex=0;intnumloop=1;while(index<100){//当小于100s时候,每秒向右滑动一次try{Thread.sleep(100);}catch(InterruptedExceptione){e.printStackTrace();}handler.sendEmptyMessage(index);index++;if(index==100){while(index>1){//当大于100s时候,每秒向左滑动一次try{Thread.sleep(100);}catch(InterruptedExceptione){e.printStackTrace();}handler.sendEmptyMessage(index);index--;}}}}};//无限循环,滑动thread.start();}}3.实现继承SQLiteOpenHelper类的dbHelper类。(50分)Android继承SQLiteOpenHelper类的DBHelper存取数据与图像如下:packagecom.test;importjava.io.ByteArrayOutputStream;importjava.io.IOException;importandroid.content.ContentValues;importandroid.content.Context;importandroid.database.Cursor;importandroid.database.sqlite.SQLiteDatabase;importandroid.database.sqlite.SQLiteOpenHelper;importandroid.graphics.Bitmap;importandroid.graphics.BitmapFactory;publicclassDBHelperextendsSQLiteOpenHelper{ privatestaticfinalStringDB_NAME="test.db"; privatestaticfinalintDB_VERSION=1; privatestaticfinalStringTABLE_NAME="info"; privatestaticfinalStringCREATE_INFO="createtableifnotexistsinfo(" +"idintegerprimarykeyautoincrement,namevarchar(20)," +"timevarchar(20),imgBLOB)"; privateSQLiteDatabasedb; DBHelper(Contextc){ // super(c,DB_NAME,null,DB_VERSION); } @Override publicvoidonCreate(SQLiteDatabasedb){ this.db=db; db.execSQL(CREATE_INFO); } publicvoidinsert(ContentValuesvalues,StringtableName){ db=getWritableDatabase(); db.insert(tableName,null,values); db.close(); } //ReturncursorwithallcolumnsbytableName publicCursorquery(StringtableName){ db=getWritableDatabase(); Cursorc=db.query(tableName,null,null,null,null,null,null); returnc; } //ReturncursorbySQLstring publicCursorrawQuery(Stringsql,String[]args){ db=getWritableDatabase(); Cursorc=db.rawQuery(sql,args); returnc; } //ExecuteasingleSQLstatement(asinsert,create,delete)insteadofaquery publicvoidexecSQL(Stringsql){ db=getWritableDatabase(); db.execSQL(sql); } //Deletebyid publicvoiddel(intid){ if(db==null) db=getWritableDatabase(); db.delete(TABLE_NAME,"id=?",newString[]{String.valueOf(id)}); } publicvoidclose(){ if(db!=null) db.close(); } @Override publicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion){ } //Bitmaptobyte[] publicbyte[]bmpToByteArray(Bitmapbmp){ //Defaultsizeis32bytes ByteArrayOutputStreambos=newByteArrayOutputStream(); try{ press(Bitmap.CompressFormat.JPEG,100,bos); bos.close(); }catch(IOExceptione){ e.printStackTrace(); } returnbos.toByteArray(); } //Cursortobitmap BitmapcursorToBmp(Cursorc,intcolumnIndex){ byte[]data=c.getBlob(columnIndex); try{ returnBitmapFactory.decodeByteArray(data,0,data.length); }catch(Exceptione){ returnnull; } }}DBhelper调用方法://定义helperprivatestaticDBHelperhelper;//创建helperhelper=newDBHelper(this);//插入数据与图像ContentValuesvalues=newContentValues();value

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论