Skip to content

Commit b48633e

Browse files
committed
✨ feat: Add paste button
1 parent d6b46aa commit b48633e

File tree

2 files changed

+43
-3
lines changed

2 files changed

+43
-3
lines changed

tests/docs/case/basic/demos/InlineImage.tsx

Lines changed: 36 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,16 +1,50 @@
1-
import React from 'react';
1+
import React, { useRef } from 'react';
22
import { useElements, TestLayout } from '@test-utils';
3+
import copy from 'copy-to-clipboard';
4+
import { message } from 'antd';
35

46
/**
57
*
68
*/
79
export default () => {
810
const { elements, ref } = useElements();
11+
const imageRef = useRef<HTMLImageElement>(null);
912

1013
return (
11-
<TestLayout elements={elements}>
14+
<TestLayout
15+
elements={elements}
16+
buttons={[
17+
{
18+
name: '复制为 Base64',
19+
onClick: () => {
20+
const img = imageRef.current;
21+
if (!img) {
22+
return;
23+
}
24+
// 1. 创建canvas DOM元素,并设置其宽高和图片一样
25+
let canvas: HTMLCanvasElement | null = document.createElement(
26+
'canvas',
27+
);
28+
canvas.width = img.width;
29+
canvas.height = img.height;
30+
31+
// 2. 使用画布画图
32+
const ctx = canvas.getContext('2d');
33+
ctx?.drawImage(img, 0, 0, img.width, img.height);
34+
35+
// 3. 返回的是一串Base64编码的URL并指定格式
36+
const dataURL = canvas.toDataURL(`image/png`);
37+
canvas = null; // 释放
38+
39+
copy(dataURL);
40+
message.success('已复制到剪切板');
41+
},
42+
},
43+
]}
44+
>
1245
<div ref={ref}>
1346
<img
47+
ref={imageRef}
1448
alt="ICON"
1549
src=""
1650
/>

tests/utils/TestLayout.tsx

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,9 +5,10 @@ import useSketchJSON from './useSketchJSON';
55

66
interface FooterProps {
77
elements: Element[] | Element;
8+
buttons?: { name: string; onClick: () => void }[];
89
}
910

10-
const TestLayout: FC<FooterProps> = ({ elements, children }) => {
11+
const TestLayout: FC<FooterProps> = ({ elements, children, buttons }) => {
1112
const { sketchJSON, generateGroup, generateSymbol } = useSketchJSON();
1213
const [showJSON, setShowJSON] = useState(false);
1314

@@ -30,6 +31,11 @@ const TestLayout: FC<FooterProps> = ({ elements, children }) => {
3031
</Col>
3132
<Col>
3233
<Space>
34+
{buttons?.map((button) => (
35+
<Button key={button.name} onClick={button.onClick}>
36+
{button.name}
37+
</Button>
38+
))}
3339
<Button
3440
onClick={() => {
3541
generateGroup(elements);

0 commit comments

Comments
 (0)