Label rendering from svg sprite.

This commit is contained in:
József Farkas
2016-05-02 22:31:39 +02:00
parent 83074e9d88
commit 1e14de3a4e
4 changed files with 175 additions and 94 deletions

View File

@@ -4,10 +4,12 @@ import { HTTP_PROVIDERS } from 'angular2/http';
import { MainAppComponent } from './main-app.component'; import { MainAppComponent } from './main-app.component';
import {DataProviderService} from './services/data-provider.service'; import {DataProviderService} from './services/data-provider.service';
import {MapperService} from './services/mapper.service';
process.stdout = require('browser-stdout')(); process.stdout = require('browser-stdout')();
bootstrap(MainAppComponent, [ bootstrap(MainAppComponent, [
HTTP_PROVIDERS, HTTP_PROVIDERS,
DataProviderService DataProviderService,
MapperService
]).catch(err => console.error(err)); ]).catch(err => console.error(err));

View File

@@ -4,7 +4,12 @@ import {KeyAction} from '../../config-serializer/config-items/KeyAction';
import {KeystrokeAction} from '../../config-serializer/config-items/KeystrokeAction'; import {KeystrokeAction} from '../../config-serializer/config-items/KeystrokeAction';
import {KeystrokeModifiersAction, KeyModifiers} from '../../config-serializer/config-items/KeystrokeModifiersAction'; import {KeystrokeModifiersAction, KeyModifiers} from '../../config-serializer/config-items/KeystrokeModifiersAction';
import {SwitchLayerAction, LayerName} from '../../config-serializer/config-items/SwitchLayerAction'; import {SwitchLayerAction, LayerName} from '../../config-serializer/config-items/SwitchLayerAction';
import {Mapper} from '../utils/mapper'; import {MapperService} from '../services/mapper.service';
enum LabelTypes {
Text,
Path
}
@Component({ @Component({
selector: 'g[svg-keyboard-key]', selector: 'g[svg-keyboard-key]',
@@ -22,20 +27,26 @@ import {Mapper} from '../utils/mapper';
[attr.font-family]="'Helvetica'" [attr.font-family]="'Helvetica'"
[attr.fill]="'#ffffff'" [attr.fill]="'#ffffff'"
[attr.style]="'dominant-baseline: central'" [attr.style]="'dominant-baseline: central'"
*ngIf="labels && labels.length > 0"> *ngIf="(labelType === enumLabelTypes.Text) && labelSource && labelSource.length > 0">
<tspan <tspan
*ngIf="labels.length === 1" *ngIf="labelSource.length === 1"
[attr.x]="width / 2" [attr.x]="width / 2"
dy="0" dy="0"
>{{ labels[0] }}</tspan> >{{ labelSource[0] }}</tspan>
<tspan <tspan
*ngIf="labels.length === 2" *ngIf="labelSource.length === 2"
*ngFor="let label of labels; let index = index" *ngFor="let label of labelSource; let index = index"
[attr.x]="width / 2" [attr.x]="width / 2"
[attr.y]="(0.75 - index * 0.5) * height" [attr.y]="(0.75 - index * 0.5) * height"
dy="0" dy="0"
>{{ label }}</tspan> >{{ label }}</tspan>
</svg:text> </svg:text>
<svg:use [attr.xlink:href]="labelSource"
[attr.width]="width / 3" [attr.height]="height / 3"
[attr.x]="width / 3" [attr.y]="height / 3"
fill="white"
*ngIf="(labelType === enumLabelTypes.Path) && labelSource">
</svg:use>
` `
}) })
export class SvgKeyboardKeyComponent implements OnInit, OnChanges { export class SvgKeyboardKeyComponent implements OnInit, OnChanges {
@@ -46,9 +57,15 @@ export class SvgKeyboardKeyComponent implements OnInit, OnChanges {
@Input() width: string; @Input() width: string;
@Input() keyAction: KeyAction; @Input() keyAction: KeyAction;
private labels: any[]; /* tslint:disable:no-unused-variable */
/* It is used in the template */
private enumLabelTypes = LabelTypes;
/* tslint:enable:no-unused-variable */
constructor() { } private labelSource: any;
private labelType: LabelTypes;
constructor(private mapperService: MapperService) { }
ngOnInit() { ngOnInit() {
this.setLabels(); this.setLabels();
@@ -60,59 +77,70 @@ export class SvgKeyboardKeyComponent implements OnInit, OnChanges {
this.setLabels(); this.setLabels();
} }
/* tslint:enable:no-string-literal */ /* tslint:enable:no-string-literal */
} }
private setLabels(): void { private setLabels(): void {
if (!this.keyAction) { if (!this.keyAction) {
return; return;
} }
let newLabels: string[] = [];
this.labelType = LabelTypes.Text;
if (this.keyAction instanceof KeystrokeModifiersAction) { if (this.keyAction instanceof KeystrokeModifiersAction) {
let keyAction: KeystrokeModifiersAction = <KeystrokeModifiersAction> this.keyAction; let keyAction: KeystrokeModifiersAction = this.keyAction as KeystrokeModifiersAction;
let newLabelSource: string[] = [];
if (keyAction.isOnlyOneModifierActive()) { if (keyAction.isOnlyOneModifierActive()) {
switch (keyAction.modifierMask) { switch (keyAction.modifierMask) {
case KeyModifiers.leftCtrl: case KeyModifiers.leftCtrl:
case KeyModifiers.rightCtrl: case KeyModifiers.rightCtrl:
newLabels.push('Ctrl'); newLabelSource.push('Ctrl');
break; break;
case KeyModifiers.leftShift: case KeyModifiers.leftShift:
case KeyModifiers.rightShift: case KeyModifiers.rightShift:
newLabels.push('Shift'); newLabelSource.push('Shift');
break; break;
case KeyModifiers.leftAlt: case KeyModifiers.leftAlt:
case KeyModifiers.rightAlt: case KeyModifiers.rightAlt:
newLabels.push('Alt'); newLabelSource.push('Alt');
break; break;
case KeyModifiers.leftGui: case KeyModifiers.leftGui:
case KeyModifiers.rightGui: case KeyModifiers.rightGui:
newLabels.push('Super'); newLabelSource.push('Super');
break; break;
default: default:
newLabels.push('Undefined'); newLabelSource.push('Undefined');
break; break;
} }
} }
this.labelSource = newLabelSource;
} else if (this.keyAction instanceof KeystrokeAction) { } else if (this.keyAction instanceof KeystrokeAction) {
let keyAction: KeystrokeAction = <KeystrokeAction> this.keyAction; let scancode: number = (this.keyAction as KeystrokeAction).scancode;
newLabels = Mapper.scanCodeToText((keyAction as KeystrokeAction).scancode); let newLabelSource: string[] = this.mapperService.scanCodeToText(scancode);
if (newLabelSource) {
this.labelSource = newLabelSource;
} else {
this.labelSource = this.mapperService.scanCodeToSvgImagePath(scancode);
this.labelType = LabelTypes.Path;
}
} else if (this.keyAction instanceof SwitchLayerAction) { } else if (this.keyAction instanceof SwitchLayerAction) {
let keyAction: SwitchLayerAction = <SwitchLayerAction> this.keyAction; let keyAction: SwitchLayerAction = this.keyAction as SwitchLayerAction;
let newLabelSource: string[] = [];
switch (keyAction.layer) { switch (keyAction.layer) {
case LayerName.mod: case LayerName.mod:
newLabels.push('Mod'); newLabelSource.push('Mod');
break; break;
case LayerName.fn: case LayerName.fn:
newLabels.push('Fn'); newLabelSource.push('Fn');
break; break;
case LayerName.mouse: case LayerName.mouse:
newLabels.push('Mouse'); newLabelSource.push('Mouse');
break; break;
default: default:
break; break;
} }
this.labelSource = newLabelSource;
} }
this.labels = newLabels;
} }
} }

