mirror of
https://github.com/gnustep/libs-gui.git
synced 2025-04-27 15:50:43 +00:00
2001-07-23 Pierre-Yves <pyrivail@ens-lyon.fr>
* Source/NSBrowser.h: Add instance variables to support alphanumerical keys. Add GNUstepExtensions category with alpahnumerical-key-related methods (acceptsAlphaNumericalKeys, setAcceptsAlphaNumericalKeys:, sendsActionOnAlphaNumericalKeys, setSendsActionOnAlphaNumericalKeys:) * Source/NSBrowser.m: Add GNUstepExtensions category methods * Source/NSBrowser.m (-initWIthFrame:): initialization of the alphanumerical-key-related instance variables. * Source/NSBrowser.m (-dealloc): TEST_RELEASE a keyDown internal object * Source/NSBrowser.m (-keyDown): support for alphanumerical keys * Source/NSBrowser.m (-selectRow:inColumn:): when calling [matrix cellAtRow:column:], column should be 0 (not column) git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gui/trunk@10531 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
543a9aaba8
commit
e0147f04ee
2 changed files with 153 additions and 1 deletions
|
@ -64,6 +64,12 @@
|
||||||
|
|
||||||
BOOL _acceptsArrowKeys;
|
BOOL _acceptsArrowKeys;
|
||||||
BOOL _sendsActionOnArrowKeys;
|
BOOL _sendsActionOnArrowKeys;
|
||||||
|
BOOL _acceptsAlphaNumericalKeys;
|
||||||
|
BOOL _sendsActionOnAlphaNumericalKeys;
|
||||||
|
NSTimeInterval _lastKeyPressed;
|
||||||
|
NSString *_charBuffer;
|
||||||
|
int _alphaNumericalLastColumn;
|
||||||
|
|
||||||
BOOL _passiveDelegate;
|
BOOL _passiveDelegate;
|
||||||
id _browserDelegate;
|
id _browserDelegate;
|
||||||
SEL _doubleAction;
|
SEL _doubleAction;
|
||||||
|
@ -231,6 +237,15 @@
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
//
|
||||||
|
// Controlling the alphanumerical keys behaviour
|
||||||
|
//
|
||||||
|
@interface NSBrowser (GNUstepExtensions)
|
||||||
|
- (BOOL)acceptsAlphaNumericalKeys;
|
||||||
|
- (void) setAcceptsAlphaNumericalKeys: (BOOL)flag;
|
||||||
|
- (BOOL) sendsActionOnAlphaNumericalKeys;
|
||||||
|
- (void) setSendsActionOnAlphaNumericalKeys: (BOOL)flag;
|
||||||
|
@end
|
||||||
|
|
||||||
//
|
//
|
||||||
// Methods Implemented by the Delegate
|
// Methods Implemented by the Delegate
|
||||||
|
|
|
@ -410,7 +410,7 @@ static float scrollerWidth; // == [NSScroller scrollerWidth]
|
||||||
if (!(matrix = [self matrixInColumn: column]))
|
if (!(matrix = [self matrixInColumn: column]))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((cell = [matrix cellAtRow: row column: column]))
|
if ((cell = [matrix cellAtRow: row column: 0]))
|
||||||
{
|
{
|
||||||
if (column < _lastColumnLoaded)
|
if (column < _lastColumnLoaded)
|
||||||
{
|
{
|
||||||
|
@ -2164,7 +2164,11 @@ static float scrollerWidth; // == [NSScroller scrollerWidth]
|
||||||
_hasHorizontalScroller = YES;
|
_hasHorizontalScroller = YES;
|
||||||
_isLoaded = NO;
|
_isLoaded = NO;
|
||||||
_acceptsArrowKeys = YES;
|
_acceptsArrowKeys = YES;
|
||||||
|
_acceptsAlphaNumericalKeys = YES;
|
||||||
|
_lastKeyPressed = 0.;
|
||||||
|
_charBuffer = nil;
|
||||||
_sendsActionOnArrowKeys = YES;
|
_sendsActionOnArrowKeys = YES;
|
||||||
|
_sendsActionOnAlphaNumericalKeys = YES;
|
||||||
_browserDelegate = nil;
|
_browserDelegate = nil;
|
||||||
_passiveDelegate = YES;
|
_passiveDelegate = YES;
|
||||||
_doubleAction = NULL;
|
_doubleAction = NULL;
|
||||||
|
@ -2208,6 +2212,7 @@ static float scrollerWidth; // == [NSScroller scrollerWidth]
|
||||||
RELEASE(_horizontalScroller);
|
RELEASE(_horizontalScroller);
|
||||||
RELEASE(_browserColumns);
|
RELEASE(_browserColumns);
|
||||||
RELEASE(_titleCell);
|
RELEASE(_titleCell);
|
||||||
|
TEST_RELEASE(_charBuffer);
|
||||||
|
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
@ -2450,6 +2455,92 @@ static float scrollerWidth; // == [NSScroller scrollerWidth]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (_acceptsAlphaNumericalKeys && (character < 0xF700)
|
||||||
|
&& ([characters length] > 0))
|
||||||
|
{
|
||||||
|
NSBrowserColumn *bc;
|
||||||
|
NSMatrix *matrix;
|
||||||
|
NSString *sv;
|
||||||
|
int i, n, s;
|
||||||
|
int selectedColumn;
|
||||||
|
SEL lcarcSel = @selector(loadedCellAtRow:column:);
|
||||||
|
IMP lcarc = [self methodForSelector: lcarcSel];
|
||||||
|
|
||||||
|
selectedColumn = [self selectedColumn];
|
||||||
|
bc = [_browserColumns objectAtIndex:
|
||||||
|
selectedColumn];
|
||||||
|
matrix = [bc columnMatrix];
|
||||||
|
n = [matrix numberOfRows];
|
||||||
|
s = [matrix selectedRow];
|
||||||
|
|
||||||
|
if (!_charBuffer)
|
||||||
|
{
|
||||||
|
_charBuffer = [characters substringToIndex: 1];
|
||||||
|
RETAIN(_charBuffer);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (([theEvent timestamp] - _lastKeyPressed < 2000.0)
|
||||||
|
&& (_alphaNumericalLastColumn == selectedColumn))
|
||||||
|
{
|
||||||
|
NSString *transition;
|
||||||
|
transition = [_charBuffer
|
||||||
|
stringByAppendingString:
|
||||||
|
[characters substringToIndex: 1]];
|
||||||
|
RELEASE(_charBuffer);
|
||||||
|
_charBuffer = transition;
|
||||||
|
RETAIN(_charBuffer);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
RELEASE(_charBuffer);
|
||||||
|
_charBuffer = [characters substringToIndex: 1];
|
||||||
|
RETAIN(_charBuffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_alphaNumericalLastColumn = selectedColumn;
|
||||||
|
_lastKeyPressed = [theEvent timestamp];
|
||||||
|
|
||||||
|
sv = [((*lcarc)(self, lcarcSel, s, selectedColumn))
|
||||||
|
stringValue];
|
||||||
|
|
||||||
|
if (([sv length] > 0)
|
||||||
|
&& ([sv hasPrefix: _charBuffer]))
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = s+1; i < n; i++)
|
||||||
|
{
|
||||||
|
sv = [((*lcarc)(self, lcarcSel, i, selectedColumn))
|
||||||
|
stringValue];
|
||||||
|
if (([sv length] > 0)
|
||||||
|
&& ([sv hasPrefix: _charBuffer]))
|
||||||
|
{
|
||||||
|
[self selectRow: i
|
||||||
|
inColumn: selectedColumn];
|
||||||
|
[matrix scrollCellToVisibleAtRow: i column: 0];
|
||||||
|
[matrix performClick: self];
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (i = 0; i < s; i++)
|
||||||
|
{
|
||||||
|
sv = [((*lcarc)(self, lcarcSel, i, selectedColumn))
|
||||||
|
stringValue];
|
||||||
|
if (([sv length] > 0)
|
||||||
|
&& ([sv hasPrefix: _charBuffer]))
|
||||||
|
{
|
||||||
|
[self selectRow: i
|
||||||
|
inColumn: selectedColumn];
|
||||||
|
[matrix scrollCellToVisibleAtRow: i column: 0];
|
||||||
|
[matrix performClick: self];
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_lastKeyPressed = 0.;
|
||||||
|
}
|
||||||
|
|
||||||
[super keyDown: theEvent];
|
[super keyDown: theEvent];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2523,9 +2614,55 @@ static float scrollerWidth; // == [NSScroller scrollerWidth]
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
@implementation NSBrowser (GNUstepExtensions)
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Setting the behavior of arrow keys
|
||||||
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// -------------------
|
||||||
|
// Returns YES if the alphanumerical keys are enabled.
|
||||||
|
//
|
||||||
|
|
||||||
|
- (BOOL)acceptsAlphaNumericalKeys
|
||||||
|
{
|
||||||
|
return _acceptsAlphaNumericalKeys;
|
||||||
|
}
|
||||||
|
|
||||||
|
// -------------------
|
||||||
|
// Enables or disables the arrow keys as used for navigating within
|
||||||
|
// and between browsers.
|
||||||
|
//
|
||||||
|
|
||||||
|
- (void) setAcceptsAlphaNumericalKeys: (BOOL)flag
|
||||||
|
{
|
||||||
|
_acceptsAlphaNumericalKeys = flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
// -------------------
|
||||||
|
// Returns NO if pressing an arrow key only scrolls the browser, YES if
|
||||||
|
// it also sends the action message specified by setAction:.
|
||||||
|
//
|
||||||
|
|
||||||
|
- (BOOL) sendsActionOnAlphaNumericalKeys
|
||||||
|
{
|
||||||
|
return _sendsActionOnAlphaNumericalKeys;
|
||||||
|
}
|
||||||
|
|
||||||
|
// -------------------
|
||||||
|
// Sets whether pressing an arrow key will cause the action message
|
||||||
|
// to be sent (in addition to causing scrolling).
|
||||||
|
//
|
||||||
|
|
||||||
|
- (void) setSendsActionOnAlphaNumericalKeys: (BOOL)flag
|
||||||
|
{
|
||||||
|
_sendsActionOnAlphaNumericalKeys = flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
|
||||||
// #############################################################################
|
// #############################################################################
|
||||||
//
|
//
|
||||||
// PRIVATE METHODS
|
// PRIVATE METHODS
|
||||||
|
|
Loading…
Reference in a new issue