|
@@ -7,39 +7,46 @@ import { save2Album, base64ToFile } from "@/utils/image";
|
7
|
7
|
import useCanvas from "./useCanvas";
|
8
|
8
|
import "./style.scss";
|
9
|
9
|
|
10
|
|
-export default (props) => {
|
11
|
|
- const {
|
12
|
|
- show,
|
13
|
|
- dataSource,
|
14
|
|
- onClose,
|
15
|
|
- onSuccess,
|
16
|
|
- } = props;
|
|
10
|
+export default props => {
|
|
11
|
+ const { show, dataSource, onClose, onSuccess } = props;
|
17
|
12
|
|
18
|
13
|
const [img, setImg] = useState();
|
19
|
14
|
const [processing, setProcessing] = useState(false);
|
20
|
15
|
|
21
|
16
|
const [canvasInited, setCanvasInited] = useState(false);
|
22
|
17
|
|
23
|
|
-
|
24
|
18
|
const posterRender = useRef();
|
25
|
19
|
|
26
|
|
- useCanvas("canvas-broker-poster", (fn) => {
|
|
20
|
+ useCanvas("canvas-broker-poster", fn => {
|
27
|
21
|
posterRender.current = fn;
|
28
|
22
|
setCanvasInited(true);
|
29
|
23
|
});
|
30
|
24
|
|
|
25
|
+ const Save = e => {
|
|
26
|
+ e.stopPropagation();
|
|
27
|
+ if (img) {
|
|
28
|
+ save2Album(img).then(() => {
|
|
29
|
+ Taro.showToast({ title: "保存成功", icon: "none" });
|
|
30
|
+ });
|
|
31
|
+
|
|
32
|
+ }
|
|
33
|
+ };
|
31
|
34
|
|
32
|
35
|
useEffect(() => {
|
33
|
36
|
if (dataSource && canvasInited) {
|
34
|
37
|
const getPoster = posterRender.current;
|
35
|
38
|
setProcessing(true);
|
36
|
39
|
getPoster(dataSource)
|
37
|
|
- .then((image) => {
|
38
|
|
-
|
39
|
|
- setImg(image);
|
|
40
|
+ .then(image => {
|
|
41
|
+
|
|
42
|
+ base64ToFile(image.replace("data:image/jpeg;base64,", "")).then(
|
|
43
|
+ tmpFile => {
|
|
44
|
+ console.log(tmpFile, "tmpFiletmpFile");
|
|
45
|
+ setImg(tmpFile);
|
|
46
|
+ }
|
|
47
|
+ );
|
40
|
48
|
|
41
|
49
|
setProcessing(false);
|
42
|
|
-
|
43
|
50
|
})
|
44
|
51
|
.catch(() => {
|
45
|
52
|
setProcessing(false);
|
|
@@ -59,7 +66,7 @@ export default (props) => {
|
59
|
66
|
src={img}
|
60
|
67
|
mode="scaleToFill"
|
61
|
68
|
className="centerLabel"
|
62
|
|
- onClick={(e) => e.stopPropagation()}
|
|
69
|
+ onClick={e => e.stopPropagation()}
|
63
|
70
|
/>
|
64
|
71
|
) : (
|
65
|
72
|
<Spin2
|
|
@@ -68,15 +75,21 @@ export default (props) => {
|
68
|
75
|
size={32}
|
69
|
76
|
/>
|
70
|
77
|
)}
|
71
|
|
-
|
72
|
78
|
</view>
|
73
|
79
|
</view>
|
|
80
|
+ <view className="saveimg">
|
|
81
|
+ <text onClick={Save}>保存到手机</text>
|
|
82
|
+ </view>
|
74
|
83
|
</view>
|
75
|
84
|
</View>
|
76
|
85
|
)}
|
77
|
86
|
|
78
|
|
- <View style={{ width: "1px", height: "1px",overflow:'hidden' }}>
|
79
|
|
- <Canvas type="2d" id="canvas-broker-poster" style={{width: '1px',height:'1px'}}/>
|
|
87
|
+ <View style={{ width: "1px", height: "1px", overflow: "hidden" }}>
|
|
88
|
+ <Canvas
|
|
89
|
+ type="2d"
|
|
90
|
+ id="canvas-broker-poster"
|
|
91
|
+ style={{ width: "1px", height: "1px" }}
|
|
92
|
+ />
|
80
|
93
|
</View>
|
81
|
94
|
</>
|
82
|
95
|
);
|