View File

@@ -0,0 +1,121 @@
import { Injectable } from 'angular2/core';
@Injectable()
export class MapperService {
private scanCodeTextMap = [
[], // 0
[], // 1
[], // 2
[], // 3
['A'], // 4
['B'], // 5
['C'], // 6
['D'], // 7
['E'], // 8
['F'], // 9
['G'], // 10
['H'], // 11
['I'], // 12
['J'], // 13
['K'], // 14
['L'], // 15
['M'], // 16
['N'], // 17
['O'], // 18
['P'], // 19
['Q'], // 20
['R'], // 21
['S'], // 22
['T'], // 23
['U'], // 24
['V'], // 25
['W'], // 26
['X'], // 27
['Y'], // 28
['Z'], // 29
['1', '!'], // 30
['2', '@'], // 31
['3', '#'], // 32
['4', '$'], // 33
['5', '%'], // 34
['6', '^'], // 35
['7', '&'], // 36
['8', '*'], // 37
['9', '('], // 38
['0', ')'], // 39
['Enter'], // 40 - Enter
['Esc'], // 41 - Escape
['←'], // 42 - Backspace
['Tab'], // 43 - Tab
['Space'], // 44 - Space
['-', '_'], // 45
['=', '+'], // 46
['[', '{'], // 47
[']', '}'], // 48
['\\', '|'], // 49
[], // 50 NON_US_HASHMARK_AND_TILDE
[';', ':'], // 51
['\'', '"'], // 52
['`', '~'], // 53
[',', '<'], // 54
['.', '>'], // 55
['/', '?'], // 56
['Caps Lock'], // 57
['F1'], // 58
['F2'], // 59
['F3'], // 60
['F4'], // 61
['F5'], // 62
['F6'], // 63
['F7'], // 64
['F8'], // 65
['F9'], // 66
['F10'], // 67
['F11'], // 68
['F12'], // 69
['PrtScn'], // 70 - Print Screen
['Scroll Lock'], // 71
['Pause'], // 72
['Insert'], // 73
['Home'], // 74
['PgUp'], // 75
['Del'], // 76
['End'], // 77
['PgDn'], // 78
undefined, // 79 Right arrow
undefined, // 80 Left arrow
undefined, // 81 Down arrow
undefined // 82 Up arrow
];
private scanCodeFileName: Map<number, string>;
constructor() {
this.initScanCodeFileName();
}
public scanCodeToText(scanCode: number): string[] {
if (this.scanCodeTextMap.length < scanCode) {
return [];
}
return this.scanCodeTextMap[scanCode];
}
public scanCodeToSvgImagePath(scanCode: number): string {
let fileName: string = this.scanCodeFileName[scanCode];
if (fileName) {
return 'build/compiled_sprite.svg#' + fileName;
}
return undefined;
}
private initScanCodeFileName(): void {
this.scanCodeFileName = new Map<number, string>();
this.scanCodeFileName[79] = 'icon-kbd__mod--arrow-right';
this.scanCodeFileName[80] = 'icon-kbd__mod--arrow-left';
this.scanCodeFileName[81] = 'icon-kbd__mod--arrow-down';
this.scanCodeFileName[82] = 'icon-kbd__mod--arrow-up';
}
}

