CodecTest.java revision 55eef638fae461d40b1ad4b1738bdef355a2d482
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 359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.IOException; 369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.InputStream; 3755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wangimport java.util.Random; 389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/** 399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Junit / Instrumentation test case for the media player api 409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */ 429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class CodecTest { 439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project private static String TAG = "MediaPlayerApiTest"; 44b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static MediaPlayer mMediaPlayer; 45b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private MediaPlayer.OnPreparedListener mOnPreparedListener; 46b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 47c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static int WAIT_FOR_COMMAND_TO_COMPLETE = 60000; //1 min max. 48b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static boolean mInitialized = false; 49c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static boolean mPrepareReset = false; 50b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static Looper mLooper = null; 51b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static final Object lock = new Object(); 52b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static final Object prepareDone = new Object(); 53c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau private static final Object videoSizeChanged = new Object(); 5455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang private static final Object onCompletion = new Object(); 55b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static boolean onPrepareSuccess = false; 5655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang private static boolean onCompleteSuccess = false; 579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static String printCpuInfo(){ 599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cm = "dumpsys cpuinfo"; 609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo =null; 619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int ch; 629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Process p = Runtime.getRuntime().exec(cm); 649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project InputStream in = p.getInputStream(); 659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project StringBuffer sb = new StringBuffer(512); 669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project while ( ( ch = in.read() ) != -1 ){ 679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project sb.append((char) ch); 689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project cpuinfo = sb.toString(); 709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (IOException e){ 719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return cpuinfo; 749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int getDuration(String filePath) { 789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getDuration - " + filePath); 799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Duration " + duration); 869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "release"); 889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return duration; 899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getCurrentPosition(String filePath){ 929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "GetCurrentPosition - " + filePath); 939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "mp currentPositon = " + currentPosition + " play duration = " + (t2-t1)); 1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be within 10% of the sleep time 1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //For the very short mp3, it should return the length instead of 10 seconds 1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.SHORTMP3)){ 1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 1000 ) 1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition < ((t2-t1) *1.2)) && (currentPosition > 0)) 1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekTo(String filePath){ 1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekTo " + filePath); 1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(MediaNames.SEEK_TIME); 1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.WAIT_TIME); 1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.getMessage()); 1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "CurrentPosition = " + currentPosition); 1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The currentposition should be at least greater than the 80% of seek time 1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition > MediaNames.SEEK_TIME *0.8)) 1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean setLooping(String filePath){ 1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1 =0; 1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2 =0; 1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v (TAG, "SetLooping - " + filePath); 1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "setLooping duration " + duration); 1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 5000); 1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(20000); 1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause"); 1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Bug# 1106852 - IllegalStateException will be thrown if pause is called 1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //in here 1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //mp.pause(); 1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "looping position " + currentPosition + "duration = " + (t2-t1)); 1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //The current position should be within 20% of the sleep time 1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //and should be greater than zero. 1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((currentPosition < ((t2-t1-5000)*1.2)) && currentPosition > 0) 1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean pause(String filePath) throws Exception { 1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pause - " + filePath); 1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean misPlaying = true; 1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean pauseResult = false; 1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t1=0; 1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project long t2=0; 1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = mp.getDuration(); 1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t1=SystemClock.uptimeMillis(); 2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project t2=SystemClock.uptimeMillis(); 2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project misPlaying = mp.isPlaying(); 2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int curPosition = mp.getCurrentPosition(); 2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, filePath + " pause currentPositon " + curPosition); 2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "isPlaying "+ misPlaying + " wait time " + (t2 - t1) ); 2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project String cpuinfo = printCpuInfo(); 2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, cpuinfo); 2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((curPosition>0) && (curPosition < ((t2-t1) * 1.3)) && (misPlaying == false)) 2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project pauseResult = true; 2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return pauseResult; 2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void prepareStopRelease(String filePath) throws Exception { 2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "prepareStopRelease" + filePath); 2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static void preparePauseRelease(String filePath) throws Exception { 2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "preparePauseRelease" + filePath); 2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 234c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 235c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau static MediaPlayer.OnVideoSizeChangedListener mOnVideoSizeChangedListener = 236c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau new MediaPlayer.OnVideoSizeChangedListener() { 237c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public void onVideoSizeChanged(MediaPlayer mp, int width, int height) { 238c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 239c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "sizechanged notification received ..."); 240c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.notify(); 241c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 242c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 243c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau }; 2449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 245c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoHeight(String filePath) throws Exception { 2479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoHeight - " + filePath); 248c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau int videoHeight = 0; 249c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 250c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 251c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 252c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 253c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 254c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 255c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 256c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 257c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 258c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 259c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 260c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 261c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 262c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 263c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 264c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 265c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 266c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 267c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 268c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 269c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 270c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 271c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoHeight = mMediaPlayer.getVideoHeight(); 272c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 273c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 274c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 275c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 276c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 2779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoHeight; 2789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 280c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Register the videoSizeChanged listener 2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static int videoWidth(String filePath) throws Exception { 2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoWidth - " + filePath); 2839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int videoWidth = 0; 284c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau 285c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (lock) { 286c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 287c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 288c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 289c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch(Exception e) { 290c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "looper was interrupted."); 291c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau return 0; 292c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 293c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 294c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 295c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDataSource(filePath); 296c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 297c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.setOnVideoSizeChangedListener(mOnVideoSizeChangedListener); 298c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau synchronized (videoSizeChanged) { 299c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau try { 300c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.prepare(); 301c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.start(); 302c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoSizeChanged.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 303c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 304c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "wait was interrupted"); 305c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 306c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 307c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau videoWidth = mMediaPlayer.getVideoWidth(); 308c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau terminateMessageLooper(); 309c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } catch (Exception e) { 310c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.e(TAG, e.getMessage()); 311c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return videoWidth; 3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This also test the streaming video which may take a long 3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //time to start the playback. 3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean videoSeekTo(String filePath) throws Exception { 3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "videoSeekTo - " + filePath); 3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean videoResult = false; 3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 3259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (filePath.equals(MediaNames.VIDEO_SHORT_3GP)){ 3289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(0); 3319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"short position " + currentPosition); 3359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > 100 ) 3369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video duration " + duration); 3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 20000 ); 3469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(1000); 3489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.pause(); 3499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(MediaNames.PAUSE_WAIT_TIME); 3509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration/2); 3519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 3539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "video currentPosition " + currentPosition); 3559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 3569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > (duration /2 )*0.9) 3579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seekToEnd(String filePath){ 3649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd - " + filePath); 3659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 3689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 3000); 3759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 3769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(6000); 3779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 3789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 3799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 3809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 3819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 3829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 3839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 3849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < 0.9 * duration || isPlaying) 3859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 3869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 3879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 3889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 3909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean shortMediaStop(String filePath){ 3919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 3929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 3939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 3949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 3959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 3969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 3979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 3989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 3999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(10000); 4049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "duration = " + duration); 4119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean playToEnd(String filePath){ 4189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "shortMediaStop - " + filePath); 4199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 200000; 4219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int updateDuration = 0; 4229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project boolean isPlaying = false; 4249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 4279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "start playback"); 4299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //duration = mp.getDuration(); 4319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(50000); 4339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project isPlaying = mp.isPlaying(); 4359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition = mp.getCurrentPosition(); 4369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //updateDuration = mp.getDuration(); 4379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seekToEnd currentPosition= " + currentPosition + " isPlaying = " + isPlaying); 4389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "duration = " + duration); 4419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Log.v(TAG, "Update duration = " + updateDuration); 4429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition > duration || isPlaying) 4439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean seektoBeforeStart(String filePath){ 4499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "seektoBeforeStart - " + filePath); 4509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int currentPosition = 0; 4539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.seekTo(duration - 10000); 4609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 4619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project currentPosition=mp.getCurrentPosition(); 4629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.stop(); 4639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 4659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (currentPosition < duration/2) 4669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 4679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 4689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 4699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean mediaRecorderRecord(String filePath){ 4729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "SoundRecording - " + filePath); 4739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 4749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 4759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaRecorder mRecorder = new MediaRecorder(); 4779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); 4789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); 4799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); 4809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.setOutputFile(filePath); 4819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.prepare(); 4829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.start(); 4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(500); 4849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.stop(); 4859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "sound recorded"); 4869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mRecorder.release(); 4879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, e.toString()); 4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Verify the recorded file 4929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 4959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 4969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 4979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,"Duration " + duration); 4989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 4999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 5009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Check the record media file length is greate than zero 5019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > 0) 5029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Test for mediaMeta Data Thumbnail 5099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean getThumbnail(String filePath, String goldenPath){ 5109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "getThumbnail - " + filePath); 5119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenHeight = 0; 5139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int goldenWidth = 0; 5149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputWidth = 0; 5159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int outputHeight = 0; 5169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //This test is only for the short media file 5189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project BitmapFactory mBitmapFactory = new BitmapFactory(); 5209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaMetadataRetriever mMediaMetadataRetriever = new MediaMetadataRetriever(); 5229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 5239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mMediaMetadataRetriever.setDataSource(filePath); 5249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } catch(Exception e) { 5259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project e.printStackTrace(); 5269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Bitmap outThumbnail = mMediaMetadataRetriever.captureFrame(); 5299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Verify the thumbnail 5319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Bitmap goldenBitmap = mBitmapFactory.decodeFile(goldenPath); 5329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputWidth = outThumbnail.getWidth(); 5349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project outputHeight = outThumbnail.getHeight(); 5359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenHeight = goldenBitmap.getHeight(); 5369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project goldenWidth = goldenBitmap.getWidth(); 5379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //check the image dimension 5399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if ((outputWidth != goldenWidth) || (outputHeight != goldenHeight)) 5409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Check one line of pixel 5439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int x = goldenHeight/2; 5449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project for (int j=0; j<goldenWidth; j++){ 5459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (goldenBitmap.getPixel(x, j) != outThumbnail.getPixel(x, j)){ 5469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "pixel = " + goldenBitmap.getPixel(x, j)); 5479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){} 5519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //Load midi file from resources 5559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean resourcesPlayback(AssetFileDescriptor afd, int expectedDuration){ 5569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project int duration = 0; 5579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(), afd.getLength()); 5609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 5619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.start(); 5629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project duration = mp.getDuration(); 5639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Thread.sleep(5000); 5649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (duration > expectedDuration) 5699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project else 5719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean prepareAsyncReset(String filePath){ 5759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project //preparesAsync 5769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try{ 5779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = new MediaPlayer(); 5789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 5799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepareAsync(); 5809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 5819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 5829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 5839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG,e.getMessage()); 5849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 5879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean isLooping(String filePath) { 5919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 5929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 5939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 5949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 5959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 5969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after ctor"); 5979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 5989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 5999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (!mp.isLooping()) { 6049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned false after setLooping(true)"); 6059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(false); 6099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after setLooping(false)"); 6119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project public static boolean isLoopingAfterReset(String filePath) { 6259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project MediaPlayer mp = null; 6269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project try { 6279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp = new MediaPlayer(); 6289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setDataSource(filePath); 6299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.prepare(); 6309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.setLooping(true); 6329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.reset(); 6339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp.isLooping()) { 6349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "MediaPlayer.isLooping() returned true after reset()"); 6359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project }catch (Exception e){ 6389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Log.v(TAG, "Exception : " + e.toString()); 6399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return false; 6409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } finally { 6419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (mp != null) 6429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project mp.release(); 6439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 6449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 6459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project return true; 6469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 647b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 648b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 649b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * Initializes the message looper so that the mediaPlayer object can 650b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * receive the callback messages. 651b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 652b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void initializeMessageLooper() { 653b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start looper"); 654b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project new Thread() { 655b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project @Override 656b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void run() { 657b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // Set up a looper to be used by camera. 658b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.prepare(); 659b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "start loopRun"); 660b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // Save the looper so that we can terminate this thread 661b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project // after we are done with it. 662b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mLooper = Looper.myLooper(); 663b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer = new MediaPlayer(); 664b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 665b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mInitialized = true; 666b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.notify(); 667b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 668b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Looper.loop(); // Blocks forever until Looper.quit() is called. 669b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "initializeMessageLooper: quit."); 670b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 671b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }.start(); 672b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 673b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 674b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project /* 675b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project * Terminates the message looper thread. 676b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project */ 677b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project private static void terminateMessageLooper() { 678b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mLooper.quit(); 679b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.release(); 680b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 681b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 682b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project static MediaPlayer.OnPreparedListener mPreparedListener = new MediaPlayer.OnPreparedListener() { 683b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project public void onPrepared(MediaPlayer mp) { 684b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 685c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if(mPrepareReset){ 686c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau Log.v(TAG, "call Reset"); 687c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mMediaPlayer.reset(); 688c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 689b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "notify the prepare callback"); 690b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.notify(); 691b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project onPrepareSuccess = true; 692b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 693b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 694b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }; 695b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 696c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau public static boolean prepareAsyncCallback(String filePath, boolean reset) throws Exception { 697c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //Added the PrepareReset flag which allow us to switch to different 698c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau //test case. 699c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau if (reset){ 700c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau mPrepareReset = true; 701c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 702b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project 703b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (lock) { 704c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau initializeMessageLooper(); 705b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 706b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 707b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch(Exception e) { 708b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "looper was interrupted."); 709b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return false; 710b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 711b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 712b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try{ 713b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setOnPreparedListener(mPreparedListener); 714b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDataSource(filePath); 715b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 716b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project mMediaPlayer.prepareAsync(); 717b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project synchronized (prepareDone) { 718b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project try { 719b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project prepareDone.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 720b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } catch (Exception e) { 721b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG, "wait was interrupted."); 722b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 723c1b80cb7e30102b304d62beb9649f84c798e00e9Yu Shan Emily Lau } 724b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project terminateMessageLooper(); 725b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project }catch (Exception e){ 726b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project Log.v(TAG,e.getMessage()); 727b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 728b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project return onPrepareSuccess; 729b2a3dd88a53cc8c6d19f6dc8ec4f3d6c4abd9b54The Android Open Source Project } 7309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project 73155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang static MediaPlayer.OnCompletionListener mCompletionListener = new MediaPlayer.OnCompletionListener() { 73255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public void onCompletion(MediaPlayer mp) { 73355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (onCompletion) { 73455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "notify the completion callback"); 73555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompletion.notify(); 73655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompleteSuccess = true; 73755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 73855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 73955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }; 74055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang 74155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // For each media file, forward twice and backward once, then play to the end 74255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang public static boolean playMediaSamples(String filePath) throws Exception { 74355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int duration = 0; 74455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int curPosition = 0; 74555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int nextPosition = 0; 74655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang int waittime = 0; 74755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Random r = new Random(); 74855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang initializeMessageLooper(); 74955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized (lock) { 75055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 75155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang lock.wait(WAIT_FOR_COMMAND_TO_COMPLETE); 75255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } catch(Exception e) { 75355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "looper was interrupted."); 75455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 75555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 75655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 75755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 75855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setOnCompletionListener(mCompletionListener); 75955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: sample file name " + filePath); 76055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDataSource(filePath); 76155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.setDisplay(MediaFrameworkTest.mSurfaceView.getHolder()); 76255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.prepare(); 76355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang duration = mMediaPlayer.getDuration(); 76455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: duration = " + duration); 76555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // start to play 76655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.start(); 76755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // randomly play for time within (0, duration/3) 76855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Thread.sleep(r.nextInt(duration/3)); 76955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.pause(); 77055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after pause: " 77155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 77255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // seek to position (0, 2/3*duration) 77355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang nextPosition = mMediaPlayer.getCurrentPosition() + r.nextInt(duration/3); 77455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.seekTo(nextPosition); 77555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after the first seek:" 77655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 77755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // play for another short time 77855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.start(); 77955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Thread.sleep(r.nextInt(duration/6)); 78055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: position after the second play:" 78155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 78255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang // seek to a random position (0, duration) 78355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang mMediaPlayer.seekTo(r.nextInt(duration)); 78455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples: current position after the second seek:" 78555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang + mMediaPlayer.getCurrentPosition()); 78655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang waittime = duration - mMediaPlayer.getCurrentPosition(); 78755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang synchronized(onCompletion){ 78855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang try { 78955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang onCompletion.wait(waittime + 30000); 79055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }catch (Exception e) { 79155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples are interrupted"); 79255eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return false; 79355eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 79455eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 79555eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang terminateMessageLooper(); 79655eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang }catch (Exception e) { 79755eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang Log.v(TAG, "playMediaSamples:" + e.getMessage()); 79855eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 79955eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang return onCompleteSuccess; 80055eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang } 80155eef638fae461d40b1ad4b1738bdef355a2d482Xia Wang} 802