效果图:
安装依赖
npm install ui-picture-bd-marker -D
源码仓库:https://github.com/sunshengfei/ui-picture-bd-marker
文档服务器欠费,暂无文档
- 增加只读模式选中 默认值
readOnlyCanSelected: true,
readOnlyAcceptEvent: ['mousedown', 'mouseup', 'touchstart', 'touchup']
- 取消标注区域最小限定,任意宽度都能进行标画和render
- 如果使用
vue-picture-bd-marker
组件,支持长图模式,外部可以套div进行overflow,只需要在vue组件设置width和ratio组合值即可- width:auto 容器宽度将会使用原有图像宽度
- ratio:0 使用原图像缩放比
- options增加
closable
是否可以关闭(删除)属性 如:
marker.setConfigOptions({
options:{closable: false}
})
- options增加
textComponent
,用于自定义标签UI显示,接受类型为Element
- 移除不必要的属性
- 修复右键oncontextmenu事件,当鼠标在tag标签报错问题
- onAnnoContextMenu事件的第二个参数(触发元素),修改为当前绑定oncontextmenu的元素,即 e.target 变为 e.currentTarget
- 修复在IE下部分ES2015方法兼容问题
- 修复在React引用下UI显示不及时响应的问题
- 修复调用marker的
setConfigOptions
方法不及时生效问题 - options中
supportDelKey
修改默认值为false
- 移除config中过时的回调方法,如下:
onDataRendered: function () { },
onDrawOne: function () { },
onSelect: function () { },
- 修复键盘删除失效问题
- 增加Mobile支持
- defaultConfig增加设备标识 (mouse | touch ,鼠标或指针设备|触摸设备)
options: {
deviceType: 'both',//both | mouse | touch
}
大范围更新
- 补全事件回调,
defaultConfig
参数调整,详见文档。export const defaultConfig = { options: { blurOtherDots: true, blurOtherDotsShowTags: false, editable: true, showTags: true,//是否显示标签 supportDelKey: true,//支持删除键 tagLocation: 1, trashPositionStart: 0, boundReachPercent: 0.01, annotationClass: 'annotation', }, onAnnoContextMenu: function (annoData, element, annoContext) { },//自定义右键菜单入口 onAnnoRemoved: function (annoData, element) { return true }, onAnnoAdded: function (insertItem, element) { //同onDrawOne }, onAnnoChanged: function (newValue, oldValue) { }, onAnnoDataFullLoaded: function () { },// 同onDataRendered onAnnoSelected: function (value, element) { },//同onSelect onUpdated: function () { }, // region maybe desperated at the end of 2019 onDataRendered: function () { }, onDrawOne: function () { }, onSelect: function () { }, // endregion
}; ``` 2. 优化性能问题。
- 重组结构,增加默认配置。
- 修复图像宽高在某些情况下,在导致内部变量不更新的问题。
- 支持图片高度超出屏幕后进行标注。
- 重新编写VMarker项目中使用的API。
- 修复bug
- 修复一处删除操作后数据未刷新的bug
感谢(@mrlinjun)
- 增加支持渲染值为百分比
- 增加控制标签位置options参数
tagLocation: 2 // 1内底部 2外底部
- 修复页面存在一个以上的控件出现的无法标注问题
- 修复动态变更只读问题
- 修复this问题
- 增加options配置
boundReachPercent
,控制能达到边界点的百分比分子 取值0.0~100
- 增加数据反选标记框
- 修改打标签及数据渲染需要的数据结构{id:,name:} -> {tag:,tagName:,[自定义属性:,...]}
- 点击选框返回包含自定义数据以作区分
- 修复打相同标签数据错乱问题
如果看到了,来个微信打赏呗,随意~