View File

@@ -1,70 +0,0 @@
export class Mapper {
private static scanCodeMap = [
[], // 0
[], // 1
[], // 2
[], // 3
['A'], // 4
['B'], // 5
['C'], // 6
['D'], // 7
['E'], // 8
['F'], // 9
['G'], // 10
['H'], // 11
['I'], // 12
['J'], // 13
['K'], // 14
['L'], // 15
['M'], // 16
['N'], // 17
['O'], // 18
['P'], // 19
['Q'], // 20
['R'], // 21
['S'], // 22
['T'], // 23
['U'], // 24
['V'], // 25
['W'], // 26
['X'], // 27
['Y'], // 28
['Z'], // 29
['1', '!'], // 30
['2', '@'], // 31
['3', '#'], // 32
['4', '$'], // 33
['5', '%'], // 34
['6', '^'], // 35
['7', '&'], // 36
['8', '*'], // 37
['9', '('], // 38
['0', ')'], // 39
['Enter'], // 40 - Enter
['Esc'], // 41 - Escape
['←'], // 42 - Backspace
['Tab'], // 43 - Tab
['Space'], // 44 - Space
['-', '_'], // 45
['=', '+'], // 46
['[', '{'], // 47
[']', '}'], // 48
['\\', '|'], // 49
[], // 50 NON_US_HASHMARK_AND_TILDE
[';', ':'], // 51
['\'', '"'], // 52
['`', '~'], // 53
[',', '<'], // 54
['.', '>'], // 55
['/', '?'], // 56
['Caps Lock'] // 57
];
public static scanCodeToText(scanCode: number): string[] {
if (Mapper.scanCodeMap.length < scanCode) {
return [];
}
return Mapper.scanCodeMap[scanCode];
}
}