19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/* 29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2008 The Android Open Source Project 39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License. 69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at 79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * 109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and 149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License. 159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage com.android.mediaframeworktest.functional; 189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project//import android.content.Resources; 229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.android.mediaframeworktest.MediaFrameworkTest; 239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.android.mediaframeworktest.MediaNames; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.res.AssetFileDescriptor; 269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.Bitmap; 279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.graphics.BitmapFactory; 289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.media.MediaMetadataRetriever; 299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.media.MediaPlayer; 309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.media.MediaRecorder; 31b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Projectimport android.os.Looper; 329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.SystemClock; 339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.util.Log; 349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 35be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lauimport java.io.File; 36be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lauimport java.io.FileWriter; 379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.IOException; 389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.InputStream; 39be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lauimport java.io.OutputStream; 40be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lauimport java.io.Writer; 41be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lauimport java.io.FileOutputStream; 4255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wangimport java.util.Random; 439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Junit / Instrumentation test case for the media player api 459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class CodecTest { 489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private static String TAG = "MediaPlayerApiTest"; 49b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static MediaPlayer mMediaPlayer; 50b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private MediaPlayer.OnPreparedListener mOnPreparedListener; 51b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 52c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static int WAIT_FOR_COMMAND_TO_COMPLETE = 60000; //1 min max. 53b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static boolean mInitialized = false; 54c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static boolean mPrepareReset = false; 55b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static Looper mLooper = null; 56b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static final Object lock = new Object(); 57b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static final Object prepareDone = new Object(); 58c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static final Object videoSizeChanged = new Object(); 5955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang private static final Object onCompletion = new Object(); 60b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static boolean onPrepareSuccess = false; 6155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang private static boolean onCompleteSuccess = false; 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static String printCpuInfo(){ 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cm = "dumpsys cpuinfo"; 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo =null; 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int ch; 679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Process p = Runtime.getRuntime().exec(cm); 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project InputStream in = p.getInputStream(); 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuffer sb = new StringBuffer(512); 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while ( ( ch = in.read() ) != -1 ){ 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append((char) ch); 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project cpuinfo = sb.toString(); 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (IOException e){ 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return cpuinfo; 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int getDuration(String filePath) { 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getDuration - " + filePath); 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 88be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau }catch (Exception e){ 89be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau Log.v(TAG, e.toString()); 90be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Duration " + duration); 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "release"); 959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return duration; 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getCurrentPosition(String filePath){ 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "GetCurrentPosition - " + filePath); 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "mp currentPositon = " + currentPosition + " play duration = " + (t2-t1)); 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be within 10% of the sleep time 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //For the very short mp3, it should return the length instead of 10 seconds 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.SHORTMP3)){ 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 1000 ) 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition < ((t2-t1) *1.2)) && (currentPosition > 0)) 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekTo(String filePath){ 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekTo " + filePath); 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(MediaNames.SEEK_TIME); 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.WAIT_TIME); 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.getMessage()); 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "CurrentPosition = " + currentPosition); 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be at least greater than the 80% of seek time 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition > MediaNames.SEEK_TIME *0.8)) 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean setLooping(String filePath){ 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1 =0; 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v (TAG, "SetLooping - " + filePath); 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "setLooping duration " + duration); 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 5000); 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(20000); 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause"); 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Bug# 1106852 - IllegalStateException will be thrown if pause is called 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //in here 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //mp.pause(); 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "looping position " + currentPosition + "duration = " + (t2-t1)); 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The current position should be within 20% of the sleep time 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //and should be greater than zero. 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition < ((t2-t1-5000)*1.2)) && currentPosition > 0) 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean pause(String filePath) throws Exception { 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause - " + filePath); 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean misPlaying = true; 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean pauseResult = false; 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2=0; 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project misPlaying = mp.isPlaying(); 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int curPosition = mp.getCurrentPosition(); 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, filePath + " pause currentPositon " + curPosition); 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "isPlaying "+ misPlaying + " wait time " + (t2 - t1) ); 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo = printCpuInfo(); 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, cpuinfo); 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((curPosition>0) && (curPosition < ((t2-t1) * 1.3)) && (misPlaying == false)) 2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project pauseResult = true; 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pauseResult; 2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void prepareStopRelease(String filePath) throws Exception { 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "prepareStopRelease" + filePath); 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void preparePauseRelease(String filePath) throws Exception { 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "preparePauseRelease" + filePath); 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 241c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 242c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau static MediaPlayer.OnVideoSizeChangedListener mOnVideoSizeChangedListener = 243c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau new MediaPlayer.OnVideoSizeChangedListener() { 244c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public void onVideoSizeChanged(MediaPlayer mp, int width, int height) { 245c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 246c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "sizechanged notification received ..."); 247c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.notify(); 248c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 249c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 250c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau }; 2519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 252c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoHeight(String filePath) throws Exception { 2549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoHeight - " + filePath); 255c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau int videoHeight = 0; 256c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 257c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 258c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 259c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 260c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 261c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 262c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 263c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 264c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 265c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 266c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 267c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 268c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 269c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 270c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 271c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 272c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 273c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 274c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 275c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 276c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 277c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 278c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoHeight = mMediaPlayer.getVideoHeight(); 279c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 280c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 281c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 282c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 283c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 2849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoHeight; 2859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 287c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoWidth(String filePath) throws Exception { 2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoWidth - " + filePath); 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int videoWidth = 0; 291c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 292c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 293c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 294c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 295c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 296c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 297c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 298c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 299c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 300c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 301c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 302c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 303c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 304c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 305c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 306c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 307c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 308c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 309c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 310c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 311c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 312c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 313c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 314c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoWidth = mMediaPlayer.getVideoWidth(); 315c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 316c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 317c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 318c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoWidth; 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This also test the streaming video which may take a long 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //time to start the playback. 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean videoSeekTo(String filePath) throws Exception { 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoSeekTo - " + filePath); 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean videoResult = false; 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.VIDEO_SHORT_3GP)){ 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(0); 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"short position " + currentPosition); 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > 100 ) 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video duration " + duration); 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 20000 ); 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration/2); 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video currentPosition " + currentPosition); 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > (duration /2 )*0.9) 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekToEnd(String filePath){ 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd - " + filePath); 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 3000); 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(6000); 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 0.9 * duration || isPlaying) 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean shortMediaStop(String filePath){ 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean playToEnd(String filePath){ 4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 200000; 4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int updateDuration = 0; 4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //duration = mp.getDuration(); 4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(50000); 4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //updateDuration = mp.getDuration(); 4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "duration = " + duration); 4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "Update duration = " + updateDuration); 4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seektoBeforeStart(String filePath){ 4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seektoBeforeStart - " + filePath); 4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 10000); 4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition=mp.getCurrentPosition(); 4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < duration/2) 4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mediaRecorderRecord(String filePath){ 4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "SoundRecording - " + filePath); 4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaRecorder mRecorder = new MediaRecorder(); 4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); 4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); 4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); 4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFile(filePath); 4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.prepare(); 4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.start(); 4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(500); 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.stop(); 4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "sound recorded"); 4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.release(); 4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Verify the recorded file 4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 5029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"Duration " + duration); 5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Check the record media file length is greate than zero 5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > 0) 5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Test for mediaMeta Data Thumbnail 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getThumbnail(String filePath, String goldenPath){ 5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getThumbnail - " + filePath); 5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenHeight = 0; 5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenWidth = 0; 5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputWidth = 0; 5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputHeight = 0; 5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project BitmapFactory mBitmapFactory = new BitmapFactory(); 5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaMetadataRetriever mMediaMetadataRetriever = new MediaMetadataRetriever(); 5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mMediaMetadataRetriever.setDataSource(filePath); 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } catch(Exception e) { 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project e.printStackTrace(); 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Bitmap outThumbnail = mMediaMetadataRetriever.captureFrame(); 5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Verify the thumbnail 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Bitmap goldenBitmap = mBitmapFactory.decodeFile(goldenPath); 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputWidth = outThumbnail.getWidth(); 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputHeight = outThumbnail.getHeight(); 5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenHeight = goldenBitmap.getHeight(); 5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenWidth = goldenBitmap.getWidth(); 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //check the image dimension 5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((outputWidth != goldenWidth) || (outputHeight != goldenHeight)) 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 548be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau // Check half line of pixel 549be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau int x = goldenHeight / 2; 550be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau for (int j = 1; j < goldenWidth / 2; j++) { 551be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau if (goldenBitmap.getPixel(x, j) != outThumbnail.getPixel(x, j)) { 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pixel = " + goldenBitmap.getPixel(x, j)); 553be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau return false; 5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 555be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 556be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau }catch (Exception e){ 557be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau Log.v(TAG, e.toString()); 558be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau return false; 559be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Load midi file from resources 5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean resourcesPlayback(AssetFileDescriptor afd, int expectedDuration){ 5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(), afd.getLength()); 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > expectedDuration) 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean prepareAsyncReset(String filePath){ 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //preparesAsync 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepareAsync(); 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean isLooping(String filePath) { 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after ctor"); 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mp.isLooping()) { 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned false after setLooping(true)"); 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(false); 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after setLooping(false)"); 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean isLoopingAfterReset(String filePath) { 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after reset()"); 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 656b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 657b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 658b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * Initializes the message looper so that the mediaPlayer object can 659b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * receive the callback messages. 660b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 661b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void initializeMessageLooper() { 662b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start looper"); 663b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project new Thread() { 664b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project @Override 665b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void run() { 666b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // Set up a looper to be used by camera. 667b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.prepare(); 668b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start loopRun"); 669b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // Save the looper so that we can terminate this thread 670b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // after we are done with it. 671b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mLooper = Looper.myLooper(); 672b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer = new MediaPlayer(); 673b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 674b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mInitialized = true; 675b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.notify(); 676b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 677b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.loop(); // Blocks forever until Looper.quit() is called. 678b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "initializeMessageLooper: quit."); 679b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 680b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }.start(); 681b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 682b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 683b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 684b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * Terminates the message looper thread. 685b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 686b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void terminateMessageLooper() { 687b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mLooper.quit(); 688b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.release(); 689b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 690b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 691b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project static MediaPlayer.OnPreparedListener mPreparedListener = new MediaPlayer.OnPreparedListener() { 692b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void onPrepared(MediaPlayer mp) { 693b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 694c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if(mPrepareReset){ 695c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "call Reset"); 696c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.reset(); 697c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 698b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "notify the prepare callback"); 699b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.notify(); 700b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project onPrepareSuccess = true; 701b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 702b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 703b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }; 704b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 705c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public static boolean prepareAsyncCallback(String filePath, boolean reset) throws Exception { 706c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Added the PrepareReset flag which allow us to switch to different 707c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //test case. 708c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if (reset){ 709c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mPrepareReset = true; 710c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 711b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 712b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 713c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 714b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 715b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 716b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch(Exception e) { 717b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "looper was interrupted."); 718b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return false; 719b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 720b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 721b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try{ 722b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setOnPreparedListener(mPreparedListener); 723b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDataSource(filePath); 724b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 725b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.prepareAsync(); 726b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 727b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 728b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 729b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch (Exception e) { 730b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "wait was interrupted."); 731b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 732c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 733b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project terminateMessageLooper(); 734b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }catch (Exception e){ 735b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG,e.getMessage()); 736b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 737b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return onPrepareSuccess; 738b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 7399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 74055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang static MediaPlayer.OnCompletionListener mCompletionListener = new MediaPlayer.OnCompletionListener() { 74155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public void onCompletion(MediaPlayer mp) { 74255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (onCompletion) { 74355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "notify the completion callback"); 74455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompletion.notify(); 74555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompleteSuccess = true; 74655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 74755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 74855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }; 74955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang 75055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // For each media file, forward twice and backward once, then play to the end 75155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public static boolean playMediaSamples(String filePath) throws Exception { 75255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int duration = 0; 75355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int curPosition = 0; 75455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int nextPosition = 0; 75555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int waittime = 0; 75655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Random r = new Random(); 75755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang initializeMessageLooper(); 75855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (lock) { 75955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 76055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 76155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } catch(Exception e) { 76255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "looper was interrupted."); 76355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 76455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 76555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 76655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 76755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setOnCompletionListener(mCompletionListener); 76855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: sample file name " + filePath); 76955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDataSource(filePath); 77055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 77155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.prepare(); 77255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang duration = mMediaPlayer.getDuration(); 77355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: duration = " + duration); 77455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // start to play 77555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.start(); 77655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // randomly play for time within (0, duration/3) 77755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Thread.sleep(r.nextInt(duration/3)); 77855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.pause(); 77955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after pause: " 78055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 78155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // seek to position (0, 2/3*duration) 78255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang nextPosition = mMediaPlayer.getCurrentPosition() + r.nextInt(duration/3); 78355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.seekTo(nextPosition); 78455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after the first seek:" 78555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 78655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // play for another short time 78755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.start(); 78855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Thread.sleep(r.nextInt(duration/6)); 78955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: position after the second play:" 79055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 79155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // seek to a random position (0, duration) 79255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.seekTo(r.nextInt(duration)); 79355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after the second seek:" 79455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 79555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang waittime = duration - mMediaPlayer.getCurrentPosition(); 79655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized(onCompletion){ 79755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 79855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompletion.wait(waittime + 30000); 79955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }catch (Exception e) { 80055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples are interrupted"); 80155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 80255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 80355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 80455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang terminateMessageLooper(); 80555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }catch (Exception e) { 80655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples:" + e.getMessage()); 80755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 80855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return onCompleteSuccess; 80955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 81055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang} 811