diff options
author | David T.H. Kao <dthkao@gmail.com> | 2017-06-20 10:13:21 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-20 10:13:21 -0700 |
commit | 4e41427eb8120f8fbc125b89d4a01d6d009af77c (patch) | |
tree | 67b0e3bd84dfe28c156d8110df663439ec3a265a /src/main | |
parent | 1627da09afbdb3d275728cd13a7e29358e47a5f3 (diff) | |
download | mobly-bundled-snippets-4e41427eb8120f8fbc125b89d4a01d6d009af77c.tar.gz |
Initial audio playback functionality (#62)
* Initial audio playback functionality
* cleanup descriptions
* whitespace cleanup
Diffstat (limited to 'src/main')
-rw-r--r-- | src/main/AndroidManifest.xml | 2 | ||||
-rw-r--r-- | src/main/java/com/google/android/mobly/snippet/bundled/MediaSnippet.java | 68 |
2 files changed, 70 insertions, 0 deletions
diff --git a/src/main/AndroidManifest.xml b/src/main/AndroidManifest.xml index a1e3ef9..1f6744b 100644 --- a/src/main/AndroidManifest.xml +++ b/src/main/AndroidManifest.xml @@ -15,6 +15,7 @@ <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.MANAGE_ACCOUNTS" /> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> + <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <uses-permission android:name="android.permission.READ_SMS" /> <uses-permission android:name="android.permission.READ_SYNC_SETTINGS"/> @@ -30,6 +31,7 @@ com.google.android.mobly.snippet.bundled.BluetoothLeAdvertiserSnippet, com.google.android.mobly.snippet.bundled.BluetoothLeScannerSnippet, com.google.android.mobly.snippet.bundled.LogSnippet, + com.google.android.mobly.snippet.bundled.MediaSnippet, com.google.android.mobly.snippet.bundled.NotificationSnippet, com.google.android.mobly.snippet.bundled.TelephonySnippet, com.google.android.mobly.snippet.bundled.WifiManagerSnippet" /> diff --git a/src/main/java/com/google/android/mobly/snippet/bundled/MediaSnippet.java b/src/main/java/com/google/android/mobly/snippet/bundled/MediaSnippet.java new file mode 100644 index 0000000..ee2a214 --- /dev/null +++ b/src/main/java/com/google/android/mobly/snippet/bundled/MediaSnippet.java @@ -0,0 +1,68 @@ +/* + * Copyright (C) 2017 Google Inc. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ + +package com.google.android.mobly.snippet.bundled; + + +import android.media.AudioAttributes; +import android.media.AudioManager; +import android.media.MediaPlayer; +import android.os.Build; +import android.os.Build.VERSION_CODES; +import com.google.android.mobly.snippet.Snippet; +import com.google.android.mobly.snippet.rpc.Rpc; +import java.io.IOException; + +/* Snippet class to control media playback. */ +public class MediaSnippet implements Snippet { + + private final MediaPlayer mPlayer; + + public MediaSnippet() { + mPlayer = new MediaPlayer(); + } + + @Rpc(description = "Resets snippet media player to an idle state, regardless of current state.") + public void mediaReset() { + mPlayer.reset(); + } + + @Rpc(description = "Play an audio file stored at a specified file path in external storage.") + public void mediaPlayAudioFile(String mediaFilePath) throws IOException { + mediaReset(); + if (Build.VERSION.SDK_INT >= VERSION_CODES.LOLLIPOP) { + mPlayer.setAudioAttributes( + new AudioAttributes.Builder() + .setContentType(AudioAttributes.CONTENT_TYPE_MUSIC) + .setUsage(AudioAttributes.USAGE_MEDIA) + .build() + ); + } else { + mPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC); + } + mPlayer.setDataSource(mediaFilePath); + mPlayer.prepare(); // Synchronous call blocks until the player is ready for playback. + mPlayer.start(); + } + + @Rpc(description = "Stops media playback.") + public void mediaStop() throws IOException { + mPlayer.stop(); + } + + @Override + public void shutdown() {} +} |