1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-16 04:37:33 +01:00

Use AudioManager for Media Buttons

Switch from ACTION_MEDIA_BUTTON to all AudioManager

Add mb_intents pref for audioplayer
This commit is contained in:
Benjamin Swartley 2022-11-07 20:09:52 -05:00 committed by José Rebelo
parent 932249f148
commit 739bd1b5a8
3 changed files with 30 additions and 14 deletions

View File

@ -48,6 +48,8 @@ public class GBMusicControlReceiver extends BroadcastReceiver {
int keyCode = -1; int keyCode = -1;
int volumeAdjust = AudioManager.ADJUST_LOWER; int volumeAdjust = AudioManager.ADJUST_LOWER;
AudioManager audioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
switch (musicCmd) { switch (musicCmd) {
case NEXT: case NEXT:
keyCode = KeyEvent.KEYCODE_MEDIA_NEXT; keyCode = KeyEvent.KEYCODE_MEDIA_NEXT;
@ -74,7 +76,6 @@ public class GBMusicControlReceiver extends BroadcastReceiver {
// change default and fall through, :P // change default and fall through, :P
volumeAdjust = AudioManager.ADJUST_RAISE; volumeAdjust = AudioManager.ADJUST_RAISE;
case VOLUMEDOWN: case VOLUMEDOWN:
AudioManager audioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
audioManager.adjustStreamVolume(AudioManager.STREAM_MUSIC, volumeAdjust, 0); audioManager.adjustStreamVolume(AudioManager.STREAM_MUSIC, volumeAdjust, 0);
final int volumeLevel = audioManager.getStreamVolume(AudioManager.STREAM_MUSIC); final int volumeLevel = audioManager.getStreamVolume(AudioManager.STREAM_MUSIC);
@ -94,21 +95,29 @@ public class GBMusicControlReceiver extends BroadcastReceiver {
long eventtime = SystemClock.uptimeMillis(); long eventtime = SystemClock.uptimeMillis();
Intent downIntent = new Intent(Intent.ACTION_MEDIA_BUTTON, null); if (GBApplication.getPrefs().getBoolean("mb_intents", false)) {
KeyEvent downEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_DOWN, keyCode, 0); Intent downIntent = new Intent(Intent.ACTION_MEDIA_BUTTON, null);
downIntent.putExtra(Intent.EXTRA_KEY_EVENT, downEvent); KeyEvent downEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_DOWN, keyCode, 0);
if (!"default".equals(audioPlayer)) { downIntent.putExtra(Intent.EXTRA_KEY_EVENT, downEvent);
downIntent.setPackage(audioPlayer); if (!"default".equals(audioPlayer)) {
} downIntent.setPackage(audioPlayer);
context.sendOrderedBroadcast(downIntent, null); }
context.sendOrderedBroadcast(downIntent, null);
Intent upIntent = new Intent(Intent.ACTION_MEDIA_BUTTON, null); Intent upIntent = new Intent(Intent.ACTION_MEDIA_BUTTON, null);
KeyEvent upEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_UP, keyCode, 0); KeyEvent upEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_UP, keyCode, 0);
upIntent.putExtra(Intent.EXTRA_KEY_EVENT, upEvent); upIntent.putExtra(Intent.EXTRA_KEY_EVENT, upEvent);
if (!"default".equals(audioPlayer)) { if (!"default".equals(audioPlayer)) {
upIntent.setPackage(audioPlayer); upIntent.setPackage(audioPlayer);
}
context.sendOrderedBroadcast(upIntent, null);
} else {
KeyEvent downEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_DOWN, keyCode, 0);
audioManager.dispatchMediaKeyEvent(downEvent);
KeyEvent upEvent = new KeyEvent(eventtime, eventtime, KeyEvent.ACTION_UP, keyCode, 0);
audioManager.dispatchMediaKeyEvent(upEvent);
} }
context.sendOrderedBroadcast(upIntent, null);
} }
} }

View File

@ -203,6 +203,7 @@
<string name="pref_title_general_autoconnectonbluetooth">Connect to Gadgetbridge device when Bluetooth is turned on</string> <string name="pref_title_general_autoconnectonbluetooth">Connect to Gadgetbridge device when Bluetooth is turned on</string>
<string name="pref_title_general_autostartonboot">Start automatically</string> <string name="pref_title_general_autostartonboot">Start automatically</string>
<string name="pref_title_general_autoreconnect">Reconnect automatically</string> <string name="pref_title_general_autoreconnect">Reconnect automatically</string>
<string name="pref_title_mb_intents">Broadcast Media Button Intents Directly</string>
<string name="pref_title_audio_player">Preferred Audioplayer</string> <string name="pref_title_audio_player">Preferred Audioplayer</string>
<string name="pref_default">Default</string> <string name="pref_default">Default</string>
<string name="pref_header_datetime">Date and Time</string> <string name="pref_header_datetime">Date and Time</string>

View File

@ -34,6 +34,12 @@
android:title="@string/pref_title_audio_player" android:title="@string/pref_title_audio_player"
android:summary="%s" /> android:summary="%s" />
<CheckBoxPreference
android:layout="@layout/preference_checkbox"
android:defaultValue="false"
android:key="mb_intents"
android:title="@string/pref_title_mb_intents" />
<PreferenceScreen android:title="@string/pref_title_theme"> <PreferenceScreen android:title="@string/pref_title_theme">
<ListPreference <ListPreference
android:defaultValue="@string/pref_theme_value_light" android:defaultValue="@string/pref_theme_value_light"