First step to support CJK input under Mac OS: implementation of the function

firstRectForCharacterRange of the NSTextInput protocol.

git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3@8228 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Manolo Gouy 2011-01-09 16:07:13 +00:00
parent 5f940c4e4b
commit 2dadc8cb54
2 changed files with 20 additions and 8 deletions

View File

@ -142,6 +142,7 @@ public:
\return insert position index into text buffer \return insert position index into text buffer
*/ */
int insert_position() const { return mCursorPos; } int insert_position() const { return mCursorPos; }
int position_to_xy(int pos, int* x, int* y) const;
int in_selection(int x, int y) const; int in_selection(int x, int y) const;
void show_insert_position(); void show_insert_position();
@ -364,8 +365,6 @@ protected:
void xy_to_rowcol(int x, int y, int* row, int* column, void xy_to_rowcol(int x, int y, int* row, int* column,
int PosType = CHARACTER_POS) const; int PosType = CHARACTER_POS) const;
int position_to_xy(int pos, int* x, int* y) const;
void maintain_absolute_top_line_number(int state); void maintain_absolute_top_line_number(int state);
int get_absolute_top_line_number() const; int get_absolute_top_line_number() const;
void absolute_top_line_number(int oldFirstChar); void absolute_top_line_number(int oldFirstChar);

View File

@ -1818,13 +1818,26 @@ static void q_set_window_title(NSWindow *nsw, const char * name ) {
} }
- (NSRect)firstRectForCharacterRange:(NSRange)aRange { - (NSRect)firstRectForCharacterRange:(NSRange)aRange {
NSRect glyphRect, frame; NSRect glyphRect;
Fl_Widget *focus = Fl::focus();
Fl_Window *wfocus = focus->window();
while (wfocus->window()) wfocus = wfocus->window();
glyphRect.size.width = 0;
frame = [self frame]; if (dynamic_cast<Fl_Text_Display*>(focus) != NULL) {
glyphRect.origin.x = frame.size.width; int x, y;
glyphRect.origin.y = 0; Fl_Text_Display *current = (Fl_Text_Display*)focus;
glyphRect.size.width = glyphRect.size.height = 0; current->position_to_xy( current->insert_position(), &x, &y );
glyphRect.origin.x = (CGFloat)x;
glyphRect.origin.y = (CGFloat)y + current->textsize();
glyphRect.size.height = current->textsize();
} else {
glyphRect.origin.x = (CGFloat)Fl::event_x();
glyphRect.origin.y = (CGFloat)Fl::event_y() + 12;
glyphRect.size.height = 12;
}
// Convert the rect to screen coordinates // Convert the rect to screen coordinates
glyphRect.origin.y = wfocus->h() - glyphRect.origin.y;
glyphRect.origin = [[self window] convertBaseToScreen:glyphRect.origin]; glyphRect.origin = [[self window] convertBaseToScreen:glyphRect.origin];
return glyphRect; return glyphRect;
} }