Skip to content

Commit

Permalink
Update Calculator keyboard for greater consistency and extensibili… (#8)
Browse files Browse the repository at this point in the history
Update Calculator keyboard for greater consistency and extensibility
  • Loading branch information
grochocki authored Sep 4, 2019
2 parents e0893c0 + c5e5385 commit 5384a52
Show file tree
Hide file tree
Showing 26 changed files with 246 additions and 0 deletions.
246 changes: 246 additions & 0 deletions active/KeyboardRefresh/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,246 @@
# Update Calculator keyboard for greater consistency and extensibility

## Problem Statement
The Calculator keyboard requires some changes to meet the demands of upcoming features, including graphing mode and always-on-top mode. Furthermore, the current standard keyboard could be better at accommodating scaled screen sizes, which improves overall accessibility of the app. There are a number of other problems this spec seeks to address, including reducing confusion over the up arrow used as the shift key and reducing the number of keyboard layout states.

## Evidence or User Insights
The current keyboard is not scalable to support new minimum size requirements for CompactOverlay mode, nor is it extensible to support additional functionality in graphing calculator.

## Proposal
Update they keyboard app-wide for increased consistency and greater extensibility to prepare for upcoming feature improvements.

## Goals and Non-Goals
**Goals**
* No functionality takebacks in existing calculator modes
* Opportunistically add missing functionality across modes
* Increase clarity around shifted operations

**Non-Goals**
* Changes to display option buttons are out of scope (e.g., BYTE/WORD mode in programmer calculator), unless the button is better suited to be included in the keyboard

## Success Criteria
Success here is unblocking future feature development and improving overall accessibility.

## Feature Requirements
| Priority | Requirement |
|:-:|:-|
| P1 | Keyboard in Standard mode is updated to new layout and styling |
| P1 | Keyboard in Scientific mode is updated to new layout and styling |
| P1 | Keyboard in Programmer mode is updated to new layout and styling |
| P1 | Keyboard in Converters are updated to new layout and styling |
| P1 | Create new Operator Overflow Panel and operator groupings |
| P1 | Calculator font updated with new/updated icons to support keyboard changes |
| P2 | Add support for X-Y focus keyboard navigation using arrow keys |
| P2 | Keyboard in Graphing Mode added with new layout and styling |

## Feature Details and High-Fidelity Concept
![Scientific Calculator After](./scientificAfter.png)

<details><summary>Standard Mode</summary>

### Standard Mode
Standard Calculator functionality which offers basic operations and evaluates commands immediately as they are entered.

|![Standard Calculator Before](./standardBefore.png)|![Standard Calculator After](./standardAfter.png)| ![Standard Calculator Annotated Changes](./standardAnnotated.png)|
|:-:|:-:|:-:|
| Before | After | Annotated |

**Red Region - Number Pad**
* Standard number pad across all keyboards
* Button styling extended to sign and decimal buttons

**Green Region - Operator Pad**
* Core arithmetic operators always grouped and ordered the same across all keyboards
* “Submit” button is always bottom-right corner across all keyboards
* “Submit” button has styling applied to draw user attention

**Yellow Region - Backspace/Clear**
* Backspace and clear buttons moved to upper-right corner across all keyboards

**Black Region - Mode-specific**
* Space not used by common keyboard components are reserved for mode-specific buttons
* Like operators are grouped together, when possible
</details>

<details><summary>Scientific Mode</summary>

### Scientific Mode
Scientific Calculator functionality which offers expanded operations and evaluates commands using order of operations.

|![Scientific Calculator Before](./scientificBefore.png)|![Scientific Calculator After](./scientificAfter.png)|![Scientific Calculator Annotated Changes](./scientificAnnotated.png)|
|:-:|:-:|:-:|
| Before | After | Annotated |

**Red Region - Shifted Operators**
* In supported keyboards, 2<sup>nd</sup> bar will always appear here in this grouping
* Shifted operations have visual treatment applied
* Shifted operations must either be the inverse operation or a variation of unshifted operator
* Adding cubes and cubic root buttons
* Adding 2<sup>x</sup> button
* Adding log<sup>x</sup>y button

**Yellow Region - Backspace/Clear**
* Outside of Standard mode, we combine CE and C buttons into one
* By default, “CE” will appear to allow user to clear everything
* Once there is input, “C” will appear instead to allow user to clear current input

**Green Region - Parenthesis**
* In supported keyboards, parenthesis will always appear here in this grouping

**Orange Region - Operator Groups**
* Modes with rich functionality will utilize a new operator overflow panel for easy access to sets of operators
* Operator groups are consistent between modes
* Scientific has following overflow operator groups
* Trig (sin, cos, tan, sec, csc, cot, with hyperbolics and inverse variants)
* Functions (abs, floor, ceil, rand, dms, deg)
* See overflow panel section for more details

**Purple Region - New Operators**
* Add absolute value to scientific calculator

**Black Region - Mode-specific**
* Space not used by common keyboard components are reserved for mode-specific buttons
* Like operators are grouped together, when possible
</details>

<details><summary>Programmer Mode</summary>

### Programmer Mode
Programmer Calculator functionality which offers common mathematical operations for developers including conversion between common bases.

|![Programmer Calculator Before](./programmerBefore.png)|![Programmer Calculator After](./programmerAfter.png)|![Programmer Calculator Annotated Changes](./programmerAnnotated.png)|
|:-:|:-:|:-:|
| Before | After | Annotated |

**Red Region - HEX Values**
* A-F buttons available for HEX input along left side
* Use same style as number pad

**Orange Region - Operator Groups**
* Programmer has following overflow operator groups
* Bitwise Operators
* Bit Shifts
* Adding support for NAND, NOR and XNOR bitwise operators
* Adding support for logical left/right and rotate through carry circular left/right bit sifts
* See overflow panel slide for more details

**Yellow Region - Decimal**
* Decimal key disabled in programmer mode (same as today)

**Purple Region - New Shift Behavior**
* Adding Left and Right Shift buttons, since those can be done in rapid succession. Option to change shift mode moved to operator group.
* Indicator will display when non-default shift is active in upper-right corner.

**Black Region - Mode-specific**
* Space not used by common keyboard components are reserved for mode-specific buttons
* Like operators are grouped together, when possible
</details>

<details><summary>Converters</summary>

### Converters
Conversion between many units of measurement.

|![Converter Before](./converterBefore.png)|![Converter After](./converterAfter.png)|![Converter Annotated Changes](./converterAnnotated.png)|
|:-:|:-:|:-:|
| Before | After | Annotated |

**Red Region - Sign Button**
* Sign button should only appear in supported modes and is enabled for all data types that support negative values:
* Temperature (sub-zero temperatures; when input is Kelvin, disable sign button)
* Power (time-rate of energy, which can be negative)
* Angle (negative angles)
* Decimal Button should be enabled for all conversations (no change)
</details>

<details><summary>Graphing Mode</summary>

### Graphing Mode (_new_)

|![Graphing Calculator](./graphingAfter.png)|![Graphing Calculator Annotated Changes](./graphingAnnotated.png)|
|:-:|:-:|
| After | Annotated |

**Orange Region - Operator Groups**
* Graphing has following overflow operator groups
* Trig (same as Scientific)
* Inequalities (=, <, <=, >, >=)
* Functions (floor, ceil, and abs)
* See overflow panel slide for more details

**Red Region - Variables**
* X and Y are special variables exposed top-level

**Green Region - Equals and Submit**
* In graphing mode, the equals button means something else, so the “submit” button is replaced with a submit/enter button to plot the equation in bottom-right corner
* The “=“ button is exposed top-level (also included in variables operator overflow group)

**Black Region - Mode-specific**
* Space not used by common keyboard components are reserved for mode-specific buttons
* Like operators are grouped together, when possible
</details>

<details><summary>Operator Panels</summary>

### Operator Panels
|![Operator Panel](./operatorPanel.png)|![Operator Panel](./operatorPanelAnnotated.png)|
|:-:|:-:|
| After | Annotated |

**Red Region - Operator Panel**
* Operator groups ordered from most common to least common
* For small screen sizes or long localized strings, operator groups should overflow off the side and FlipView-like arrow buttons will appear (you can also scroll)

**Green Region - Toggle Buttons**
* Toggle button pattern with chevron flip to indicate toggle state

**Orange Region - Flyout**
* Panel is light-dismissible and closes if user clicks a button
* Buttons follow same styling as other keyboard buttons

#### Trig
![Operator Panel](./operatorPanelTrigAnnotated.png)

#### Functions
![Operator Panel](./operatorPanelFunctionsAnnotated.png)

* Graphing mode only has abs, floor, and ceil

#### Inequalities
![Operator Panel](./operatorPanelInequalitiesAnnotated.png)

#### Bitwise Operators
![Operator Panel](./operatorPanelBitwiseAnnotated.png)

#### Bit Shifts
![Operator Panel](./operatorPanelShiftOptions.png)

* Default to Arithmetic Shift every time you enter programmer mode
* If user changes option, preserve through mode session (i.e., if they leave and come back, reset)

</details>

<details><summary>Scaling</summary>

### Scaling
We are reducing the number of distinct keyboard layout states to _two_.

![Scaling Keyboard](./scaling.png)

* Subtitle (20)/Title (24) font size for buttons/numpad buttons on small (320x320) and medium (640x640) layouts
* Sub-Header (34)/Header (48) font size for buttons/numpad buttons on large (1080x1080) layouts

</details>

<details><summary>Accessibility</summary>

### Accessibility
* Add support for X-Y focus navigation when focus is inside of any keyboard area (including overflow panels)
* Addresses feedback from recent Calculator accessibility review as one of the issues preventing us from achieving an “A” rating

![Keyboard Accessibility](./accessibility.png)
</details>

_**Note:** Strings and icons above are not final._

![needs glyph marker](./needsGlyphKey.png)
Binary file added active/KeyboardRefresh/accessibility.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/converterAfter.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/converterAnnotated.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/converterBefore.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/graphingAfter.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/graphingAnnotated.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/miniProofOfConcept.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/needsGlyphKey.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/operatorPanel.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/programmerAfter.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/programmerAnnotated.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/programmerBefore.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/scaling.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/scientificAfter.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/scientificAnnotated.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/scientificBefore.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/standardAfter.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/standardAnnotated.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added active/KeyboardRefresh/standardBefore.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 5384a52

Please sign in to comment.