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 45d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 46d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou */ 47d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zoupublic class CodecTest { 48a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau private static String TAG = "CodecTest"; 49b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static MediaPlayer mMediaPlayer; 50b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private MediaPlayer.OnPreparedListener mOnPreparedListener; 51d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 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; 61a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau public static boolean onCompleteSuccess = false; 62a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau public static boolean mPlaybackError = false; 6385305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau public static int mMediaInfoUnknownCount = 0; 6485305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau public static int mMediaInfoVideoTrackLaggingCount = 0; 6585305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau public static int mMediaInfoBadInterleavingCount = 0; 6685305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau public static int mMediaInfoNotSeekableCount = 0; 6785305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau public static int mMediaInfoMetdataUpdateCount = 0; 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 69d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou public static String printCpuInfo(){ 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cm = "dumpsys cpuinfo"; 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo =null; 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int ch; 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Process p = Runtime.getRuntime().exec(cm); 75d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou InputStream in = p.getInputStream(); 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuffer sb = new StringBuffer(512); 77d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou while ( ( ch = in.read() ) != -1 ){ 78d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou sb.append((char) ch); 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 80d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou cpuinfo = sb.toString(); 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (IOException e){ 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return cpuinfo; 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int getDuration(String filePath) { 899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getDuration - " + filePath); 909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 93d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.prepare(); 94be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau }catch (Exception e){ 95be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau Log.v(TAG, e.toString()); 96be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Duration " + duration); 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 100d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou Log.v(TAG, "release"); 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return duration; 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getCurrentPosition(String filePath){ 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "GetCurrentPosition - " + filePath); 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 125d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.release(); 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "mp currentPositon = " + currentPosition + " play duration = " + (t2-t1)); 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be within 10% of the sleep time 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //For the very short mp3, it should return the length instead of 10 seconds 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.SHORTMP3)){ 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 1000 ) 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 133d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou if ((currentPosition < ((t2-t1) *1.2)) && (currentPosition > 0)) 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 137d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekTo(String filePath){ 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekTo " + filePath); 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(MediaNames.SEEK_TIME); 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.WAIT_TIME); 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.getMessage()); 152d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "CurrentPosition = " + currentPosition); 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be at least greater than the 80% of seek time 157d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou if ((currentPosition > MediaNames.SEEK_TIME *0.8)) 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean setLooping(String filePath){ 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1 =0; 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v (TAG, "SetLooping - " + filePath); 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 173d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou duration = mp.getDuration(); 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "setLooping duration " + duration); 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 5000); 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(20000); 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause"); 183d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou //Bug# 1106852 - IllegalStateException will be thrown if pause is called 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //in here 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //mp.pause(); 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "looping position " + currentPosition + "duration = " + (t2-t1)); 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 190d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The current position should be within 20% of the sleep time 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //and should be greater than zero. 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition < ((t2-t1-5000)*1.2)) && currentPosition > 0) 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 199d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean pause(String filePath) throws Exception { 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause - " + filePath); 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean misPlaying = true; 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean pauseResult = false; 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2=0; 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 209d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.prepare(); 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project misPlaying = mp.isPlaying(); 2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int curPosition = mp.getCurrentPosition(); 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, filePath + " pause currentPositon " + curPosition); 2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "isPlaying "+ misPlaying + " wait time " + (t2 - t1) ); 2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo = printCpuInfo(); 2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, cpuinfo); 2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((curPosition>0) && (curPosition < ((t2-t1) * 1.3)) && (misPlaying == false)) 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project pauseResult = true; 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pauseResult; 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void prepareStopRelease(String filePath) throws Exception { 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "prepareStopRelease" + filePath); 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void preparePauseRelease(String filePath) throws Exception { 2409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "preparePauseRelease" + filePath); 2419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 247d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 248c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau static MediaPlayer.OnVideoSizeChangedListener mOnVideoSizeChangedListener = 249c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau new MediaPlayer.OnVideoSizeChangedListener() { 250c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public void onVideoSizeChanged(MediaPlayer mp, int width, int height) { 251c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 252c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "sizechanged notification received ..."); 253c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.notify(); 254c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 255c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 256c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau }; 2579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 258c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoHeight(String filePath) throws Exception { 2609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoHeight - " + filePath); 261d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou int videoHeight = 0; 262c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 263c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 264c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 265c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 266c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 267c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 268c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 269c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 270c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 271c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 272c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 273c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 274c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 275c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 276c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 277c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 278c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 279c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 280c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 281c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 282c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 283c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 284c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoHeight = mMediaPlayer.getVideoHeight(); 285c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 286c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 287c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 288c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 289d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoHeight; 2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 293c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoWidth(String filePath) throws Exception { 2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoWidth - " + filePath); 2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int videoWidth = 0; 297c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 298c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 299c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 300c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 301c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 302c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 303c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 304c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 305c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 306c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 307c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 308c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 309c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 310c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 311c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 312c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 313c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 314c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 315c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 316c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 317c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 318c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 319c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 320c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoWidth = mMediaPlayer.getVideoWidth(); 321c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 322c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 323c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 324d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoWidth; 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This also test the streaming video which may take a long 329d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou //time to start the playback. 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean videoSeekTo(String filePath) throws Exception { 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoSeekTo - " + filePath); 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean videoResult = false; 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.VIDEO_SHORT_3GP)){ 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(0); 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"short position " + currentPosition); 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > 100 ) 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video duration " + duration); 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 20000 ); 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration/2); 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video currentPosition " + currentPosition); 3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > (duration /2 )*0.9) 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekToEnd(String filePath){ 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd - " + filePath); 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 3000); 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(6000); 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 395d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.release(); 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 0.9 * duration || isPlaying) 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 400d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou return true; 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean shortMediaStop(String filePath){ 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 422d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.release(); 4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 427d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou return true; 4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean playToEnd(String filePath){ 4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 200000; 4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int updateDuration = 0; 4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //duration = mp.getDuration(); 4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(50000); 4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //updateDuration = mp.getDuration(); 4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 452d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mp.release(); 4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "duration = " + duration); 4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "Update duration = " + updateDuration); 4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 458d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou return true; 4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seektoBeforeStart(String filePath){ 4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seektoBeforeStart - " + filePath); 4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 10000); 4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition=mp.getCurrentPosition(); 4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < duration/2) 4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 481d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou return true; 4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mediaRecorderRecord(String filePath){ 4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "SoundRecording - " + filePath); 4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaRecorder mRecorder = new MediaRecorder(); 4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); 4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); 4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFile(filePath); 4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.prepare(); 4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.start(); 4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(500); 4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.stop(); 4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "sound recorded"); 4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.release(); 5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 502d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Verify the recorded file 5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"Duration " + duration); 5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Check the record media file length is greate than zero 5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > 0) 5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Test for mediaMeta Data Thumbnail 5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getThumbnail(String filePath, String goldenPath){ 5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getThumbnail - " + filePath); 5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenHeight = 0; 5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenWidth = 0; 5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputWidth = 0; 5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputHeight = 0; 5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project BitmapFactory mBitmapFactory = new BitmapFactory(); 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaMetadataRetriever mMediaMetadataRetriever = new MediaMetadataRetriever(); 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mMediaMetadataRetriever.setDataSource(filePath); 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } catch(Exception e) { 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project e.printStackTrace(); 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 541f6bd1ea0c79516a5ef3c0c463761deec1a80e419James Dong Bitmap outThumbnail = mMediaMetadataRetriever.getFrameAtTime(-1); 5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 543d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou //Verify the thumbnail 5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Bitmap goldenBitmap = mBitmapFactory.decodeFile(goldenPath); 5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputWidth = outThumbnail.getWidth(); 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputHeight = outThumbnail.getHeight(); 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenHeight = goldenBitmap.getHeight(); 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenWidth = goldenBitmap.getWidth(); 5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //check the image dimension 5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((outputWidth != goldenWidth) || (outputHeight != goldenHeight)) 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 554be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau // Check half line of pixel 555be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau int x = goldenHeight / 2; 556be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau for (int j = 1; j < goldenWidth / 2; j++) { 557be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau if (goldenBitmap.getPixel(x, j) != outThumbnail.getPixel(x, j)) { 5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pixel = " + goldenBitmap.getPixel(x, j)); 559be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau return false; 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 561be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 562be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau }catch (Exception e){ 563be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau Log.v(TAG, e.toString()); 564be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau return false; 565be467b579e06443bc79ea6a04ba0b4d4746da994Yu Shan Emily Lau } 5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Load midi file from resources 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean resourcesPlayback(AssetFileDescriptor afd, int expectedDuration){ 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(), afd.getLength()); 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > expectedDuration) 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 589d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou public static boolean prepareAsyncReset(String filePath){ 590d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou //preparesAsync 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepareAsync(); 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 605d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou public static boolean isLooping(String filePath) { 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 607d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after ctor"); 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mp.isLooping()) { 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned false after setLooping(true)"); 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 622d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(false); 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after setLooping(false)"); 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean isLoopingAfterReset(String filePath) { 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 6489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after reset()"); 6509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 662d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 663b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 664d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou * Initializes the message looper so that the mediaPlayer object can 665b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * receive the callback messages. 666b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 667b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void initializeMessageLooper() { 668b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start looper"); 669b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project new Thread() { 670b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project @Override 671b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void run() { 672b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // Set up a looper to be used by camera. 673b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.prepare(); 674b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start loopRun"); 675d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou // Save the looper so that we can terminate this thread 676b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // after we are done with it. 677d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mLooper = Looper.myLooper(); 678d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mMediaPlayer = new MediaPlayer(); 679b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 680b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mInitialized = true; 681b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.notify(); 682b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 683b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.loop(); // Blocks forever until Looper.quit() is called. 684b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "initializeMessageLooper: quit."); 685b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 686b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }.start(); 687b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 688d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 689b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 690b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * Terminates the message looper thread. 691b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 692b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void terminateMessageLooper() { 693b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mLooper.quit(); 694b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.release(); 695b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 696d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 697b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project static MediaPlayer.OnPreparedListener mPreparedListener = new MediaPlayer.OnPreparedListener() { 698b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void onPrepared(MediaPlayer mp) { 699b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 700c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if(mPrepareReset){ 701c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "call Reset"); 702c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.reset(); 703c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 704b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "notify the prepare callback"); 705b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.notify(); 706b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project onPrepareSuccess = true; 707b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 708b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 709b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }; 710d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 711c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public static boolean prepareAsyncCallback(String filePath, boolean reset) throws Exception { 712c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Added the PrepareReset flag which allow us to switch to different 713c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //test case. 714c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if (reset){ 715c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mPrepareReset = true; 716c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 717d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 718b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 719c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 720b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 721b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 722b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch(Exception e) { 723b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "looper was interrupted."); 724b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return false; 725b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 726b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 727b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try{ 728b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setOnPreparedListener(mPreparedListener); 729b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDataSource(filePath); 730b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 731d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou mMediaPlayer.prepareAsync(); 732b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 733b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 734b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 735b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch (Exception e) { 736b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "wait was interrupted."); 737b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 738d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 739b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project terminateMessageLooper(); 740b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }catch (Exception e){ 741b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG,e.getMessage()); 742d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 743b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return onPrepareSuccess; 744b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 7459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 74655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang static MediaPlayer.OnCompletionListener mCompletionListener = new MediaPlayer.OnCompletionListener() { 74755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public void onCompletion(MediaPlayer mp) { 74855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (onCompletion) { 74955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "notify the completion callback"); 75055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompletion.notify(); 75155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompleteSuccess = true; 75255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 75355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 75455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }; 75555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang 756a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau static MediaPlayer.OnErrorListener mOnErrorListener = new MediaPlayer.OnErrorListener() { 757a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau public boolean onError(MediaPlayer mp, int framework_err, int impl_err) { 758a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau mPlaybackError = true; 759a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau mp.reset(); 760a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau return true; 761a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau } 762a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau }; 763a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau 764a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau static MediaPlayer.OnInfoListener mInfoListener = new MediaPlayer.OnInfoListener() { 765a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau public boolean onInfo(MediaPlayer mp, int what, int extra) { 766a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau switch (what){ 767a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau case MediaPlayer.MEDIA_INFO_UNKNOWN: 76885305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoUnknownCount++; 769a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau break; 770a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau case MediaPlayer.MEDIA_INFO_VIDEO_TRACK_LAGGING: 77185305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoVideoTrackLaggingCount++; 772a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau break; 773a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau case MediaPlayer.MEDIA_INFO_BAD_INTERLEAVING: 77485305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoBadInterleavingCount++; 775a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau break; 776a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau case MediaPlayer.MEDIA_INFO_NOT_SEEKABLE: 77785305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoNotSeekableCount++; 778a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau break; 779a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau case MediaPlayer.MEDIA_INFO_METADATA_UPDATE: 78085305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoMetdataUpdateCount++; 781a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau break; 782a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau } 783a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau return true; 784a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau } 785a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau }; 786a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau 78755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public static boolean playMediaSamples(String filePath) throws Exception { 788d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou return playMediaSamples(filePath, 2000); 789d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } 790d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou 791d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou // For each media file, forward twice and backward once, then play to the end 792d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou public static boolean playMediaSamples(String filePath, int buffertime) throws Exception { 79355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int duration = 0; 79455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int curPosition = 0; 79555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int nextPosition = 0; 79655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int waittime = 0; 797a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau onCompleteSuccess = false; 79885305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoUnknownCount = 0; 79985305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoVideoTrackLaggingCount = 0; 80085305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoBadInterleavingCount = 0; 80185305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoNotSeekableCount = 0; 80285305f04d52e921de0452a1efef01175b1bbac3cYu Shan Emily Lau mMediaInfoMetdataUpdateCount = 0; 803a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau mPlaybackError = false; 804a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau String testResult; 805a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau 80655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang initializeMessageLooper(); 80755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (lock) { 80855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 80955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 81055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } catch(Exception e) { 81155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "looper was interrupted."); 81255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 81355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 81455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 81555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 81655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setOnCompletionListener(mCompletionListener); 817a58389bdc1f3c41014003ab6e1a5e9a0ca37d789Yu Shan Emily Lau mMediaPlayer.setOnErrorListener(mOnErrorListener); 818ce6ff2c2e6f5ac1d4e86c94b68587b8634032908Yu Shan Emily Lau mMediaPlayer.setOnInfoListener(mInfoListener); 81955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: sample file name " + filePath); 82055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDataSource(filePath); 82155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 82255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.prepare(); 82355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang duration = mMediaPlayer.getDuration(); 82455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // start to play 82555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.start(); 82655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang waittime = duration - mMediaPlayer.getCurrentPosition(); 82755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized(onCompletion){ 82855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 829d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou onCompletion.wait(waittime + buffertime); 83055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }catch (Exception e) { 83155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples are interrupted"); 83255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 83355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 83455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 83555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang terminateMessageLooper(); 836d097e7ef745714cadc299db5e8bb0ff57c255373Shaohan Zou } catch (Exception e) { 83755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples:" + e.getMessage()); 83855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 83955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return onCompleteSuccess; 84055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 84155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang} 842