代码拉取完成,页面将自动刷新
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>上划线、中划线、下划线</title>
</head>
<body>
<canvas id="c1" width="300" height="300" style="border: 1px solid #ccc"></canvas>
<!-- <button>上划线</button> -->
<button onclick="linethrough()">中划线</button>
<!-- <button>下划线</button> -->
<canvas id="c2" width="300" height="300" style="border: 1px solid #ccc"></canvas>
<script src="../../script/fabric.js"></script>
<script>
// c1
const canvas1 = new fabric.Canvas('c1')
const iText1 = new fabric.IText('aaa',{
styles: {
0: {
0: { overline: true }, // 上划线
1: { linethrough: true }, // 中划线
2: { underline: true } // 下划线
}
}
})
canvas1.add(iText1)
// c2
const canvas2 = new fabric.Canvas('c2')
const iText2 = new fabric.IText('hello wor\nld')
canvas2.add(iText2)
function linethrough() {
let activeTxt = canvas2.getActiveObject()
if (!activeTxt) return
if (activeTxt.isEditing) {
// 编辑状态
const state = activeTxt.getSelectionStyles().find(item => item.linethrough !== true)
if (!state || (JSON.stringify(state) === '{}' && activeTxt['linethrough'] === true)) {
activeTxt.setSelectionStyles({ 'linethrough': false })
} else {
activeTxt.setSelectionStyles({ 'linethrough': true })
}
} else {
// 选择状态
if (activeTxt['linethrough'] === true) {
activeTxt.linethrough = false
activeTxt.dirty = true;
let s = activeTxt.styles
for(let i in s) {
for (let j in s[i]) {
s[i][j].linethrough = false
}
}
} else {
activeTxt.linethrough = true
activeTxt.dirty = true;
let s = activeTxt.styles
for(let i in s) {
for (let j in s[i]) {
s[i][j].linethrough = true
}
}
}
}
canvas2.renderAll()
}
</script>
</body>
</html>
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。