optimize hex mode

This commit is contained in:
Xen 2020-05-25 21:46:33 +08:00
parent 92eb71eaed
commit 7e2ed2af55
2 changed files with 55 additions and 13 deletions

View File

@ -456,7 +456,7 @@ amdRequire(["vs/editor/editor.main"], function () {
editor.addAction({
id: "highlight-toggle",
label: "Highlight Toggle",
keybindings: [monaco.KeyMod.CtrlCmd | monaco.KeyCode.KEY_E],
keybindings: [monaco.KeyMod.CtrlCmd + monaco.KeyCode.KEY_E],
precondition: null,
keybindingContext: null,
contextMenuGroupId: "9_cutcopypaste",
@ -518,7 +518,7 @@ amdRequire(["vs/editor/editor.main"], function () {
return newRange;
}
function selectLineRange(model, range) {
function showCursors(model, range) {
let cordRange = getCordinateRange(model, range);
if (undefined === cordRange) return;
@ -537,12 +537,14 @@ amdRequire(["vs/editor/editor.main"], function () {
range: range,
options: {
className: "hex-select",
zIndex: 999,
},
},
{
range: cordRange,
options: {
className: "hex-select",
zIndex: 999,
overviewRuler: {
color: "#f06292",
position: 4, // 2: center, 4: right, 1: left, 7: full
@ -553,6 +555,44 @@ amdRequire(["vs/editor/editor.main"], function () {
);
}
function selectLineRange(model, range, decoration) {
let cordRange = getCordinateRange(model, range);
if (undefined === cordRange) return;
// first remove old decos
let decos = model.getLineDecorations(range.startLineNumber);
for (let deco of decos) {
if (
deco.options.className !== null &&
deco.options.className.indexOf("hl-") !== -1
) {
model.deltaDecorations([deco.id], []);
}
}
model.deltaDecorations(
[],
[
{
range: range,
options: {
className: decoration.style,
},
},
{
range: cordRange,
options: {
className: decoration.style,
overviewRuler: {
color: decoration.color,
position: 4, // 2: center, 4: right, 1: left, 7: full
},
},
},
]
);
}
function extracLineRange(range, line) {
let lineRange = new monaco.Range(line, 1, line, 1);
@ -597,20 +637,22 @@ amdRequire(["vs/editor/editor.main"], function () {
}
editor.onMouseUp(() => {
return;
let model = editor.getModel();
let range = editor.getSelection();
console.log("In: " + range);
// processHexLine(model, range);
if (range.isEmpty() === true) {
showCursors(model, range);
} else {
let deco = decoGet();
for (
let line = range.startLineNumber;
line <= range.endLineNumber;
line++
) {
let lineRange = extracLineRange(range, line);
selectLineRange(model, lineRange);
selectLineRange(model, lineRange, deco);
}
}
});
});

View File

@ -307,5 +307,5 @@ input {
}
.hex-select {
border: 1px solid #f06292;
border-left: 2px solid #e91e63;;
}