Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
K
kityminder-core
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
吴志俊
kityminder-core
Commits
31a7b2df
Commit
31a7b2df
authored
Sep 20, 2015
by
张博
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fixed bug: 导出 png 节点不显示图片。
parent
a2d8e1f4
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
109 additions
and
20 deletions
+109
-20
promise.js
src/core/promise.js
+28
-0
png.js
src/protocol/png.js
+81
-20
No files found.
src/core/promise.js
View file @
31a7b2df
...
@@ -49,6 +49,34 @@ define(function(require, exports, module) {
...
@@ -49,6 +49,34 @@ define(function(require, exports, module) {
}
}
};
};
Promise
.
all
=
function
(
arr
)
{
return
new
Promise
(
function
(
resolve
,
reject
)
{
var
len
=
arr
.
length
,
i
=
0
,
res
=
0
,
results
=
[];
if
(
len
===
0
)
{
resolve
(
results
);
}
while
(
i
<
len
)
{
arr
[
i
].
then
(
function
(
result
)
{
results
.
push
(
result
);
if
(
++
res
===
len
)
{
resolve
(
results
);
}
},
function
(
val
)
{
reject
(
val
);
}
);
i
++
;
}
});
};
/* deliver an action */
/* deliver an action */
var
deliver
=
function
(
curr
,
state
,
name
,
value
)
{
var
deliver
=
function
(
curr
,
state
,
name
,
value
)
{
if
(
curr
.
state
===
STATE_PENDING
)
{
if
(
curr
.
state
===
STATE_PENDING
)
{
...
...
src/protocol/png.js
View file @
31a7b2df
...
@@ -5,20 +5,26 @@ define(function(require, exports, module) {
...
@@ -5,20 +5,26 @@ define(function(require, exports, module) {
var
DomURL
=
window
.
URL
||
window
.
webkitURL
||
window
;
var
DomURL
=
window
.
URL
||
window
.
webkitURL
||
window
;
function
loadImage
(
url
,
callback
)
{
function
loadImage
(
info
,
callback
)
{
return
new
Promise
(
function
(
resolve
,
reject
)
{
return
new
Promise
(
function
(
resolve
,
reject
)
{
var
image
=
document
.
createElement
(
'img'
);
var
image
=
document
.
createElement
(
"img"
);
image
.
onload
=
function
()
{
image
.
onload
=
function
()
{
resolve
(
this
);
resolve
({
element
:
this
,
x
:
info
.
x
,
y
:
info
.
y
,
width
:
info
.
width
,
height
:
info
.
height
});
};
};
image
.
onerror
=
function
(
err
)
{
image
.
onerror
=
function
(
err
)
{
reject
(
err
);
reject
(
err
);
};
};
//image.setAttribute('crossOrigin', 'anonymous');
image
.
crossOrigin
=
''
;
image
.
crossOrigin
=
''
;
image
.
src
=
url
;
image
.
src
=
info
.
url
;
});
});
}
}
function
getSVGInfo
(
minder
)
{
function
getSVGInfo
(
minder
)
{
var
paper
=
minder
.
getPaper
(),
var
paper
=
minder
.
getPaper
(),
paperTransform
,
paperTransform
,
...
@@ -74,11 +80,41 @@ define(function(require, exports, module) {
...
@@ -74,11 +80,41 @@ define(function(require, exports, module) {
//svgUrl = 'data:image/svg+xml;charset=utf-8,' + encodeURIComponent(svgXml);
//svgUrl = 'data:image/svg+xml;charset=utf-8,' + encodeURIComponent(svgXml);
var
allNodes
=
minder
.
getAllNode
();
var
imagesInfo
=
[];
for
(
var
i
=
0
;
i
<
allNodes
.
length
;
i
++
)
{
var
nodeData
=
allNodes
[
i
].
data
;
if
(
nodeData
.
image
)
{
/*
* 导出之前渲染这个节点,否则取出的 contentBox 不对
* by zhangbobell
* */
minder
.
renderNode
(
allNodes
[
i
]);
var
imageUrl
=
nodeData
.
image
;
var
imageSize
=
nodeData
.
imageSize
;
var
imageRenderBox
=
allNodes
[
i
].
getRenderBox
(
'ImageRenderer'
,
minder
.
getRenderContainer
());
var
imageInfo
=
{
url
:
imageUrl
,
width
:
imageSize
.
width
,
height
:
imageSize
.
height
,
x
:
-
renderContainer
.
getBoundaryBox
().
x
+
imageRenderBox
.
x
+
20
,
y
:
-
renderContainer
.
getBoundaryBox
().
y
+
imageRenderBox
.
y
+
20
};
imagesInfo
.
push
(
imageInfo
);
}
}
return
{
return
{
width
:
width
,
width
:
width
,
height
:
height
,
height
:
height
,
dataUrl
:
svgUrl
,
dataUrl
:
svgUrl
,
xml
:
svgXml
xml
:
svgXml
,
imagesInfo
:
imagesInfo
};
};
}
}
...
@@ -87,13 +123,15 @@ define(function(require, exports, module) {
...
@@ -87,13 +123,15 @@ define(function(require, exports, module) {
var
resultCallback
;
var
resultCallback
;
var
Promise
=
kityminder
.
Promise
;
/* 绘制 PNG 的画布及上下文 */
/* 绘制 PNG 的画布及上下文 */
var
canvas
=
document
.
createElement
(
'canvas'
);
var
canvas
=
document
.
createElement
(
'canvas'
);
var
ctx
=
canvas
.
getContext
(
'2d'
);
var
ctx
=
canvas
.
getContext
(
'2d'
);
/* 尝试获取背景图片 URL 或背景颜色 */
/* 尝试获取背景图片 URL 或背景颜色 */
var
bgDeclare
=
minder
.
getStyle
(
'background'
).
toString
();
var
bgDeclare
=
minder
.
getStyle
(
'background'
).
toString
();
var
bgUrl
=
/url
\(
(
.+
)
\)
/
.
exec
(
bgDeclare
);
var
bgUrl
=
/url
\(
\"(
.+
)\"
\)
/
.
exec
(
bgDeclare
);
var
bgColor
=
kity
.
Color
.
parse
(
bgDeclare
);
var
bgColor
=
kity
.
Color
.
parse
(
bgDeclare
);
/* 获取 SVG 文件内容 */
/* 获取 SVG 文件内容 */
...
@@ -101,6 +139,7 @@ define(function(require, exports, module) {
...
@@ -101,6 +139,7 @@ define(function(require, exports, module) {
var
width
=
svgInfo
.
width
;
var
width
=
svgInfo
.
width
;
var
height
=
svgInfo
.
height
;
var
height
=
svgInfo
.
height
;
var
svgDataUrl
=
svgInfo
.
dataUrl
;
var
svgDataUrl
=
svgInfo
.
dataUrl
;
var
imagesInfo
=
svgInfo
.
imagesInfo
;
/* 画布的填充大小 */
/* 画布的填充大小 */
var
padding
=
20
;
var
padding
=
20
;
...
@@ -115,25 +154,48 @@ define(function(require, exports, module) {
...
@@ -115,25 +154,48 @@ define(function(require, exports, module) {
ctx
.
restore
();
ctx
.
restore
();
}
}
function
drawImage
(
ctx
,
image
,
x
,
y
)
{
function
drawImage
(
ctx
,
image
,
x
,
y
,
width
,
height
)
{
ctx
.
drawImage
(
image
,
x
,
y
);
if
(
width
&&
height
)
{
ctx
.
drawImage
(
image
,
x
,
y
,
width
,
height
);
}
else
{
ctx
.
drawImage
(
image
,
x
,
y
);
}
}
}
function
generateDataUrl
(
canvas
)
{
function
generateDataUrl
(
canvas
)
{
return
canvas
.
toDataURL
(
'png'
);
return
canvas
.
toDataURL
(
'image/png'
);
}
// 加载节点上的图片
function
loadImages
(
imagesInfo
)
{
var
imagePromises
=
imagesInfo
.
map
(
function
(
imageInfo
)
{
return
loadImage
(
imageInfo
);
});
return
Promise
.
all
(
imagePromises
);
}
}
function
drawSVG
()
{
function
drawSVG
()
{
return
loadImage
(
svgDataUrl
).
then
(
function
(
svgImage
)
{
var
svgData
=
{
url
:
svgDataUrl
};
drawImage
(
ctx
,
svgImage
,
padding
,
padding
);
return
loadImage
(
svgData
).
then
(
function
(
$image
)
{
drawImage
(
ctx
,
$image
.
element
,
padding
,
padding
);
return
loadImages
(
imagesInfo
);
}).
then
(
function
(
$images
)
{
for
(
var
i
=
0
;
i
<
$images
.
length
;
i
++
)
{
drawImage
(
ctx
,
$images
[
i
].
element
,
$images
[
i
].
x
,
$images
[
i
].
y
,
$images
[
i
].
width
,
$images
[
i
].
height
);
}
DomURL
.
revokeObjectURL
(
svgDataUrl
);
DomURL
.
revokeObjectURL
(
svgDataUrl
);
document
.
body
.
appendChild
(
canvas
);
return
generateDataUrl
(
canvas
);
return
generateDataUrl
(
canvas
);
});
});
}
}
if
(
bgUrl
)
{
if
(
bgUrl
)
{
return
loadImage
(
bgUrl
[
1
]).
then
(
function
(
image
)
{
var
bgInfo
=
{
url
:
bgUrl
[
1
]};
fillBackground
(
ctx
,
ctx
.
createPattern
(
image
,
'repeat'
));
return
loadImage
(
bgInfo
).
then
(
function
(
$image
)
{
fillBackground
(
ctx
,
ctx
.
createPattern
(
$image
.
element
,
"repeat"
));
return
drawSVG
();
return
drawSVG
();
});
});
}
else
{
}
else
{
...
@@ -141,12 +203,11 @@ define(function(require, exports, module) {
...
@@ -141,12 +203,11 @@ define(function(require, exports, module) {
return
drawSVG
();
return
drawSVG
();
}
}
}
}
data
.
registerProtocol
(
"png"
,
module
.
exports
=
{
data
.
registerProtocol
(
'png'
,
module
.
exports
=
{
fileDescription
:
"PNG 图片"
,
fileDescription
:
'PNG 图片'
,
fileExtension
:
".png"
,
fileExtension
:
'.png'
,
mineType
:
"image/png"
,
mineType
:
'image/png'
,
dataType
:
"base64"
,
dataType
:
'base64'
,
encode
:
encode
encode
:
encode
});
});
});
});
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment