fix: cursor navigation across pages #229

pr675
Hufe921 3 years ago
parent 94247c324b
commit a96a77a237

@ -205,55 +205,71 @@ export function keydown(evt: KeyboardEvent, host: CanvasEvent) {
}
}
const {
rowNo,
index,
pageNo,
coordinate: { leftTop, rightTop }
rowNo,
rowIndex,
coordinate: {
leftTop: [curLeftX],
rightTop: [curRightX]
}
} = anchorPosition
if ((isUp && rowNo !== 0) || (!isUp && rowNo !== draw.getRowCount())) {
// 下一个光标点所在行位置集合
const probablePosition = isUp
? positionList
.slice(0, index)
.filter(p => p.rowNo === rowNo - 1 && pageNo === p.pageNo)
: positionList
.slice(index, positionList.length - 1)
.filter(p => p.rowNo === rowNo + 1 && pageNo === p.pageNo)
// 查找与当前位置元素点交叉最多的位置
let maxIndex = 0
let maxDistance = 0
for (let p = 0; p < probablePosition.length; p++) {
const position = probablePosition[p]
// 当前光标在前
// 向上时在首行、向下时再最尾则忽略
if (
(isUp && rowIndex === 0) ||
(!isUp && rowIndex === draw.getRowCount() - 1)
) {
return
}
// 查找下一行信息
const probablePosition: IElementPosition[] = []
if (isUp) {
let p = index - 1
while (p > 0) {
const position = positionList[p]
p--
if (position.rowNo === rowNo) continue
if (
position.coordinate.leftTop[0] >= leftTop[0] &&
position.coordinate.leftTop[0] <= rightTop[0]
probablePosition[0] &&
probablePosition[0].rowNo !== position.rowNo
) {
const curDistance = rightTop[0] - position.coordinate.leftTop[0]
if (curDistance > maxDistance) {
maxIndex = position.index
maxDistance = curDistance
break
}
probablePosition.unshift(position)
}
// 当前光标在后
else if (
position.coordinate.leftTop[0] <= leftTop[0] &&
position.coordinate.rightTop[0] >= leftTop[0]
} else {
let p = index + 1
while (p < positionList.length) {
const position = positionList[p]
p++
if (position.rowNo === rowNo) continue
if (
probablePosition[0] &&
probablePosition[0].rowNo !== position.rowNo
) {
const curDistance = position.coordinate.rightTop[0] - leftTop[0]
if (curDistance > maxDistance) {
maxIndex = position.index
maxDistance = curDistance
break
}
probablePosition.push(position)
}
}
// 查找下一行位置:第一个存在交叉宽度的元素位置
let nextIndex = 0
for (let p = 0; p < probablePosition.length; p++) {
const nextPosition = probablePosition[p]
const {
coordinate: {
leftTop: [nextLeftX],
rightTop: [nextRightX]
}
// 匹配不到
if (p === probablePosition.length - 1 && maxIndex === 0) {
maxIndex = position.index
} = nextPosition
if (p === probablePosition.length - 1) {
nextIndex = nextPosition.index
}
if (curRightX <= nextLeftX || curLeftX >= nextRightX) continue
nextIndex = nextPosition.index
break
}
const curIndex = maxIndex
if (!nextIndex) return
const curIndex = nextIndex
// shift则缩放选区
let anchorStartIndex = curIndex
let anchorEndIndex = curIndex
@ -284,7 +300,6 @@ export function keydown(evt: KeyboardEvent, host: CanvasEvent) {
isSubmitHistory: false,
isCompute: false
})
}
} else if (isMod(evt) && evt.key === KeyMap.Z) {
if (isReadonly) return
historyManager.undo()

Loading…
Cancel
Save