| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604 |
- /*!vue3-sketch-ruler v1.3.62022年11月Fri Nov 04 2022 18:18:02 GMT+0800 (中国标准时间)制作*/
- import { defineComponent, ref, onMounted, computed, reactive, watch } from "vue-demi";
- import { withDirectives, openBlock, createElementBlock, normalizeStyle, createElementVNode, toDisplayString, vShow, resolveComponent, normalizeClass, createVNode, Fragment, renderList, createBlock } from "vue";
- var rulerLine_vue_vue_type_style_index_0_scoped_true_lang = /* @__PURE__ */ (() => ".line[data-v-5dea28d6]{pointer-events:auto;position:absolute}.line .action[data-v-5dea28d6]{position:absolute;display:flex;justify-content:center;align-items:center}.line .value[data-v-5dea28d6]{pointer-events:none;transform:scale(.83)}.line .del[data-v-5dea28d6]{padding:3px 5px;cursor:pointer;visibility:hidden}.line:hover .del[data-v-5dea28d6]{visibility:visible}\n")();
- var _export_sfc = (sfc, props) => {
- const target = sfc.__vccOpts || sfc;
- for (const [key, val] of props) {
- target[key] = val;
- }
- return target;
- };
- const _sfc_main$3 = defineComponent({
- name: "LineRuler",
- props: {
- scale: Number,
- thick: Number,
- palette: Object,
- index: Number,
- start: Number,
- vertical: Boolean,
- value: Number,
- isShowReferLine: Boolean
- },
- emits: ["onMouseDown", "onRelease", "onRemove"],
- setup(props, { emit }) {
- const startValue = ref(0);
- const showLine = ref(true);
- onMounted(() => {
- startValue.value = props.value;
- });
- const setShowLine = (offset2) => {
- showLine.value = offset2 >= 0;
- };
- const offset = computed(() => {
- const offset2 = (startValue.value - props.start) * props.scale;
- setShowLine(offset2);
- const positionValue = offset2 + "px";
- const position = props.vertical ? { top: positionValue } : { left: positionValue };
- return position;
- });
- const borderCursor = computed(() => {
- var _a;
- const borderValue = `1px solid ${(_a = props.palette) == null ? void 0 : _a.lineColor}`;
- const border = props.vertical ? { borderTop: borderValue } : { borderLeft: borderValue };
- const cursorValue = props.isShowReferLine ? props.vertical ? "ns-resize" : "ew-resize" : "none";
- return {
- cursor: cursorValue,
- ...border
- };
- });
- const actionStyle = computed(() => {
- const actionStyle2 = props.vertical ? { left: props.thick + "px" } : { top: props.thick + "px" };
- return actionStyle2;
- });
- const handleDown = (e) => {
- const startD = props.vertical ? e.clientY : e.clientX;
- const initValue = startValue.value;
- emit("onMouseDown");
- const onMove = (e2) => {
- const currentD = props.vertical ? e2.clientY : e2.clientX;
- const newValue = Math.round(initValue + (currentD - startD) / props.scale);
- startValue.value = newValue;
- };
- const onEnd = () => {
- emit("onRelease", startValue.value, props.index);
- document.removeEventListener("mousemove", onMove);
- document.removeEventListener("mouseup", onEnd);
- };
- document.addEventListener("mousemove", onMove);
- document.addEventListener("mouseup", onEnd);
- };
- const handleRemove = () => {
- emit("onRemove", props.index);
- };
- return {
- startValue,
- showLine,
- offset,
- borderCursor,
- actionStyle,
- handleDown,
- handleRemove
- };
- }
- });
- const _hoisted_1$2 = { class: "value" };
- function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
- return withDirectives((openBlock(), createElementBlock("div", {
- class: "line",
- style: normalizeStyle([_ctx.offset, _ctx.borderCursor]),
- onMousedown: _cache[1] || (_cache[1] = (...args) => _ctx.handleDown && _ctx.handleDown(...args))
- }, [
- createElementVNode("div", {
- class: "action",
- style: normalizeStyle(_ctx.actionStyle)
- }, [
- createElementVNode("span", {
- class: "del",
- onClick: _cache[0] || (_cache[0] = (...args) => _ctx.handleRemove && _ctx.handleRemove(...args))
- }, "\xD7"),
- createElementVNode("span", _hoisted_1$2, toDisplayString(_ctx.startValue), 1)
- ], 4)
- ], 36)), [
- [vShow, _ctx.showLine]
- ]);
- }
- var RulerLine = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3], ["__scopeId", "data-v-5dea28d6"]]);
- const getGridSize = (scale) => {
- if (scale <= 0.25)
- return 40;
- if (scale <= 0.5)
- return 20;
- if (scale <= 1)
- return 10;
- if (scale <= 2)
- return 5;
- if (scale <= 4)
- return 2;
- return 1;
- };
- const FONT_SCALE = 0.83;
- const drawCavaseRuler = (ctx, start, selectStart, selectLength, options, h) => {
- const { scale, width, height, ratio, palette } = options;
- const { bgColor, fontColor, shadowColor, longfgColor, shortfgColor } = palette;
- ctx.scale(ratio, ratio);
- ctx.clearRect(0, 0, width, height);
- ctx.fillStyle = bgColor;
- ctx.fillRect(0, 0, width, height);
- if (selectLength) {
- const shadowX = (selectStart - start) * scale;
- const shadowWidth = selectLength * scale;
- ctx.fillStyle = shadowColor;
- h ? ctx.fillRect(shadowX, 0, shadowWidth, height * 3 / 8) : ctx.fillRect(0, shadowX, width * 3 / 8, shadowWidth);
- }
- const gridSize = getGridSize(scale);
- const gridPixel = gridSize * scale;
- const gridSize10 = gridSize * 10;
- const gridPixel10 = gridSize10 * scale;
- const startValue = Math.floor(start / gridSize) * gridSize;
- const startValue10 = Math.floor(start / gridSize10) * gridSize10;
- const offsetX = (startValue - start) / gridSize * gridPixel;
- const offsetX10 = (startValue10 - start) / gridSize10 * gridPixel10;
- const endValue = start + Math.ceil((h ? width : height) / scale);
- ctx.beginPath();
- ctx.fillStyle = fontColor;
- ctx.strokeStyle = longfgColor;
- for (let value = startValue10, count = 0; value < endValue; value += gridSize10, count++) {
- const x = offsetX10 + count * gridPixel10 + 0.5;
- h ? ctx.moveTo(x, 0) : ctx.moveTo(0, x);
- ctx.save();
- h ? ctx.translate(x, height * 0.4) : ctx.translate(width * 0.4, x);
- if (!h) {
- ctx.rotate(-Math.PI / 2);
- }
- ctx.scale(FONT_SCALE / ratio, FONT_SCALE / ratio);
- ctx.fillText(value.toString(), 4 * ratio, 7 * ratio);
- ctx.restore();
- h ? ctx.lineTo(x, height * 9 / 16) : ctx.lineTo(width * 9 / 16, x);
- }
- ctx.stroke();
- ctx.closePath();
- ctx.beginPath();
- ctx.strokeStyle = shortfgColor;
- for (let value = startValue, count = 0; value < endValue; value += gridSize, count++) {
- const x = offsetX + count * gridPixel + 0.5;
- h ? ctx.moveTo(x, 0) : ctx.moveTo(0, x);
- if (value % gridSize10 !== 0) {
- h ? ctx.lineTo(x, height * 1 / 4) : ctx.lineTo(width * 1 / 4, x);
- }
- }
- ctx.stroke();
- ctx.closePath();
- ctx.setTransform(1, 0, 0, 1, 0, 0);
- };
- const _sfc_main$2 = defineComponent({
- name: "CanvasRuler",
- props: {
- showIndicator: Boolean,
- valueNum: Number,
- scale: Number,
- ratio: Number,
- palette: Object,
- vertical: Boolean,
- start: Number,
- width: Number,
- height: Number,
- selectStart: Number,
- selectLength: Number
- },
- emits: ["onAddLine", "update:showIndicator", "update:valueNum"],
- setup(props, { emit }) {
- const state = reactive({
- canvasContext: null
- });
- let ratio = 1;
- const canvas = ref(null);
- onMounted(() => {
- ratio = props.ratio || window.devicePixelRatio || 1;
- initCanvasRef();
- updateCanvasContext(ratio);
- drawRuler(ratio);
- });
- const initCanvasRef = () => {
- state.canvasContext = canvas.value && canvas.value.getContext("2d");
- };
- const updateCanvasContext = (ratio2) => {
- if (canvas.value) {
- canvas.value.width = props.width * ratio2;
- canvas.value.height = props.height * ratio2;
- const ctx = state.canvasContext;
- if (ctx) {
- ctx.font = `${12 * ratio2}px -apple-system,
- "Helvetica Neue", ".SFNSText-Regular",
- "SF UI Text", Arial, "PingFang SC", "Hiragino Sans GB",
- "Microsoft YaHei", "WenQuanYi Zen Hei", sans-serif`;
- ctx.lineWidth = 1;
- ctx.textBaseline = "middle";
- }
- }
- };
- const drawRuler = (ratio2) => {
- const options = {
- scale: props.scale,
- width: props.width,
- height: props.height,
- palette: props.palette,
- ratio: ratio2
- };
- if (state.canvasContext) {
- drawCavaseRuler(state.canvasContext, props.start, props.selectStart, props.selectLength, options, !props.vertical);
- }
- };
- watch(() => props.start, () => drawRuler(ratio));
- watch([() => props.width, () => props.height], () => {
- updateCanvasContext(ratio);
- drawRuler(ratio);
- });
- const handle = (e, key) => {
- const getValueByOffset = (offset2, start, scale) => Math.round(start + offset2 / scale);
- const offset = props.vertical ? e.offsetY : e.offsetX;
- const value = getValueByOffset(offset, props.start, props.scale);
- switch (key) {
- case "click":
- emit("onAddLine", value);
- break;
- case "enter":
- emit("update:valueNum", value);
- emit("update:showIndicator", true);
- break;
- default:
- emit("update:valueNum", value);
- break;
- }
- };
- return {
- handle,
- canvas
- };
- }
- });
- function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
- return openBlock(), createElementBlock("canvas", {
- ref: "canvas",
- class: "ruler",
- onClick: _cache[0] || (_cache[0] = ($event) => _ctx.handle($event, "click")),
- onMouseenter: _cache[1] || (_cache[1] = ($event) => _ctx.handle($event, "enter")),
- onMousemove: _cache[2] || (_cache[2] = ($event) => _ctx.handle($event, "move")),
- onMouseleave: _cache[3] || (_cache[3] = ($event) => _ctx.$emit("update:showIndicator", false))
- }, null, 544);
- }
- var CanvasRuler = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2]]);
- const wrapperProps = {
- scale: Number,
- ratio: Number,
- thick: Number,
- palette: Object,
- vertical: {
- type: Boolean,
- default: true
- },
- width: {
- type: Number,
- default: 200
- },
- height: {
- type: Number,
- default: 200
- },
- start: {
- type: Number,
- default: 0
- },
- lines: {
- type: Array,
- default: () => []
- },
- selectStart: {
- type: Number
- },
- selectLength: {
- type: Number
- },
- isShowReferLine: {
- type: Boolean
- }
- };
- var rulerWrapper_vue_vue_type_style_index_0_scoped_true_lang = /* @__PURE__ */ (() => ".line[data-v-b6c23352],.h-container[data-v-b6c23352],.v-container[data-v-b6c23352]{position:absolute}.h-container .lines[data-v-b6c23352],.v-container .lines[data-v-b6c23352]{pointer-events:none}.h-container:hover .lines[data-v-b6c23352],.v-container:hover .lines[data-v-b6c23352]{pointer-events:auto}.h-container[data-v-b6c23352]{top:0}.h-container .line[data-v-b6c23352]{top:0;height:100vh;padding-left:5px}.h-container .line .action[data-v-b6c23352]{transform:translate(-24px)}.h-container .line .action .value[data-v-b6c23352]{margin-left:4px}.h-container .indicator[data-v-b6c23352]{top:0;height:100vw}.h-container .indicator .value[data-v-b6c23352]{width:auto;padding:0 2px;margin-top:4px;margin-left:4px}.v-container[data-v-b6c23352]{left:0}.v-container .line[data-v-b6c23352]{left:0;width:100vw;padding-top:5px}.v-container .line .action[data-v-b6c23352]{transform:translateY(-24px);flex-direction:column}.v-container .line .action .value[data-v-b6c23352]{margin-top:4px}.v-container .indicator[data-v-b6c23352]{width:100vw}.v-container .indicator .value[data-v-b6c23352]{left:0;width:auto;padding:0 2px;margin-top:-5px;margin-left:2px;transform:rotate(-90deg);transform-origin:0 0}\n")();
- const _sfc_main$1 = defineComponent({
- name: "RulerWrapper",
- components: {
- CanvasRuler,
- RulerLine
- },
- props: wrapperProps,
- setup(props) {
- const showIndicator = ref(false);
- const valueNum = ref(0);
- const rwClassName = computed(() => {
- const className = props.vertical ? "v-container" : "h-container";
- return className;
- });
- const rwStyle = computed(() => {
- const hContainer = {
- width: `calc(100% - ${props.thick}px)`,
- height: `${props.thick + 1}px`,
- left: `${props.thick}px`
- };
- const vContainer = {
- width: `${props.thick && props.thick + 1}px`,
- height: `calc(100% - ${props.thick}px)`,
- top: `${props.thick}px`
- };
- return props.vertical ? vContainer : hContainer;
- });
- const indicatorStyle = computed(() => {
- var _a;
- const indicatorOffset = (valueNum.value - props.start) * props.scale;
- let positionKey = "top";
- let boderKey = "borderLeft";
- positionKey = props.vertical ? "top" : "left";
- boderKey = props.vertical ? "borderBottom" : "borderLeft";
- return {
- [positionKey]: indicatorOffset + "px",
- [boderKey]: `1px solid ${(_a = props.palette) == null ? void 0 : _a.lineColor}`
- };
- });
- const handleNewLine = (value) => {
- props.lines.push(value);
- };
- const handleLineRelease = (value, index) => {
- const offset = value - props.start;
- const maxOffset = (props.vertical ? props.height : props.width) / props.scale;
- if (offset < 0 || offset > maxOffset) {
- handleLineRemove(index);
- } else {
- props.lines[index] = value;
- }
- };
- const handleLineRemove = (index) => {
- props.lines.splice(index, 1);
- };
- return {
- showIndicator,
- valueNum,
- rwClassName,
- rwStyle,
- indicatorStyle,
- handleNewLine,
- handleLineRelease,
- handleLineRemove
- };
- }
- });
- const _hoisted_1$1 = { class: "lines" };
- const _hoisted_2 = { class: "value" };
- function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
- const _component_CanvasRuler = resolveComponent("CanvasRuler");
- const _component_RulerLine = resolveComponent("RulerLine");
- return openBlock(), createElementBlock("div", {
- class: normalizeClass(_ctx.rwClassName),
- style: normalizeStyle(_ctx.rwStyle)
- }, [
- createVNode(_component_CanvasRuler, {
- vertical: _ctx.vertical,
- scale: _ctx.scale,
- width: _ctx.width,
- height: _ctx.height,
- start: _ctx.start,
- ratio: _ctx.ratio,
- "select-start": _ctx.selectStart,
- "select-length": _ctx.selectLength,
- palette: _ctx.palette,
- valueNum: _ctx.valueNum,
- "onUpdate:valueNum": _cache[0] || (_cache[0] = ($event) => _ctx.valueNum = $event),
- showIndicator: _ctx.showIndicator,
- "onUpdate:showIndicator": _cache[1] || (_cache[1] = ($event) => _ctx.showIndicator = $event),
- onOnAddLine: _ctx.handleNewLine
- }, null, 8, ["vertical", "scale", "width", "height", "start", "ratio", "select-start", "select-length", "palette", "valueNum", "showIndicator", "onOnAddLine"]),
- withDirectives(createElementVNode("div", _hoisted_1$1, [
- (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.lines, (v, i) => {
- return openBlock(), createBlock(_component_RulerLine, {
- key: v + i,
- index: i,
- value: v >> 0,
- scale: _ctx.scale,
- start: _ctx.start,
- thick: _ctx.thick,
- palette: _ctx.palette,
- vertical: _ctx.vertical,
- "is-show-refer-line": _ctx.isShowReferLine,
- onOnRemove: _ctx.handleLineRemove,
- onOnRelease: _ctx.handleLineRelease
- }, null, 8, ["index", "value", "scale", "start", "thick", "palette", "vertical", "is-show-refer-line", "onOnRemove", "onOnRelease"]);
- }), 128))
- ], 512), [
- [vShow, _ctx.isShowReferLine]
- ]),
- withDirectives(createElementVNode("div", {
- class: "indicator",
- style: normalizeStyle(_ctx.indicatorStyle)
- }, [
- createElementVNode("div", _hoisted_2, toDisplayString(_ctx.valueNum), 1)
- ], 4), [
- [vShow, _ctx.showIndicator]
- ])
- ], 6);
- }
- var RulerWrapper = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-b6c23352"]]);
- const eye64 = ``;
- const closeEye64 = ``;
- const sketchRulerProps = {
- eyeIcon: {
- type: String
- },
- closeEyeIcon: {
- type: String
- },
- scale: {
- type: Number,
- default: 1
- },
- ratio: {
- type: Number
- },
- thick: {
- type: Number,
- default: 16
- },
- palette: Object,
- startX: {
- type: Number
- },
- startY: {
- type: Number,
- default: 0
- },
- width: {
- type: Number,
- default: 200
- },
- height: {
- type: Number,
- default: 200
- },
- shadow: {
- type: Object,
- default: () => {
- return {
- x: 0,
- y: 0,
- width: 0,
- height: 0
- };
- }
- },
- lines: {
- type: Object,
- default: () => {
- return {
- h: [],
- v: []
- };
- }
- },
- isShowReferLine: {
- type: Boolean,
- default: true
- }
- };
- var index_vue_vue_type_style_index_0_lang = /* @__PURE__ */ (() => '@charset "UTF-8";.style-ruler{position:absolute;z-index:3;width:100%;height:100%;overflow:hidden;font-size:12px;pointer-events:none}.style-ruler span{line-height:1}.corner{position:absolute;top:0;left:0;pointer-events:auto;cursor:pointer;box-sizing:content-box;transition:all .2s ease-in-out}.indicator{position:absolute;pointer-events:none}.indicator .value{position:absolute;background:white}.ruler{width:100%;height:100%;pointer-events:auto}\n')();
- const _sfc_main = defineComponent({
- name: "SketchRule",
- components: {
- RulerWrapper
- },
- props: sketchRulerProps,
- emits: ["onCornerClick"],
- setup(props, { emit }) {
- let showReferLine = ref(true);
- showReferLine.value = props.isShowReferLine;
- const paletteCpu = computed(() => {
- function merge(obj, o) {
- Object.keys(obj).forEach((key) => {
- if (key && obj.hasOwnProperty(key)) {
- if (typeof o["key"] === "object") {
- obj[key] = merge(obj[key], o[key]);
- } else if (o.hasOwnProperty(key)) {
- obj[key] = o[key];
- }
- }
- });
- return obj;
- }
- const finalObj = merge({
- bgColor: "rgba(225,225,225, 0)",
- longfgColor: "#BABBBC",
- shortfgColor: "#C8CDD0",
- fontColor: "#7D8694",
- shadowColor: "#E8E8E8",
- lineColor: "#EB5648",
- borderColor: "#DADADC",
- cornerActiveColor: "rgb(235, 86, 72, 0.6)",
- menu: {
- bgColor: "#fff",
- dividerColor: "#DBDBDB",
- listItem: {
- textColor: "#415058",
- hoverTextColor: "#298DF8",
- disabledTextColor: "rgba(65, 80, 88, 0.4)",
- bgColor: "#fff",
- hoverBgColor: "#F2F2F2"
- }
- }
- }, props.palette || {});
- return finalObj;
- });
- const cornerStyle = computed(() => {
- return {
- backgroundImage: showReferLine.value ? `url(${props.eyeIcon || eye64})` : `url(${props.closeEyeIcon || closeEye64})`,
- width: props.thick + "px",
- height: props.thick + "px",
- borderRight: `1px solid ${paletteCpu.value.borderColor}`,
- borderBottom: `1px solid ${paletteCpu.value.borderColor}`
- };
- });
- const onCornerClick = (e) => {
- showReferLine.value = !showReferLine.value;
- emit("onCornerClick", showReferLine.value);
- };
- watch([() => props.isShowReferLine], () => {
- showReferLine.value = props.isShowReferLine;
- });
- return {
- showReferLine,
- paletteCpu,
- cornerStyle,
- onCornerClick
- };
- }
- });
- const _hoisted_1 = {
- id: "mb-ruler",
- class: "style-ruler mb-ruler"
- };
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
- const _component_RulerWrapper = resolveComponent("RulerWrapper");
- return openBlock(), createElementBlock("div", _hoisted_1, [
- createVNode(_component_RulerWrapper, {
- vertical: false,
- width: _ctx.width,
- height: _ctx.thick,
- "is-show-refer-line": _ctx.showReferLine,
- thick: _ctx.thick,
- ratio: _ctx.ratio,
- start: _ctx.startX,
- lines: _ctx.lines.h,
- "select-start": _ctx.shadow.x,
- "select-length": _ctx.shadow.width,
- scale: _ctx.scale,
- palette: _ctx.paletteCpu
- }, null, 8, ["width", "height", "is-show-refer-line", "thick", "ratio", "start", "lines", "select-start", "select-length", "scale", "palette"]),
- createVNode(_component_RulerWrapper, {
- vertical: true,
- width: _ctx.thick,
- height: _ctx.height,
- "is-show-refer-line": _ctx.showReferLine,
- thick: _ctx.thick,
- ratio: _ctx.ratio,
- start: _ctx.startY,
- lines: _ctx.lines.v,
- "select-start": _ctx.shadow.y,
- "select-length": _ctx.shadow.height,
- scale: _ctx.scale,
- palette: _ctx.paletteCpu
- }, null, 8, ["width", "height", "is-show-refer-line", "thick", "ratio", "start", "lines", "select-start", "select-length", "scale", "palette"]),
- createElementVNode("a", {
- class: "corner",
- style: normalizeStyle(_ctx.cornerStyle),
- onClick: _cache[0] || (_cache[0] = (...args) => _ctx.onCornerClick && _ctx.onCornerClick(...args))
- }, null, 4)
- ]);
- }
- var SketchRule = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
- export { SketchRule, SketchRule as default };
|