diff --git a/KeyHandler/Android.mk b/KeyHandler/Android.mk new file mode 100644 index 0000000..2a4b19b --- /dev/null +++ b/KeyHandler/Android.mk @@ -0,0 +1,30 @@ +# +# Copyright (C) 2018 The LineageOS Project +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +LOCAL_PATH := $(call my-dir) + +include $(CLEAR_VARS) + +LOCAL_SRC_FILES := $(call all-java-files-under, src) +LOCAL_PACKAGE_NAME := KeyHandler + +LOCAL_CERTIFICATE := platform +LOCAL_PRIVILEGED_MODULE := true +LOCAL_MODULE_TAGS := optional + +LOCAL_PROGUARD_ENABLED := disabled + +include $(BUILD_PACKAGE) diff --git a/KeyHandler/AndroidManifest.xml b/KeyHandler/AndroidManifest.xml new file mode 100644 index 0000000..4b74ee3 --- /dev/null +++ b/KeyHandler/AndroidManifest.xml @@ -0,0 +1,20 @@ + + + + diff --git a/KeyHandler/src/org/lineageos/settings/device/KeyHandler.java b/KeyHandler/src/org/lineageos/settings/device/KeyHandler.java new file mode 100644 index 0000000..49312a9 --- /dev/null +++ b/KeyHandler/src/org/lineageos/settings/device/KeyHandler.java @@ -0,0 +1,73 @@ +/* + * Copyright (C) 2018 The LineageOS Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.lineageos.settings.device; + +import android.content.Context; +import android.media.AudioManager; +import android.os.Vibrator; +import android.view.KeyEvent; + +import com.android.internal.os.DeviceKeyHandler; + +public class KeyHandler implements DeviceKeyHandler { + private static final String TAG = KeyHandler.class.getSimpleName(); + + // Slider key codes + private static final int MODE_NORMAL = 601; + private static final int MODE_VIBRATION = 602; + private static final int MODE_SILENCE = 603; + + private final Context mContext; + private final AudioManager mAudioManager; + private final Vibrator mVibrator; + + public KeyHandler(Context context) { + mContext = context; + + mAudioManager = mContext.getSystemService(AudioManager.class); + mVibrator = mContext.getSystemService(Vibrator.class); + } + + public KeyEvent handleKeyEvent(KeyEvent event) { + int scanCode = event.getScanCode(); + + switch (scanCode) { + case MODE_NORMAL: + mAudioManager.setRingerModeInternal(AudioManager.RINGER_MODE_NORMAL); + break; + case MODE_VIBRATION: + mAudioManager.setRingerModeInternal(AudioManager.RINGER_MODE_VIBRATE); + break; + case MODE_SILENCE: + mAudioManager.setRingerModeInternal(AudioManager.RINGER_MODE_SILENT); + break; + default: + return event; + } + doHapticFeedback(); + + return null; + } + + private void doHapticFeedback() { + if (mVibrator == null || !mVibrator.hasVibrator()) { + return; + } + + mVibrator.vibrate(50); + } +} diff --git a/common.mk b/common.mk index 021359c..3477a5b 100644 --- a/common.mk +++ b/common.mk @@ -105,6 +105,7 @@ PRODUCT_COPY_FILES += \ # tri-state-key PRODUCT_PACKAGES += \ + KeyHandler \ tri-state-key_daemon # Update engine diff --git a/overlay-lineage/lineage-sdk/lineage/res/res/values/config.xml b/overlay-lineage/lineage-sdk/lineage/res/res/values/config.xml index 7428233..1379fbc 100644 --- a/overlay-lineage/lineage-sdk/lineage/res/res/values/config.xml +++ b/overlay-lineage/lineage-sdk/lineage/res/res/values/config.xml @@ -20,6 +20,18 @@ 100 true + + + /system/priv-app/LineageParts/LineageParts.apk + /system/priv-app/KeyHandler/KeyHandler.apk + + + + + org.lineageos.lineageparts.gestures.KeyHandler + org.lineageos.settings.device.KeyHandler + +