mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-11 14:30:08 +00:00
Beginnings of key handling for Apple2Mac
This commit is contained in:
parent
6c63c49d09
commit
a42a10eb86
@ -18,6 +18,8 @@
|
|||||||
#define NIB_PROPERTIES @".nib 232960 bytes"
|
#define NIB_PROPERTIES @".nib 232960 bytes"
|
||||||
#define GZ_EXTENSION @"gz"
|
#define GZ_EXTENSION @"gz"
|
||||||
|
|
||||||
|
#define KEYCODE_CAPS_LOCK 0x39
|
||||||
|
|
||||||
@interface EmulatorWindowController ()
|
@interface EmulatorWindowController ()
|
||||||
|
|
||||||
@property (nonatomic, assign) IBOutlet EmulatorGLView *view;
|
@property (nonatomic, assign) IBOutlet EmulatorGLView *view;
|
||||||
@ -312,22 +314,42 @@
|
|||||||
self.fullscreenWindow = nil;
|
self.fullscreenWindow = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)flagsChanged:(NSEvent*)event
|
||||||
|
{
|
||||||
|
static BOOL modified_caps_lock = NO;
|
||||||
|
if ([event keyCode] == KEYCODE_CAPS_LOCK)
|
||||||
|
{
|
||||||
|
NSUInteger flags = [event modifierFlags];
|
||||||
|
if (flags & NSAlphaShiftKeyMask)
|
||||||
|
{
|
||||||
|
modified_caps_lock = YES;
|
||||||
|
caps_lock = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
caps_lock = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)keyUp:(NSEvent *)event
|
||||||
|
{
|
||||||
|
unichar c = [[event charactersIgnoringModifiers] characterAtIndex:0];
|
||||||
|
|
||||||
|
c_keys_handle_input((int)c, 0, 1);
|
||||||
|
|
||||||
|
// Allow other character to be handled (or not and beep)
|
||||||
|
//[super keyDown:event];
|
||||||
|
}
|
||||||
|
|
||||||
- (void)keyDown:(NSEvent *)event
|
- (void)keyDown:(NSEvent *)event
|
||||||
{
|
{
|
||||||
unichar c = [[event charactersIgnoringModifiers] characterAtIndex:0];
|
unichar c = [[event charactersIgnoringModifiers] characterAtIndex:0];
|
||||||
|
|
||||||
switch (c)
|
c_keys_handle_input((int)c, 1, 1);
|
||||||
{
|
|
||||||
case 27:
|
|
||||||
NSLog(@"key ESC");
|
|
||||||
return;
|
|
||||||
case 'f':
|
|
||||||
NSLog(@"key 'f'");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Allow other character to be handled (or not and beep)
|
// Allow other character to be handled (or not and beep)
|
||||||
[super keyDown:event];
|
//[super keyDown:event];
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
@ -32,7 +32,7 @@ extern int raw_js_y;
|
|||||||
|
|
||||||
static int next_key = -1;
|
static int next_key = -1;
|
||||||
static int last_scancode = -1;
|
static int last_scancode = -1;
|
||||||
bool caps_lock = false; /* is enabled */
|
bool caps_lock = true; // default enabled because so much breaks otherwise
|
||||||
|
|
||||||
/* ----------------------------------------------------
|
/* ----------------------------------------------------
|
||||||
//e Keymap. Mapping scancodes to Apple //e US Keyboard
|
//e Keymap. Mapping scancodes to Apple //e US Keyboard
|
||||||
@ -171,7 +171,6 @@ void c_keys_handle_input(int scancode, int pressed, int is_cooked)
|
|||||||
{
|
{
|
||||||
int *keymap = NULL;
|
int *keymap = NULL;
|
||||||
|
|
||||||
assert(scancode < 0x80);
|
|
||||||
if (is_cooked) {
|
if (is_cooked) {
|
||||||
last_scancode = -1;
|
last_scancode = -1;
|
||||||
if (!pressed) {
|
if (!pressed) {
|
||||||
@ -184,6 +183,7 @@ void c_keys_handle_input(int scancode, int pressed, int is_cooked)
|
|||||||
}
|
}
|
||||||
next_key = scancode;
|
next_key = scancode;
|
||||||
} else if (scancode >= 0) {
|
} else if (scancode >= 0) {
|
||||||
|
assert(scancode < 0x80);
|
||||||
last_scancode = scancode;
|
last_scancode = scancode;
|
||||||
|
|
||||||
if ((key_pressed[ SCODE_L_SHIFT ] || key_pressed[ SCODE_R_SHIFT ]) &&
|
if ((key_pressed[ SCODE_L_SHIFT ] || key_pressed[ SCODE_R_SHIFT ]) &&
|
||||||
|
Loading…
x
Reference in New Issue
Block a user