mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 21:29:20 +08:00 
			
		
		
		
	Added: Allow users to adjust terminal horizontal and vertical margin
The `terminal-margin-horizontal` key can be used to adjust the terminal left/right margin and the `terminal-margin-vertical` can be used to adjust the terminal top/bottom margin. This will also affect drawer. The user can set an integer value between `0` and `100` as `dp` units. The default value is still `3` for horizontal and `0` for vertical margin. So adding an entry like `terminal-margin-horizontal=10` to `termux.properties` file will allow users to set a horizontal margin of `10dp`. After updating the value, either restart termux or run `termux-reload-settings` for changes to take effect. This was added since for some users text on edges would not be shown on the screen or they had screen protectors/cases that covered screen edges (Of course, that would require fixing every single app and android system UI itself, so kinda stupid to use). Moreover, horizontal margin of like `10dp` may be helpful with peek-and-slide for people having gesture navigation enabled on android `10+` since they won't be to touch at exactly the edge of the screen to trigger peek (#1325). Closes #2210
This commit is contained in:
		| @@ -12,7 +12,7 @@ import java.util.HashSet; | ||||
| import java.util.Set; | ||||
|  | ||||
| /* | ||||
|  * Version: v0.12.0 | ||||
|  * Version: v0.13.0 | ||||
|  * | ||||
|  * Changelog | ||||
|  * | ||||
| @@ -55,6 +55,9 @@ import java.util.Set; | ||||
|  * | ||||
|  * - 0.12.0 (2021-06-10) | ||||
|  *      - Add `*KEY_TERMINAL_CURSOR_STYLE*`. | ||||
|  * | ||||
|  * - 0.13.0 (2021-08-25) | ||||
|  *      - Add `*KEY_TERMINAL_MARGIN_HORIZONTAL*` and `*KEY_TERMINAL_MARGIN_VERTICAL*`. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
| @@ -173,6 +176,20 @@ public final class TermuxPropertyConstants { | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for the terminal margin on left and right in dp units */ | ||||
|     public static final String KEY_TERMINAL_MARGIN_HORIZONTAL =  "terminal-margin-horizontal"; // Default: "terminal-margin-horizontal" | ||||
|     public static final int IVALUE_TERMINAL_MARGIN_HORIZONTAL_MIN = 0; | ||||
|     public static final int IVALUE_TERMINAL_MARGIN_HORIZONTAL_MAX = 100; | ||||
|     public static final int DEFAULT_IVALUE_TERMINAL_HORIZONTAL_MARGIN = 3; | ||||
|  | ||||
|     /** Defines the key for the terminal margin on top and bottom in dp units */ | ||||
|     public static final String KEY_TERMINAL_MARGIN_VERTICAL =  "terminal-margin-vertical"; // Default: "terminal-margin-vertical" | ||||
|     public static final int IVALUE_TERMINAL_MARGIN_VERTICAL_MIN = 0; | ||||
|     public static final int IVALUE_TERMINAL_MARGIN_VERTICAL_MAX = 100; | ||||
|     public static final int DEFAULT_IVALUE_TERMINAL_VERTICAL_MARGIN = 0; | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for the terminal transcript rows */ | ||||
|     public static final String KEY_TERMINAL_TRANSCRIPT_ROWS =  "terminal-transcript-rows"; // Default: "terminal-transcript-rows" | ||||
|     public static final int IVALUE_TERMINAL_TRANSCRIPT_ROWS_MIN = TerminalEmulator.TERMINAL_TRANSCRIPT_ROWS_MIN; | ||||
| @@ -314,6 +331,8 @@ public final class TermuxPropertyConstants { | ||||
|         KEY_BELL_BEHAVIOUR, | ||||
|         KEY_TERMINAL_CURSOR_BLINK_RATE, | ||||
|         KEY_TERMINAL_CURSOR_STYLE, | ||||
|         KEY_TERMINAL_MARGIN_HORIZONTAL, | ||||
|         KEY_TERMINAL_MARGIN_VERTICAL, | ||||
|         KEY_TERMINAL_TRANSCRIPT_ROWS, | ||||
|  | ||||
|         /* float */ | ||||
|   | ||||
| @@ -219,6 +219,10 @@ public class TermuxSharedProperties { | ||||
|                 return (int) getTerminalCursorBlinkRateInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE: | ||||
|                 return (int) getTerminalCursorStyleInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_MARGIN_HORIZONTAL: | ||||
|                 return (int) getTerminalMarginHorizontalInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_MARGIN_VERTICAL: | ||||
|                 return (int) getTerminalMarginVerticalInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_TRANSCRIPT_ROWS: | ||||
|                 return (int) getTerminalTranscriptRowsInternalPropertyValueFromValue(value); | ||||
|  | ||||
| @@ -318,6 +322,42 @@ public class TermuxSharedProperties { | ||||
|         return (int) SharedProperties.getDefaultIfNotInMap(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE, TermuxPropertyConstants.MAP_TERMINAL_CURSOR_STYLE, SharedProperties.toLowerCase(value), TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_CURSOR_STYLE, true, LOG_TAG); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_MARGIN_HORIZONTAL_MIN} and | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_MARGIN_HORIZONTAL_MAX}, | ||||
|      * otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_HORIZONTAL_MARGIN}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
|      */ | ||||
|     public static int getTerminalMarginHorizontalInternalPropertyValueFromValue(String value) { | ||||
|         return SharedProperties.getDefaultIfNotInRange(TermuxPropertyConstants.KEY_TERMINAL_MARGIN_HORIZONTAL, | ||||
|             DataUtils.getIntFromString(value, TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_HORIZONTAL_MARGIN), | ||||
|             TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_HORIZONTAL_MARGIN, | ||||
|             TermuxPropertyConstants.IVALUE_TERMINAL_MARGIN_HORIZONTAL_MIN, | ||||
|             TermuxPropertyConstants.IVALUE_TERMINAL_MARGIN_HORIZONTAL_MAX, | ||||
|             true, true, LOG_TAG); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_MARGIN_VERTICAL_MIN} and | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_MARGIN_VERTICAL_MAX}, | ||||
|      * otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_VERTICAL_MARGIN}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
|      */ | ||||
|     public static int getTerminalMarginVerticalInternalPropertyValueFromValue(String value) { | ||||
|         return SharedProperties.getDefaultIfNotInRange(TermuxPropertyConstants.KEY_TERMINAL_MARGIN_VERTICAL, | ||||
|             DataUtils.getIntFromString(value, TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_VERTICAL_MARGIN), | ||||
|             TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_VERTICAL_MARGIN, | ||||
|             TermuxPropertyConstants.IVALUE_TERMINAL_MARGIN_VERTICAL_MIN, | ||||
|             TermuxPropertyConstants.IVALUE_TERMINAL_MARGIN_VERTICAL_MAX, | ||||
|             true, true, LOG_TAG); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_TRANSCRIPT_ROWS_MIN} and | ||||
| @@ -508,6 +548,14 @@ public class TermuxSharedProperties { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE, true); | ||||
|     } | ||||
|  | ||||
|     public int getTerminalMarginHorizontal() { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_MARGIN_HORIZONTAL, true); | ||||
|     } | ||||
|  | ||||
|     public int getTerminalMarginVertical() { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_MARGIN_VERTICAL, true); | ||||
|     } | ||||
|  | ||||
|     public int getTerminalTranscriptRows() { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_TRANSCRIPT_ROWS, true); | ||||
|     } | ||||
|   | ||||
| @@ -8,6 +8,7 @@ import android.graphics.Point; | ||||
| import android.graphics.Rect; | ||||
| import android.util.TypedValue; | ||||
| import android.view.View; | ||||
| import android.view.ViewGroup; | ||||
|  | ||||
| import androidx.annotation.NonNull; | ||||
| import androidx.annotation.Nullable; | ||||
| @@ -218,4 +219,18 @@ public class ViewUtils { | ||||
|         return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp, context.getResources().getDisplayMetrics()); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     public static void setLayoutMarginsInDp(@NonNull View view, int left, int top, int right, int bottom) { | ||||
|         Context context = view.getContext(); | ||||
|         setLayoutMarginsInPixels(view, dpToPx(context, left), dpToPx(context, top), dpToPx(context, right), dpToPx(context, bottom)); | ||||
|     } | ||||
|  | ||||
|     public static void setLayoutMarginsInPixels(@NonNull View view, int left, int top, int right, int bottom) { | ||||
|         if (view.getLayoutParams() instanceof ViewGroup.MarginLayoutParams) { | ||||
|             ViewGroup.MarginLayoutParams params = (ViewGroup.MarginLayoutParams) view.getLayoutParams(); | ||||
|             params.setMargins(left, top, right, bottom); | ||||
|             view.setLayoutParams(params); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user