mirror of https://github.com/buggins/dlangui.git
implement part 1 of #267 - tab position marks in editors
This commit is contained in:
parent
76a631ebff
commit
2f5a481d2e
|
@ -273,7 +273,7 @@ class EditWidgetBase : ScrollWidgetBase, EditableContentListener, MenuItemAction
|
||||||
@property bool copyCurrentLineWhenNoSelection() { return _copyCurrentLineWhenNoSelection; }
|
@property bool copyCurrentLineWhenNoSelection() { return _copyCurrentLineWhenNoSelection; }
|
||||||
@property EditWidgetBase copyCurrentLineWhenNoSelection(bool flg) { _copyCurrentLineWhenNoSelection = flg; return this; }
|
@property EditWidgetBase copyCurrentLineWhenNoSelection(bool flg) { _copyCurrentLineWhenNoSelection = flg; return this; }
|
||||||
|
|
||||||
protected bool _showTabPositionMarks = true;
|
protected bool _showTabPositionMarks = false;
|
||||||
/// when true shows mark on tab positions in beginning of line
|
/// when true shows mark on tab positions in beginning of line
|
||||||
@property bool showTabPositionMarks() { return _showTabPositionMarks; }
|
@property bool showTabPositionMarks() { return _showTabPositionMarks; }
|
||||||
@property EditWidgetBase showTabPositionMarks(bool flg) {
|
@property EditWidgetBase showTabPositionMarks(bool flg) {
|
||||||
|
@ -2681,6 +2681,8 @@ class EditBox : EditWidgetBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
void drawWhiteSpaceMarks(DrawBuf buf, ref FontRef font, dstring txt, int tabSize, Rect lineRect, Rect visibleRect) {
|
void drawWhiteSpaceMarks(DrawBuf buf, ref FontRef font, dstring txt, int tabSize, Rect lineRect, Rect visibleRect) {
|
||||||
|
// _showTabPositionMarks
|
||||||
|
// _showWhiteSpaceMarks
|
||||||
int firstNonSpace = -1;
|
int firstNonSpace = -1;
|
||||||
int lastNonSpace = -1;
|
int lastNonSpace = -1;
|
||||||
bool hasTabs = false;
|
bool hasTabs = false;
|
||||||
|
@ -2698,7 +2700,12 @@ class EditBox : EditWidgetBase {
|
||||||
uint color = addAlpha(textColor, 0xC0);
|
uint color = addAlpha(textColor, 0xC0);
|
||||||
static int[] textSizeBuffer;
|
static int[] textSizeBuffer;
|
||||||
int charsMeasured = font.measureText(txt, textSizeBuffer, MAX_WIDTH_UNSPECIFIED, tabSize, 0, 0);
|
int charsMeasured = font.measureText(txt, textSizeBuffer, MAX_WIDTH_UNSPECIFIED, tabSize, 0, 0);
|
||||||
|
int ts = tabSize;
|
||||||
|
if (ts < 1)
|
||||||
|
ts = 1;
|
||||||
|
if (ts > 8)
|
||||||
|
ts = 8;
|
||||||
|
int spaceIndex = 0;
|
||||||
for (int i = 0; i < txt.length && i < charsMeasured; i++) {
|
for (int i = 0; i < txt.length && i < charsMeasured; i++) {
|
||||||
dchar ch = txt[i];
|
dchar ch = txt[i];
|
||||||
bool outsideText = (i < firstNonSpace || i >= lastNonSpace);
|
bool outsideText = (i < firstNonSpace || i >= lastNonSpace);
|
||||||
|
@ -2708,6 +2715,17 @@ class EditBox : EditWidgetBase {
|
||||||
rc.right = lineRect.left + textSizeBuffer[i];
|
rc.right = lineRect.left + textSizeBuffer[i];
|
||||||
int h = rc.height;
|
int h = rc.height;
|
||||||
if (rc.intersects(visibleRect)) {
|
if (rc.intersects(visibleRect)) {
|
||||||
|
if (_showTabPositionMarks && i < firstNonSpace) {
|
||||||
|
if (spaceIndex % ts == 0) {
|
||||||
|
// draw mark
|
||||||
|
buf.fillRect(Rect(rc.left, rc.top, rc.left + 1, rc.bottom), color);
|
||||||
|
}
|
||||||
|
if (ch == ' ')
|
||||||
|
spaceIndex++;
|
||||||
|
else if (ch == '\t')
|
||||||
|
spaceIndex = (spaceIndex + ts) / ts * ts;
|
||||||
|
}
|
||||||
|
if (_showWhiteSpaceMarks) {
|
||||||
// draw space mark
|
// draw space mark
|
||||||
if (ch == ' ') {
|
if (ch == ' ') {
|
||||||
// space
|
// space
|
||||||
|
@ -2737,6 +2755,7 @@ class EditBox : EditWidgetBase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
override protected void drawClient(DrawBuf buf) {
|
override protected void drawClient(DrawBuf buf) {
|
||||||
// update matched braces
|
// update matched braces
|
||||||
|
@ -2761,7 +2780,7 @@ class EditBox : EditWidgetBase {
|
||||||
drawLineBackground(buf, _firstVisibleLine + i, lineRect, visibleRect);
|
drawLineBackground(buf, _firstVisibleLine + i, lineRect, visibleRect);
|
||||||
if (!txt.length)
|
if (!txt.length)
|
||||||
continue;
|
continue;
|
||||||
if (_showWhiteSpaceMarks)
|
if (_showWhiteSpaceMarks || _showTabPositionMarks)
|
||||||
drawWhiteSpaceMarks(buf, font, txt, tabSize, lineRect, visibleRect);
|
drawWhiteSpaceMarks(buf, font, txt, tabSize, lineRect, visibleRect);
|
||||||
if (_leftPaneWidth > 0) {
|
if (_leftPaneWidth > 0) {
|
||||||
Rect leftPaneRect = visibleRect;
|
Rect leftPaneRect = visibleRect;
|
||||||
|
|
Loading…
Reference in New Issue