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:
parent
5f940c4e4b
commit
2dadc8cb54
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user