leaferjs 刷新后,第一次hover动画时背景图短暂模糊

我正在使用leaferjs 开发一个图片标注工具,基本逻辑就是任意一张图片作为底稿,然后实现对图片就行标注;如图所示:

其中有一个需求是用户鼠标hover在标注元素上时候,需要放大一些这个标注,现在发现页面刷新后,第一次hover动画时背景图短暂模糊,第一次以后就不会有这个问题了,如图所示:

第一次hover动画模糊截图,可以很明显的看到图明显很模糊

对比不模糊时

以下是关键部分代码 样稿图加载代码:

arduino 复制代码
const app = appInst.value;

const { designDraftGroupKey, designDraftRectKey } = curConfig.value;

const designDraftGroup = new Group({
    id: `${designDraftGroupKey}`,

});
app.add(designDraftGroup);
const { width: ow, height: oh } = getPictureSize();

// 样稿图
const designDraftRect = new Rect({
    id: `${designDraftRectKey}`,
    x: 0,
    y: 0,

    width: ow,
    height: oh,
    stroke: props.debuggerMode ? 'red' : null,
    fill: {
        type: 'image',
        url: props.url, 
        mode: 'stretch' // 拉伸填充
    },
    draggable: false // 允许拖动
});
designDraftGroup.add(designDraftRect);
designDraftRectEl.value = designDraftGroup;

创建标注代码

javascript 复制代码
const textDom = new Text({
    tag: 'Text',
    id: `${labelItem.key}_${textContentKey}`,
    text: textBoxParams.text,
    fill: mainColor,
    padding: [10, 20],
    textAlign: 'left',
    verticalAlign: 'top',
});
// 文本框  相关
const textBox = new Box({
    x: textBoxParams?.x ?? 0,
    y: textBoxParams?.y ?? 0,
    id: `${labelItem.key}_${textBoxKey}`,
    className: `${textBoxKey}`,
    fill: '#fff',
    draggable: true,
    cornerRadius: 5,
    stroke: mainColor, // 设置边框颜色
    strokeWidth: 2, // 设置边框宽度
    zIndex: 1,
    origin: 'center',
    // 默认不显示 等
    visible: false,
    cursor: 'pointer',
    children: [
        textDom
    ]
});

app.add(textBox);

绑定hover动画 代码 : textBoxEl是文本框 、targetEl 是图片对应区域 、lineEl 是连接线

scss 复制代码
// 绑定 hover动画
const buildEnterAnimate = () => {
    if (draging) {
        return;
    }
    const { textBoxEl, targetEl, lineEl, textContentEl } = queryDataItemElement(labelItem);
    textBoxEl?.animate({ scale: getBaseScale(labelItem?.textBoxParams?.scale || 0) + getBaseScale(1.1), }, animateParams);
    lineEl?.animate({ strokeWidth: 4 * getBaseScale(textBoxParams?.scale || 1), opacity: 1 }, animateParams);
    targetEl?.animate({ strokeWidth: 4 * getBaseScale(textBoxParams?.scale || 1), fill: labelItem.color, opacity: 0.7 }, animateParams);
    setActiveLabelElement(labelItem);
}
const buildLeaveAnimate = () => {
    const { textBoxEl, targetEl, lineEl, textContentEl } = queryDataItemElement(labelItem);
    textBoxEl?.animate({ scale: getBaseScale(labelItem?.textBoxParams?.scale || 1), }, animateParams);
    lineEl?.animate({ strokeWidth: 2 * getBaseScale(textBoxParams?.scale || 1), opacity: 0.7 }, animateParams);


    if (isFocusViewMode.value) {
        targetEl?.animate({ strokeWidth: 2 * getBaseScale(textBoxParams?.scale || 1), opacity: 0.7 }, animateParams);
    } else {
        targetEl?.animate({ strokeWidth: 2 * getBaseScale(textBoxParams?.scale || 1), fill: null, opacity: 0.7 }, animateParams);
    }
}

const { textBoxEl, targetEl, lineEl, textContentEl } = queryDataItemElement(labelItem);
textBoxEl.on(PointerEvent.ENTER, buildEnterAnimate);
textBoxEl.on(PointerEvent.LEAVE, buildLeaveAnimate);

targetEl?.on(PointerEvent.ENTER, buildEnterAnimate);
targetEl?.on(PointerEvent.LEAVE, buildLeaveAnimate);

lineEl?.on(PointerEvent.ENTER, buildEnterAnimate);
lineEl?.on(PointerEvent.LEAVE, buildLeaveAnimate);

有没有人知道原因呢?求解答

相关推荐
程序员Agions9 小时前
useMemo、useCallback、React.memo,可能真的要删了
前端·react.js
滕青山9 小时前
Vue项目BMI计算器技术实现
前端·vue.js
子兮曰9 小时前
深入浏览器指纹:Canvas、WebGL、Audio是如何暴露你的身份的?
前端·浏览器·canvas
月亮补丁9 小时前
AntiGravity只能生成 1:1 图片?一招破解尺寸限制
前端
何中应9 小时前
MindMap部署
前端·node.js
NAGNIP9 小时前
程序员效率翻倍的快捷键大全!
前端·后端·程序员
一个网络学徒9 小时前
python5
java·服务器·前端
tiantian_cool9 小时前
Claude Opus 4.6 模型新特性(2026年2月5日发布)
前端
0思必得09 小时前
[Web自动化] Selenium获取元素的子元素
前端·爬虫·selenium·自动化·web自动化
用户5757303346249 小时前
🌟 从一行 HTML 到屏幕像素:浏览器是如何“画”出网页的?
前端