ScintillaWX::ScintillaWX(wxStyledTextCtrl* win) {
capturedMouse = false;
wMain = win;
- wDraw = win;
stc = win;
wheelRotation = 0;
Initialise();
void ScintillaWX::ScrollText(int linesToMove) {
int dy = vs.lineHeight * (linesToMove);
- // TODO: calculate the rectangle to refreshed...
wMain.GetID()->ScrollWindow(0, dy);
+ wMain.GetID()->Update();
}
void ScintillaWX::SetVerticalScrollPos() {
}
void ScintillaWX::CreateCallTipWindow(PRectangle) {
- ct.wCallTip = new wxSTCCallTip(wDraw.GetID(), -1, &ct);
+ ct.wCallTip = new wxSTCCallTip(wMain.GetID(), -1, &ct);
ct.wDraw = ct.wCallTip;
}
}
-void ScintillaWX::DoMouseWheel(int rotation, int delta, int linesPerAction) {
+void ScintillaWX::DoMouseWheel(int rotation, int delta, int linesPerAction, int ctrlDown) {
int topLineNew = topLine;
int lines;
- wheelRotation += rotation;
- lines = wheelRotation / delta;
- wheelRotation -= lines * delta;
- if (lines != 0) {
- lines *= linesPerAction;
- topLineNew -= lines;
- ScrollTo(topLineNew);
+ if (ctrlDown) { // Zoom the fonts if Ctrl key down
+ if (rotation < 0) {
+ KeyCommand(SCI_ZOOMIN);
+ }
+ else {
+ KeyCommand(SCI_ZOOMOUT);
+ }
+ }
+ else { // otherwise just scroll the window
+ wheelRotation += rotation;
+ lines = wheelRotation / delta;
+ wheelRotation -= lines * delta;
+ if (lines != 0) {
+ lines *= linesPerAction;
+ topLineNew -= lines;
+ ScrollTo(topLineNew);
+ }
}
}
}
void ScintillaWX::DoLoseFocus(){
- DropCaret();
+ SetFocusState(false);
}
void ScintillaWX::DoGainFocus(){
- ShowCaretAtCurrentPosition();
+ SetFocusState(true);
}
void ScintillaWX::DoSysColourChange() {
// AutoCompleteChanged(ch);
}
-int ScintillaWX::DoKeyDown(int key, bool shift, bool ctrl, bool alt) {
+int ScintillaWX::DoKeyDown(int key, bool shift, bool ctrl, bool alt, bool* consumed) {
switch (key) {
case WXK_DOWN: key = SCK_DOWN; break;
case WXK_UP: key = SCK_UP; break;
case WXK_SHIFT: key = 0; break;
}
- return KeyDown(key, shift, ctrl, alt);
+ return KeyDown(key, shift, ctrl, alt, consumed);
}