diff options
author | Brad Fitzpatrick <bradfitz@android.com> | 2010-11-03 15:53:47 -0700 |
---|---|---|
committer | Brad Fitzpatrick <bradfitz@android.com> | 2010-11-08 13:16:02 -0800 |
commit | 66dc7065701d28d07f4a7dd49e95ed49aef64a8f (patch) | |
tree | 2e9744e0f20d8667d81467c56be2edd5c10b3780 /src | |
parent | 38f8a1d0fafccdd838dda889b8db786e1703f7ca (diff) | |
download | packages_apps_settings-66dc7065701d28d07f4a7dd49e95ed49aef64a8f.zip packages_apps_settings-66dc7065701d28d07f4a7dd49e95ed49aef64a8f.tar.gz packages_apps_settings-66dc7065701d28d07f4a7dd49e95ed49aef64a8f.tar.bz2 |
Don't stutter animations during Bluetooth broadcasts.
Bug: 3163109
Change-Id: I89ba3da4ee1f0999f3c7113f2f5fdce6fdafebd7
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/settings/bluetooth/BluetoothEventRedirector.java | 50 |
1 files changed, 37 insertions, 13 deletions
diff --git a/src/com/android/settings/bluetooth/BluetoothEventRedirector.java b/src/com/android/settings/bluetooth/BluetoothEventRedirector.java index 947eaf6..c8787a2 100644 --- a/src/com/android/settings/bluetooth/BluetoothEventRedirector.java +++ b/src/com/android/settings/bluetooth/BluetoothEventRedirector.java @@ -32,8 +32,13 @@ import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.content.SharedPreferences; +import android.os.Handler; import android.util.Log; +import java.util.concurrent.LinkedBlockingQueue; +import java.util.concurrent.ThreadPoolExecutor; +import java.util.concurrent.TimeUnit; + /** * BluetoothEventRedirector receives broadcasts and callbacks from the Bluetooth * API and dispatches the event on the UI thread to the right class in the @@ -42,9 +47,14 @@ import android.util.Log; public class BluetoothEventRedirector { private static final String TAG = "BluetoothEventRedirector"; - private LocalBluetoothManager mManager; + private final LocalBluetoothManager mManager; + + private final ThreadPoolExecutor mSerialExecutor = new ThreadPoolExecutor( + 0, 1, 1000L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>()); + + private final Handler mHandler = new Handler(); - private BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() { + private final BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { Log.v(TAG, "Received " + intent.getAction()); @@ -57,13 +67,11 @@ public class BluetoothEventRedirector { BluetoothAdapter.ERROR); mManager.setBluetoothStateInt(state); } else if (action.equals(BluetoothAdapter.ACTION_DISCOVERY_STARTED)) { - persistDiscoveringTimestamp(); - mManager.onScanningStateChanged(true); - + PendingResult pr = goAsync(); // so loading shared prefs doesn't kill animation + persistDiscoveringTimestamp(pr, true); } else if (action.equals(BluetoothAdapter.ACTION_DISCOVERY_FINISHED)) { - persistDiscoveringTimestamp(); - mManager.onScanningStateChanged(false); - + PendingResult pr = goAsync(); // so loading shared prefs doesn't kill animation + persistDiscoveringTimestamp(pr, false); } else if (action.equals(BluetoothDevice.ACTION_FOUND)) { short rssi = intent.getShortExtra(BluetoothDevice.EXTRA_RSSI, Short.MIN_VALUE); BluetoothClass btClass = intent.getParcelableExtra(BluetoothDevice.EXTRA_CLASS); @@ -222,10 +230,26 @@ public class BluetoothEventRedirector { return null; } - private void persistDiscoveringTimestamp() { - SharedPreferences.Editor editor = mManager.getSharedPreferences().edit(); - editor.putLong(LocalBluetoothManager.SHARED_PREFERENCES_KEY_DISCOVERING_TIMESTAMP, - System.currentTimeMillis()); - editor.apply(); + private void persistDiscoveringTimestamp( + final BroadcastReceiver.PendingResult pr, final boolean newState) { + // Load the shared preferences and edit it on a background + // thread (but serialized!), but then post back to the main + // thread to run the onScanningStateChanged callbacks which + // update the UI... + mSerialExecutor.submit(new Runnable() { + public void run() { + SharedPreferences.Editor editor = mManager.getSharedPreferences().edit(); + editor.putLong( + LocalBluetoothManager.SHARED_PREFERENCES_KEY_DISCOVERING_TIMESTAMP, + System.currentTimeMillis()); + editor.apply(); + mHandler.post(new Runnable() { + public void run() { + mManager.onScanningStateChanged(newState); + pr.finish(); + } + }); + } + }); } } |