1. 信息-设置-通知-重要程度-中(不发出提示音),非锁屏界面下无提示通知框弹出
vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/phone/StatusBar.java
method:shouldPeek
@@ -7578,8 +7578,8 @@ private PowerManager.WakeLock mNotificationWakeLock; } // Allow peeking for DEFAULT notifications only if we're on Ambient Display. - int importanceLevel = isDozing() ? NotificationManager.IMPORTANCE_DEFAULT - : NotificationManager.IMPORTANCE_HIGH; + int importanceLevel = NotificationManager.IMPORTANCE_LOW/*devin.20180510 isDozing() ? NotificationManager.IMPORTANCE_DEFAULT + : NotificationManager.IMPORTANCE_HIGH;*/ if (mNotificationData.getImportance(sbn.getKey()) < importanceLevel) { if (true/**DEBUG*/) Log.d(TAG, "No peeking: unimportant notification: " + sbn.getKey()); return false;
2. 关机动画播放时长/关机时长/关机动画播放不全
vendor/mediatek/proprietary/frameworks/base/services/core/java/com/mediatek/server/MtkShutdownThread.java
method:showCustomizedShutdownAnimation
- private static final int MIN_SHUTDOWN_ANIMATION_PLAY_TIME = 5 * 1000; + private static final int MIN_SHUTDOWN_ANIMATION_PLAY_TIME = 10 * 1000;//devin.20180510 beginAnimationTime = 0; boolean mShutOffAnimation = configShutdownAnimation(context); - int screenTurnOffTime = getScreenTurnOffTime(context); + int screenTurnOffTime = MIN_SHUTDOWN_ANIMATION_PLAY_TIME;//getScreenTurnOffTime(context);devin.20180510 synchronized (mEnableAnimatingSync) { if (mEnableAnimating) { if (mShutOffAnimation) {
3. 灭屏状态下收到短信、蓝牙收到文件,屏幕亮屏
vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/phone/StatusBar.java
+private PowerManager.WakeLock mNotificationWakeLock; public void onAsyncInflationFinished(Entry entry) { mPendingNotifications.remove(entry.key); // If there was an async task started after the removal, we don't want to add it back to // the list, otherwise we might get leaks. boolean isNew = mNotificationData.get(entry.key) == null; + //devin.20180424 + mNotificationWakeLock = mPowerManager.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP
+ | PowerManager.ON_AFTER_RELEASE, TAG); + //end + mNotificationWakeLock.setReferenceCounted(false); if (isNew && !entry.row.isRemoved()) { protected void addNotificationViews(Entry entry) { if (entry == null) { return; } // Add the expanded view and icon. mNotificationData.add(entry); Log.d(TAG, "packgename:"+entry.key); + //devin.20180424 + if (!mPowerManager.isScreenOn() && entry.key != null && (entry.key.contains("com.google.android.apps.messaging")
+ || entry.key.contains("com.android.bluetooth"))){ + mNotificationWakeLock.acquire(5000); + Log.d(TAG, "special app notification turn screen on"); + } + //end updateNotifications(); } public void updateNotification(StatusBarNotification notification, RankingMap ranking) throws InflationException { ...... if (entry == null) { return; } mNotificationData.add(entry); + //devin.20180424 + if (!mPowerManager.isScreenOn() && entry.key != null && (entry.key.contains("com.google.android.apps.messaging")
+ || entry.key.contains("com.android.bluetooth"))){ + mNotificationWakeLock.acquire(5000); + Log.d(TAG, "special app notification turn screen on"); + } + //end mHeadsUpEntriesToRemoveOnSwitch.remove(entry); mRemoteInputEntriesToRemoveOnCollapse.remove(entry); ......
4. 默认音量
frameworks/base/media/java/android/media/AudioSystem.java
@@ -866,11 +866,11 @@ public class AudioSystem */ public static int[] DEFAULT_STREAM_VOLUME = new int[] { 4, // STREAM_VOICE_CALL - 15, // STREAM_SYSTEM - 15, // STREAM_RING - 15, // STREAM_MUSIC - 15, // STREAM_ALARM - 15, // STREAM_NOTIFICATION + 12, // STREAM_SYSTEM + 12, // STREAM_RING + 12, // STREAM_MUSIC + 12, // STREAM_ALARM + 12, // STREAM_NOTIFICATION
多媒体音量
frameworks/base/services/core/java/com/android/server/audio/AudioService.java
@@ -712,7 +712,7 @@ public class AudioService extends IAudioService.Stub MAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 4; } else { AudioSystem.DEFAULT_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] = - MAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 3; + /*MAX_STREAM_VOLUME[AudioSystem.STREAM_MUSIC] / 3*/ 12;//devin.20180509 } }
5. 默认亮度
vendor/mediatek/proprietary/packages/apps/SettingsProvider/res/values/defaults.xml
+158
6. 去掉设置-应用和通知-查看全部23个应用-信息-应用通知-应用中的其他设置
vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/android/settings/notification/NotificationSettingsBase.java
protected void addAppLinkPref() { - if (mAppRow.settingsIntent != null && mAppLink == null) { + Log.i("joyatel","pkg:"+mAppRow.pkg); + if (mAppRow.settingsIntent != null && mAppLink == null && !mAppRow.pkg.equals("com.google.android.apps.messaging")/*devin.20180507*/) { addPreferencesFromResource(R.xml.inapp_notification_settings); mAppLink = (Preference) findPreference(KEY_APP_LINK);
7. 打开设置-存储中的默认存储器菜单及功能
vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/mediatek/settings/deviceinfo/StorageSettingsExts.java
@@ -57,13 +57,14 @@ public class StorageSettingsExts { mDiskCategory = (PreferenceCategory) mRoot .findPreference(KEY_DEFAULT_WRITE_DISK); - if (!FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) { + if (FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) { mRoot.removePreference(mDiskCategory); } } private void updateDefaultWriteDiskCategory() { - if (!FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) { + Log.i("devin","MTK_A1_FEATURE:"+FeatureOption.MTK_A1_FEATURE); + if (FeatureOption.MTK_DEFAULT_WRITE_DISK || FeatureOption.MTK_A1_FEATURE) { return; }
vendor/mediatek/proprietary/frameworks/base/core/java/com/mediatek/storage/StorageManagerEx.java
@@ -101,8 +101,15 @@ public class StorageManagerEx { boolean supportMultiUsers = false; // Modifications for O1.BSP+ as default path feature is not supported. - path = Environment.getExternalStorageDirectory().getAbsolutePath(); + //devin.20180424 + // path = Environment.getExternalStorageDirectory().getAbsolutePath(); + path = SystemProperties.get(PROP_SD_DEFAULT_PATH); + Log.i(TAG,"path1:"+path); + if(path.equals("")){ + path = Environment.getExternalStorageDirectory().getAbsolutePath(); + } Log.i(TAG, " Default path taken as primary storage, path=" + path); + //devin.20180424 // Modifications complete for O1.BSP+. return path;
通话录音、FM录音默认存储跟随设置
vendor/mediatek/proprietary/packages/apps/FMRadio/src/com/android/fmradio/FmUtils.java
+import com.mediatek.storage.StorageManagerEx; @@ -201,7 +202,8 @@ public class FmUtils { * @return The phone storage path */ public static String getDefaultStoragePath() { - return Environment.getExternalStorageDirectory().getPath(); + // return Environment.getExternalStorageDirectory().getPath(); + return StorageManagerEx.getDefaultPath(); //devin.20180424 }
vendor/mediatek/proprietary/packages/services/CallRecorderService/src/com/mediatek/callrecorder/Recorder.java
@@ -116,8 +116,8 @@ public abstract class Recorder implements OnErrorListener { SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd_HH.mm.ss"); String prefix = dateFormat.format(new Date()); - //File sampleDir = new File(StorageManagerEx.getDefaultPath()); - File sampleDir = Environment.getExternalStorageDirectory(); + File sampleDir = new File(StorageManagerEx.getDefaultPath());//devin.20180424 + //File sampleDir = Environment.getExternalStorageDirectory();
8. 相机设置拍照预览默认4:3
vendor/mediatek/proprietary/packages/apps/Camera/src/com/android/camera/bridge/CameraDeviceExt.java
@@ -190,7 +190,8 @@ public class CameraDeviceExt implements ICameraDeviceExt { mParametersExt); if (supportedRatios != null && supportedRatios.size() > 0) { SharedPreferences.Editor editor = mPreferences.edit(); - String ratioString = supportedRatios.get(supportedRatios.size() - 1); + //String ratioString = supportedRatios.get(supportedRatios.size() - 1); + String ratioString = supportedRatios.get(0);//devin.2018420 editor.putString(SettingConstants.KEY_PICTURE_RATIO, ratioString); editor.apply(); pictureRatio = ratioString;
vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/setting/SettingUtils.java
@@ -259,7 +259,8 @@ public class SettingUtils { String ratioString = null; if (supportedRatios != null && supportedRatios.size() > 0) { SharedPreferences.Editor editor = sharedPreferences.edit(); - ratioString = supportedRatios.get(supportedRatios.size() - 1); + //ratioString = supportedRatios.get(supportedRatios.size() - 1); + ratioString = supportedRatios.get(0);//devin.20180420 editor.putString(SettingConstants.KEY_PICTURE_RATIO, ratioString); editor.apply();
9. 文件默认显示内部存储设备
public static boolean mustShowDeviceRoot(Intent intent) { /// M: Discussed with QA, this option should always be shown - return false; + return true;//devin.20180423 //return intent.getBooleanExtra(DocumentsContract.EXTRA_SHOW_ADVANCED, false); }
10. Camera 屏蔽高温报警和连拍
vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/AdditionManager.java
@@ -78,12 +78,12 @@ public class AdditionManager { mIContinuousShotAddition = new ContinuousShot(cameraContext); mDistanceInfo = new DistanceInfo(cameraContext); mRemoteCameraAddition = new RemoteCameraAddition(cameraContext); - mNormalAddition.add(new ThermalThrottle(cameraContext)); + // mNormalAddition.add(new ThermalThrottle(cameraContext)); mPhotoAddtion.add(new Asd(cameraContext)); - mPhotoAddtion.add(mIContinuousShotAddition); + //mPhotoAddtion.add(mIContinuousShotAddition); mNormalAddition.add(mDistanceInfo); mPhotoAddtion.add(mRemoteCameraAddition); - mDenoiseAddition.add(mIContinuousShotAddition); + // mDenoiseAddition.add(mIContinuousShotAddition); }
vendor/mediatek/proprietary/packages/apps/Camera/src/com/mediatek/camera/addition/thermalthrottle/ThermalThrottle.java
@@ -148,7 +148,7 @@ public class ThermalThrottle extends CameraAddition { private void updateCountDownTime(final Activity activity) { Log.d(TAG, "[updateCountDownTime]mCountDown = " + mWatingTime + ",mIsResumed = " + mIsResumed); - if (isTemperTooHigh()) { + if (false/**isTemperTooHigh()**/) { if (mWatingTime > 0) { mWatingTime--; mAlertDialog.setCountDownTime(String.valueOf(mWatingTime));
11. 低电量不能开启手电筒
vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/FlashlightControllerImpl.java
+import android.os.BatteryManager; +import android.widget.Toast; public void setFlashlight(boolean enabled) { + BatteryManager batteryManager=(BatteryManager)mContext.getSystemService(mContext.BATTERY_SERVICE); + int counter = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CHARGE_COUNTER); + int averge = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CURRENT_AVERAGE); + int current_now = batteryManager.getIntProperty(BatteryManager.BATTERY_PROPERTY_CURRENT_NOW); + Log.d(TAG,"FlashlightControllerImpl::setFlashlight...counter:"+counter+", averge:"+averge+", current_now:"+current_now); + + boolean enoughtBatteryLevel = counter >= 3; + if(!enoughtBatteryLevel){ + Toast.makeText(mContext, "low battery level", 3000).show(); + } + + enabled = enabled&enoughtBatteryLevel; boolean pendingError = false; synchronized (this) { if (mCameraId == null) return;
12. 添加虚拟键振动功能
frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java
@@ -6097,7 +6097,7 @@ public class PhoneWindowManager implements WindowManagerPolicy { } boolean useHapticFeedback = down - && (policyFlags & WindowManagerPolicy.FLAG_VIRTUAL) != 0 + // && (policyFlags & WindowManagerPolicy.FLAG_VIRTUAL) != 0 && event.getRepeatCount() == 0;
13. 去掉关闭网络数据时的叉号
vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/TelephonyIcons.java
- static final int ICON_DATA_DISABLED = R.drawable.stat_sys_data_disabled; + static final int ICON_DATA_DISABLED = -1/**R.drawable.stat_sys_data_disabled**/; - static final int QS_ICON_DATA_DISABLED = R.drawable.ic_qs_data_disabled; + static final int QS_ICON_DATA_DISABLED = -1/**R.drawable.ic_qs_data_disabled**/;
14. 切换语言后设置中的"勿扰偏好设置"菜单下的自动规则字符串不刷新
frameworks/base/services/core/java/com/android/server/notification/NotificationManagerService.java
@@ -818,8 +818,9 @@ public class NotificationManagerService extends SystemService { @Override public void onReceive(Context context, Intent intent) { if (Intent.ACTION_LOCALE_CHANGED.equals(intent.getAction())) { - mZenModeHelper.updateDefaultZenRules(); + //mZenModeHelper.updateDefaultZenRules(); devin.2018419 mRankingHelper.onLocaleChanged(context, ActivityManager.getCurrentUser()); + mZenModeHelper = new ZenModeHelper(getContext(), mHandler.getLooper(), mConditionProviders);//devin.2018419 } } };
15. 客制化BT,WiFi direct,WLAN热点名称
BT:device/generic/common/bluetooth/bdroid_buildcfg.h
-#define BTM_DEF_LOCAL_NAME "Android Bluedroid" +#define BTM_DEF_LOCAL_NAME "Vox_5S"
WiFi direct:vendor/mediatek/proprietary/packages/apps/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java
@@ -2659,6 +2659,8 @@ class DatabaseHelper extends SQLiteOpenHelper { loadSetting(stmt, Settings.Global.ENHANCED_4G_MODE_ENABLED, ImsConfig.FeatureValueConstants.ON); + loadSetting(stmt, Settings.Global.WIFI_P2P_DEVICE_NAME,"Vox_5S"); + /// M: Load MTK added Global providers before Android M. mUtils.loadCustomGlobalSettings(stmt);
WLAN热点:frameworks/opt/net/wifi/service/java/com/android/server/wifi/WifiApConfigStore.java
@@ -207,8 +207,9 @@ public class WifiApConfigStore { */ private WifiConfiguration getDefaultApConfiguration() { WifiConfiguration config = new WifiConfiguration(); - config.SSID = mContext.getResources().getString( - R.string.wifi_tether_configure_ssid_default) + "_" + getRandomIntForDefaultSsid(); + //config.SSID = mContext.getResources().getString( + // R.string.wifi_tether_configure_ssid_default) + "_" + getRandomIntForDefaultSsid(); + config.SSID = "Vox_5S"; config.allowedKeyManagement.set(KeyMgmt.WPA2_PSK); String randomUUID = UUID.randomUUID().toString(); //first 12 chars from xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx
16. 12小时制,锁屏/状态栏增加A/PM显示
锁屏:vendor/mediatek/proprietary/packages/apps/SystemUI/res-keyguard/values/strings.xml
-h:mm +aa
vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/keyguard/KeyguardStatusView.java
@@ -308,9 +308,9 @@ public class KeyguardStatusView extends GridLayout { clockView12 = DateFormat.getBestDateTimePattern(locale, clockView12Skel); // CLDR insists on adding an AM/PM indicator even though it wasn't in the skeleton // format. The following code removes the AM/PM indicator if we didn't want it. - if (!clockView12Skel.contains("a")) { + /* meng if (!clockView12Skel.contains("a")) { clockView12 = clockView12.replaceAll("a", "").trim(); - } + }*/ clockView24 = DateFormat.getBestDateTimePattern(locale, clockView24Skel);
状态栏:vendor/mediatek/proprietary/packages/apps/SystemUI/src/com/android/systemui/statusbar/policy/Clock.java
@@ -108,8 +108,9 @@ public class Clock extends TextView implements DemoMode, Tunable, CommandQueue.C try { mSystemUIFactoryBase = OpSystemUICustomizationFactoryBase.getOpFactory(context); mStatusBarExt = mSystemUIFactoryBase.makeSystemUIStatusBar(context); - mAmPmStyle = mStatusBarExt.getClockAmPmStyle(a.getInt(R.styleable.Clock_amPmStyle, - AM_PM_STYLE_GONE)); + //mAmPmStyle = mStatusBarExt.getClockAmPmStyle(a.getInt(R.styleable.Clock_amPmStyle, + // AM_PM_STYLE_GONE)); + mAmPmStyle = AM_PM_STYLE_NORMAL; mShowDark = a.getBoolean(R.styleable.Clock_showDark, true); } finally { a.recycle();
17. 长按Home键 取消屏幕固定
frameworks/base/core/res/res/values/strings.xml
-To unpin this screen, touch & hold Back and Overview - buttons +To unpin this screen, touch & hold Home buttons
vendor/mediatek/proprietary/packages/apps/SystemUI/res/values/strings.xml
-This keeps it in view until you unpin. Touch & hold Back and Overview to unpin. +This keeps it in view until you unpin. Touch & hold Home to unpin.
frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java
+import android.app.IActivityManager; +import android.view.accessibility.AccessibilityManager; +import android.view.accessibility.AccessibilityManager.AccessibilityServicesStateChangeListener; +import android.app.ActivityManagerNative; + private void onLongPressBackMenu(){ + IActivityManager activityManager = ActivityManagerNative.getDefault(); + boolean touchExplorationEnabled = mAccessibilityManager.isTouchExplorationEnabled(); + try { + boolean inLockTaskMode = activityManager.isInLockTaskMode(); + Log.d("joyatel","onLongPressBackMenu......inLockTaskMode:"+inLockTaskMode+", touchExplorationEnabled:"+touchExplorationEnabled); + if (inLockTaskMode && !touchExplorationEnabled) { + activityManager.stopLockTaskMode(); + } + + + } catch (RemoteException e) { + Log.d(TAG, "Unable to reach activity manager", e); + } + + + } @@ -3488,6 +3511,7 @@ public class PhoneWindowManager implements WindowManagerPolicy { } else if ((event.getFlags() & KeyEvent.FLAG_LONG_PRESS) != 0) { if (!keyguardOn) { handleLongPressOnHome(event.getDeviceId()); + onLongPressBackMenu(); } }
18. 联系人-任意联系人-设置-设置铃声-默认铃声的状态下点击添加铃声,返回后没有焦点packages/providers/MediaProvider/src/com/android/providers/media/RingtonePickerActivity.ja+ ///devin.20180518 @{
+ protected void onResume() {
+ super.onResume();
+ requeryForAdapter();
+ }
+ ///@}
private void requeryForAdapter() {
// Refresh and set a new cursor, closing the old one.
initRingtoneManager();
mAdapter.changeCursor(mCursor);
// Update checked item location.
- int checkedPosition = POS_UNKNOWN;
+ int checkedPosition = /*POS_UNKNOWN*/getCheckedItem();//devin.20180518
for (int i = 0; i < mAdapter.getCount(); i++) {
if (mAdapter.getItemId(i) == mCheckedItemId) {
checkedPosition = getListPosition(i);
19.主界面hotseat打开相机,底部有白线
packages/apps/Launcher3/src/com/android/launcher3/Launcher.java
@@ -2672,6 +2672,7 @@ public class Launcher extends BaseActivity
// private contract between launcher and may be ignored in the future).
boolean useLaunchAnimation = (v != null) &&
!intent.hasExtra(INTENT_EXTRA_IGNORE_LAUNCH_ANIMATION);
+ useLaunchAnimation = false; //andy
Bundle optsBundle = useLaunchAnimation ? getActivityLaunchOptions(v) : null;
UserHandle user = item == null ? null : item.user;
20. 默认SIM卡短信设置去掉每次都询问
vendor/mediatek/proprietary/packages/apps/MtkSettings/ext/src/com/mediatek/settings/ext/DefaultRCSSettings.java
public boolean isNeedAskFirstItemForSms() { Log.d("@M_" + TAG, "isNeedAskFirstItemForSms"); - return true; + return false;///mh.20180523 default=true }
vendor/mediatek/proprietary/packages/apps/MtkSettings/src/com/android/settings/sim/SimDialogActivity.java
private int getPickSmsDefaultSub(final ListsubInfoList, int value) { int subId = SubscriptionManager.INVALID_SUBSCRIPTION_ID; if (value < 1) { int length = subInfoList == null ? 0 : subInfoList.size(); //if (length == 1) {mh.20180528 subId = subInfoList.get(value).getSubscriptionId(); //} else { // subId = MtkDefaultSmsSimSettings.ASK_USER_SUB_ID; //} } else if (value >= 1 && value < subInfoList.size() + 1) { subId = subInfoList.get(value).getSubscriptionId(); } subId = mRCSExt.getDefaultSmsClickContentExt(subInfoList, value, subId); Log.d(TAG, "getPickSmsDefaultSub, value: " + value + ", subId: " + subId); return subId; }