Ответ 1
У меня была та же проблема изменения яркости экрана внутри службы, и пару дней назад я успешно ее разрешил (и обновил мое приложение Телефонный расписание с функцией яркости;)). Итак, это код, который вы ввели в свою службу:
// This is important. In the next line 'brightness'
// should be a float number between 0.0 and 1.0
int brightnessInt = (int)(brightness*255);
//Check that the brightness is not 0, which would effectively
//switch off the screen, and we don't want that:
if(brightnessInt<1) {brightnessInt=1;}
// Set systemwide brightness setting.
Settings.System.putInt(getContentResolver(),
Settings.System.SCREEN_BRIGHTNESS_MODE, Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL);
Settings.System.putInt(getContentResolver(), Settings.System.SCREEN_BRIGHTNESS, brightnessInt);
// Apply brightness by creating a dummy activity
Intent intent = new Intent(getBaseContext(), DummyBrightnessActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.putExtra("brightness value", brightness);
getApplication().startActivity(intent);
Обратите внимание, что в приведенном выше фрагменте кода я использую две переменные для яркости. Один из них - brightness
, который является числом с плавающей точкой между 0.0 и 1.0, а другой - brightnessInt
, которое является целым числом от 0 до 255. Причина этого заключается в том, что для Settings.System
требуется целое число для сохранения яркости всей системы значение, а lp.screenBrightness
, которое вы увидите в следующем фрагменте кода, требует поплавка. Не спрашивайте меня, почему бы не использовать одно и то же значение, так оно и есть в Android SDK, поэтому нам просто придется жить с ним.
Это код для DummyBrightnessActivity:
public class DummyBrightnessActivity extends Activity{
private static final int DELAYED_MESSAGE = 1;
private Handler handler;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
handler = new Handler() {
@Override
public void handleMessage(Message msg) {
if(msg.what == DELAYED_MESSAGE) {
DummyBrightnessActivity.this.finish();
}
super.handleMessage(msg);
}
};
Intent brightnessIntent = this.getIntent();
float brightness = brightnessIntent.getFloatExtra("brightness value", 0);
WindowManager.LayoutParams lp = getWindow().getAttributes();
lp.screenBrightness = brightness;
getWindow().setAttributes(lp);
Message message = handler.obtainMessage(DELAYED_MESSAGE);
//this next line is very important, you need to finish your activity with slight delay
handler.sendMessageDelayed(message,1000);
}
}
Вот как вы добавляете свою активность в AndroidManifest.xml, возможно, самую важную часть:
<activity android:name="com.antonc.phone_schedule.DummyBrightnessActivity"
android:taskAffinity="com.antonc.phone_schedule.Dummy"
android:excludeFromRecents="true"
android:theme="@style/EmptyActivity"></activity>
Небольшое объяснение о том, что.
android:taskAffinity
должен быть другим, чем имя вашего пакета! Это заставляет DummyBrightnessActivity начинаться не в вашем основном стеке действий, а в отдельном, что означает, что когда DummyBrightnessActivity закрыт, вы не увидите следующего действия, что бы это ни было. Пока я не включил эту строку, закрытие DummyBrightnessActivity вызовет мою основную деятельность.
android:excludeFromRecents="true"
делает эту активность недоступной в списке недавно запущенных приложений, которые вы определенно хотите.
android:theme="@style/EmptyActivity"
определяет способ, которым DummyBrightnessActivity выглядит для пользователя, и именно там вы делаете его невидимым. Вот как вы определяете этот стиль в файле styles.xml:
<style name="EmptyActivity" parent="android:Theme.Dialog">
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowAnimationStyle">@android:style/Animation.Toast</item>
<item name="android:background">#00000000</item>
<item name="android:windowBackground">#00000000</item>
<item name="android:windowNoTitle">true</item>
<item name="android:colorForeground">#000</item>
</style>
Таким образом, ваш DummyBrightnessActivity будет невидим для пользователя. Я не уверен, если все эти параметры стиля действительно необходимы, но он работает для меня таким образом.
Я надеюсь, что это объяснит, но если у вас есть какие-либо вопросы, просто дайте мне знать.