abouttreesummaryrefslogcommitdiff
diff options
context:
space:
mode:
authorJules Aguillon2024-02-28 23:19:50 +0100
committerJules Aguillon2024-02-28 23:19:50 +0100
commit8b5d971fb5d9b091823509b096fa9a44f4003cee (patch)
tree8ea42bb3410a35f192135c2b20b0cdfa5ee64eac
parent8c7559d8f6bde569f139b3b6b9a79f84160ab425 (diff)
downloadunexpected-keyboard-8b5d971fb5d9b091823509b096fa9a44f4003cee.tar.gz
unexpected-keyboard-8b5d971fb5d9b091823509b096fa9a44f4003cee.zip
Modify the number row according to the numpad script
The same way as the numpad is modified.
-rw-r--r--srcs/juloo.keyboard2/Config.java36
-rw-r--r--srcs/juloo.keyboard2/KeyboardData.java4
2 files changed, 27 insertions, 13 deletions
diff --git a/srcs/juloo.keyboard2/Config.java b/srcs/juloo.keyboard2/Config.java
index a63df84..70ccb94 100644
--- a/srcs/juloo.keyboard2/Config.java
+++ b/srcs/juloo.keyboard2/Config.java
@@ -223,9 +223,11 @@ public final class Config
extra_keys_subtype.compute(extra_keys,
new ExtraKeys.Query(kw.script, present));
}
- boolean number_row = this.number_row && !show_numpad;
- if (number_row)
- remove_keys.addAll(KeyboardData.number_row.getKeys(0).keySet());
+ KeyboardData.Row number_row = null;
+ if (this.number_row && !show_numpad)
+ number_row = modify_number_row(KeyboardData.number_row, kw);
+ if (number_row != null)
+ remove_keys.addAll(number_row.getKeys(0).keySet());
kw = kw.mapKeys(new KeyboardData.MapKeyValues() {
public KeyValue apply(KeyValue key, boolean localized)
{
@@ -278,8 +280,8 @@ public final class Config
});
if (show_numpad)
kw = kw.addNumPad(modify_numpad(KeyboardData.num_pad, kw));
- if (number_row)
- kw = kw.addNumberRow();
+ if (number_row != null)
+ kw = kw.addTopRow(number_row);
if (extra_keys.size() > 0)
kw = kw.addExtraKeys(extra_keys.entrySet().iterator());
return kw;
@@ -328,12 +330,10 @@ public final class Config
});
}
- /** Modify the pin entry layout. [main_kw] is used to map the digits into the
- same script. */
- public KeyboardData modify_pinentry(KeyboardData kw, KeyboardData main_kw)
+ static KeyboardData.MapKeyValues numpad_script_map(String numpad_script)
{
- final KeyModifier.Map_char map_digit = KeyModifier.modify_numpad_script(main_kw.numpad_script);
- return kw.mapKeys(new KeyboardData.MapKeyValues() {
+ final KeyModifier.Map_char map_digit = KeyModifier.modify_numpad_script(numpad_script);
+ return new KeyboardData.MapKeyValues() {
public KeyValue apply(KeyValue key, boolean localized)
{
switch (key.getKind())
@@ -346,7 +346,21 @@ public final class Config
}
return key;
}
- });
+ };
+ }
+
+ /** Modify the pin entry layout. [main_kw] is used to map the digits into the
+ same script. */
+ public KeyboardData modify_pinentry(KeyboardData kw, KeyboardData main_kw)
+ {
+ return kw.mapKeys(numpad_script_map(main_kw.numpad_script));
+ }
+
+ /** Modify the number row according to [main_kw]'s script. */
+ public KeyboardData.Row modify_number_row(KeyboardData.Row row,
+ KeyboardData main_kw)
+ {
+ return row.mapKeys(numpad_script_map(main_kw.numpad_script));
}
private float get_dip_pref(DisplayMetrics dm, String pref_name, float def)
diff --git a/srcs/juloo.keyboard2/KeyboardData.java b/srcs/juloo.keyboard2/KeyboardData.java
index 3cbd4aa..af432b7 100644
--- a/srcs/juloo.keyboard2/KeyboardData.java
+++ b/srcs/juloo.keyboard2/KeyboardData.java
@@ -132,10 +132,10 @@ public final class KeyboardData
return new KeyboardData(this, extendedRows);
}
- public KeyboardData addNumberRow()
+ public KeyboardData addTopRow(Row row)
{
ArrayList<Row> rows_ = new ArrayList<Row>(this.rows);
- rows_.add(0, number_row.updateWidth(keysWidth));
+ rows_.add(0, row.updateWidth(keysWidth));
return new KeyboardData(this, rows_);
}