android 屏幕亮度調(diào)節(jié)方法詳解
屏幕亮度自動(dòng)調(diào)節(jié):
主要是從Sensor分析之中分離出來(lái)分析LIGHT 光線感應(yīng)器,因此就分析一下自動(dòng)調(diào)節(jié)屏幕亮度(手機(jī)隨著光線的強(qiáng)度自我調(diào)節(jié),也就是在亮的光線下屏幕自動(dòng)調(diào)亮一些,暗的時(shí)候就自動(dòng)調(diào)暗一些,省得光線對(duì)眼睛有刺激).....
(本人從歷經(jīng)挫折才大概了解流程),現(xiàn)在就開始講一下流程,如果有不對(duì)地方希望牛人指出來(lái)。。。
先從Sttings入手吧,在diaplay中有屏幕亮度調(diào)節(jié),有一個(gè)進(jìn)度調(diào),上面有一個(gè)checkbox(自動(dòng)調(diào)節(jié)屏幕亮度的),
那么我們當(dāng)然去找settings下的文件開始看了,先找到
DiaplaySettings.java文件以及display_setting.xml文件,display_setting.xml里面能找到相應(yīng)的組件,但是 在DiaplaySettings.java文件中卻不能找到調(diào)用相應(yīng)組件的代碼,
那么我們?cè)俚絪ettings中去找,能找到BrightnessPreference.java文件,沒錯(cuò)這個(gè)文件就是自動(dòng)調(diào)節(jié)亮度的文件,我們先看看代碼:
構(gòu)造函數(shù)中有mAutomaticAvailable = context.getResources().getBoolean(com.android.internal.R.bool.config_automatic_brightness_available);
開始以為mAutomaticAvailabl的值(為true,在config.xml中)是判斷是否自動(dòng)調(diào)節(jié)亮度,因?yàn)樵谖腋M(jìn)到PowerManagerService.java中,在initInThread() 中
mUseSoftwareAutoBrightness = resources.getBoolean(
com.android.internal.R.bool.config_automatic_brightness_available);
if (mUseSoftwareAutoBrightness) {
mAutoBrightnessLevels = resources.getIntArray(
com.android.internal.R.array.config_autoBrightnessLevels);//得到自動(dòng)化調(diào)節(jié)的值調(diào)用 getAutoBrightnessValue(int sensorValue, int[] values) 方法
mLcdBacklightValues = resources.getIntArray(
com.android.internal.R.array.config_autoBrightnessLcdBacklightValues);
mButtonBacklightValues = resources.getIntArray(
com.android.internal.R.array.config_autoBrightnessButtonBacklightValues);
mKeyboardBacklightValues = resources.getIntArray(。。。。。
。。。。。。這里看起來(lái)好像是當(dāng)mUseSoftwareAutoBrightness為true時(shí)就取得config.xml文件config_autoBrightnessLevels的值,再去根據(jù)光線自動(dòng)調(diào)節(jié),但是mAutomaticAvailabl的值只是說(shuō)明有沒有自動(dòng)調(diào)節(jié)屏幕的功能(比如說(shuō)你將config.xml文件的config_automatic_brightness_available的值改為false,編譯替換framework-res.apk那么在屏幕亮度調(diào)節(jié)中將沒有自動(dòng)調(diào)節(jié)的checkbox),這也能解釋構(gòu)造函數(shù)一開始就初始化mAutomaticAvailabl的值。
接下來(lái)在BrightnessPreference.java文件中有onProgressChanged,onStartTrackingTouch(SeekBar seekBar),onStopTrackingTouch(SeekBar seekBar)方法,這些一看也能懂就不介紹了,在onBindDialogView(View view)方法中有
mCheckBox = (CheckBox)view.findViewById(R.id.automatic_mode);
if (mAutomaticAvailable) {//當(dāng)有自動(dòng)調(diào)節(jié)功能
mCheckBox.setOnCheckedChangeListener(this);//為checkbox添加監(jiān)聽事件
try {
mOldAutomatic = Settings.System.getInt(getContext().getContentResolver(),
Settings.System.SCREEN_BRIGHTNESS_MODE);
。。。。。。
主要看public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
setMode(isChecked ? Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC
: Settings.System.SCREEN_BRIGHTNESS_MODE_MANUAL);
if (!isChecked) {
setBrightness(mSeekBar.getProgress() + MINIMUM_BACKLIGHT);
}
}
這里才是你選擇自動(dòng)調(diào)節(jié)亮度的checkbox,如果選擇則setMode(Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC);并將數(shù)據(jù)存放到數(shù)據(jù)庫(kù)中。
這里是重點(diǎn):這里有個(gè)數(shù)據(jù)庫(kù),當(dāng)監(jiān)測(cè)到數(shù)據(jù)庫(kù)中的值發(fā)生改變時(shí)也就是變?yōu)镾ettings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC時(shí),就會(huì)跳到
powerManagerService.java的initInThread()中ContentResolver resolver = mContext.getContentResolver();
Cursor settingsCursor = resolver.query(Settings.System.CONTENT_URI, null,
"(" + Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?) or ("
+ Settings.System.NAME + "=?)",
new String[]{STAY_ON_WHILE_PLUGGED_IN, SCREEN_OFF_TIMEOUT, DIM_SCREEN, XEC_DLS_CONTROL,
SCREEN_BRIGHTNESS_MODE, WINDOW_ANIMATION_SCALE, TRANSITION_ANIMATION_SCALE},
null);
mSettings = new ContentQueryMap(settingsCursor, Settings.System.NAME, true, mHandler);
SettingsObserver settingsObserver = new SettingsObserver();
mSettings.addObserver(settingsObserver);
數(shù)據(jù)庫(kù)中數(shù)據(jù)發(fā)生改變時(shí)觸發(fā)事件的發(fā)生。
在 powerManagerService.java的systemReady()(只在開機(jī)調(diào)用一次就不再調(diào)用)中
if (mUseSoftwareAutoBrightness) {
Log.i("frist","frist="+"aaaa");
mLightSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_LIGHT);
enableLightSensor(true);
}
而mUseSoftwareAutoBrightness是在initInThread()線程中取得了true值,那么就到enableLightSensor(true);方法去看
if (enable) {
mSensorManager.registerListener(mLightListener, mLightSensor,
SensorManager.SENSOR_DELAY_NORMAL);
}
如果傳遞來(lái)的值為true也就是enable=true就監(jiān)聽而且用匹配屏幕方向變化的感應(yīng)SENSOR_DELAY_NORMAL。
再看mLightListener事件:SensorEventListener mLightListener = new SensorEventListener() {
public void onSensorChanged(SensorEvent event) {
synchronized (mLocks) {
int value = (int)event.values[0];//從event里面獲取當(dāng)前數(shù)據(jù)
Log.i("value","value="+value);
long milliseconds = SystemClock.elapsedRealtime();
if (mDebugLightSensor) {
Slog.d(TAG, "onSensorChanged: light value: " + value);
}
mHandler.removeCallbacks(mAutoBrightnessTask);
if (mLightSensorValue != value) {//mLightSensorValue是當(dāng)前的屏幕亮度
if (mLightSensorValue == -1 ||
milliseconds < mLastScreenOnTime + mLightSensorWarmupTime) {
// process the value immediately if screen has just turned on
lightSensorChangedLocked(value);
} else {
// delay processing to debounce the sensor
mLightSensorPendingValue = value;//mLightSensorPendingValue是準(zhǔn)備要設(shè)置的亮度
mHandler.postDelayed(mAutoBrightnessTask, LIGHT_SENSOR_DELAY);//到mAutoBrightnessTask線程去完成自動(dòng)調(diào)節(jié)
}
} else {
mLightSensorPendingValue = -1;
}
}
}
當(dāng)前屏幕亮度肯定不等與-1,所以做else中的mHandler.postDelayed(mAutoBrightnessTask, LIGHT_SENSOR_DELAY),那么我們?cè)俚絤AutoBrightnessTask
線程看:private Runnable mAutoBrightnessTask = new Runnable() {
public void run() {
synchronized (mLocks) {
int value = (int)mLightSensorPendingValue;
Log.i("mLightSensorPendingValue","mLightSensorPendingValue"+mLightSensorPendingValue);
if (value >= 0) {
mLightSensorPendingValue = -1;
lightSensorChangedLocked(value);
}
}
}
};就是不斷的去調(diào)用lightSensorChangedLocked(value)
private void lightSensorChangedLocked(int value) {
。。。。。。。
if (mLightSensorValue != value) {
mLightSensorValue = value;
if ((mPowerState & BATTERY_LOW_BIT) == 0) {
// Use light sensor value no matter it is in a dock or not.
int lcdValue = getAutoBrightnessValue(
value,
mLcdBacklightValues);// 取得mLcdBacklightValues里面的值
int buttonValue = getAutoBrightnessValue(value, mButtonBacklightValues);
int keyboardValue;
if (mKeyboardVisible) {
keyboardValue = getAutoBrightnessValue(value, mKeyboardBacklightValues);
} else {
keyboardValue = 0;
}
。。。
if (mAutoBrightessEnabled && mScreenBrightnessOverride < 0) {//設(shè)置屏幕亮度
mScreenBrightness.setTargetLocked(lcdValue, AUTOBRIGHTNESS_ANIM_STEPS,
INITIAL_SCREEN_BRIGHTNESS, (int)mScreenBrightness.curValue);
}
。。。。。
}
- Android開發(fā)實(shí)現(xiàn)調(diào)節(jié)屏幕亮度功能
- Android視頻播放器屏幕左側(cè)邊隨手指上下滑動(dòng)亮度調(diào)節(jié)功能的原理實(shí)現(xiàn)
- Android亮度調(diào)節(jié)的幾種實(shí)現(xiàn)方法
- Android編程調(diào)節(jié)屏幕亮度(背景燈)及保持背景燈常亮的方法
- Android調(diào)節(jié)屏幕亮度實(shí)現(xiàn)代碼
- android 如何設(shè)置開機(jī)后屏幕亮度默認(rèn)值為自動(dòng)調(diào)節(jié)
- 使用android隱藏api實(shí)現(xiàn)亮度調(diào)節(jié)的方法
- Android 如何實(shí)現(xiàn)亮度自動(dòng)調(diào)節(jié)
相關(guān)文章
android開發(fā)之為activity增加左右手勢(shì)識(shí)別示例
這篇文章主要介紹了android開發(fā)中為activity增加左右手勢(shì)識(shí)別示例,需要的朋友可以參考下2014-04-04Android 屏幕實(shí)現(xiàn)上下翻轉(zhuǎn)
這篇文章主要介紹了Android 屏幕實(shí)現(xiàn)上下翻轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下2017-07-07Android zxing如何識(shí)別反轉(zhuǎn)二維碼詳解
這篇文章主要給大家介紹了關(guān)于Android zxing如何識(shí)別反轉(zhuǎn)二維碼的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09ERROR/AndroidRuntime(17121)的問題解決
ERROR/AndroidRuntime(17121)的問題解決,需要的朋友可以參考一下2013-05-05Android?registerForActivityResult新用法實(shí)現(xiàn)兩個(gè)Activity間數(shù)據(jù)傳遞
這篇文章主要為大家介紹了Android?registerForActivityResult新用法實(shí)現(xiàn)兩個(gè)Activity間數(shù)據(jù)傳遞詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04Android自定義控件實(shí)現(xiàn)九宮格解鎖功能
這篇文章主要為大家詳細(xì)介紹了Android自定義控件實(shí)現(xiàn)九宮格解鎖功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05Android自定義View實(shí)現(xiàn)抖音飄動(dòng)紅心效果
這篇文章主要為大家詳細(xì)介紹了Android自定義View實(shí)現(xiàn)抖音飄動(dòng)紅心效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05淺析Android App的相對(duì)布局RelativeLayout
這篇文章主要介紹了Android App的相對(duì)布局RelativeLayout,文中舉了一個(gè)登錄界面的XML布局例子,非常直觀,需要的朋友可以參考下2016-04-04