gpt4 book ai didi

javascript - 使用 css 和 javascript 更改路径填写 svg 文件

转载 作者:行者123 更新时间:2023-11-29 16:13:35 26 4
gpt4 key购买 nike

好吧,我花了一整天的时间尝试将 css 样式与在 inkscape 中创建的 svg 文件“连接”起来。我有带有 map 和几个路径的 svg 文件,当我将鼠标悬停在该路径上时,我想更改填充颜色。拜托,你能帮我吗? :/。如果我正在创建

<img src="example.svg" />

,比我在 css 样式中放置的示例:

 <style type="text/css">
#path6666
{ fill: green;
}
</style>

什么都没发生。我不想使用 jquery,只使用 javascript 和 css。请帮忙!..

更新:

这是svg代码:

<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
id="svg2985"
version="1.1"
inkscape:version="0.48.4 r9939"
width="1176"
height="617"
sodipodi:docname="mainMapa.svg">
<metadata
id="metadata2991">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<defs
id="defs2989">
<inkscape:path-effect
effect="spiro"
id="path-effect3794"
is_visible="true" />
<inkscape:path-effect
effect="spiro"
id="path-effect3790"
is_visible="true" />
<inkscape:path-effect
effect="spiro"
id="path-effect3786"
is_visible="true" />
<inkscape:path-effect
effect="spiro"
id="path-effect3782"
is_visible="true" />
<inkscape:path-effect
effect="spiro"
id="path-effect3778"
is_visible="true" />
<inkscape:path-effect
effect="spiro"
id="path-effect2997"
is_visible="true" />
</defs>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1280"
inkscape:window-height="962"
id="namedview2987"
showgrid="false"
inkscape:zoom="0.97789116"
inkscape:cx="374.5729"
inkscape:cy="311.15508"
inkscape:window-x="-8"
inkscape:window-y="-8"
inkscape:window-maximized="1"
inkscape:current-layer="svg2985" />
<image
width="1176"
height="617"
xlink:href="data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD/
2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0a
HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy
BRRRQAUUUUAFFFFAB
RRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFF
FFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUU
UAFFFFABRRRQAUUUUAf/2Q==
"
id="image2993"
x="0"
y="0" />
<path
style="fill:#2b54e6;stroke:#281300;stroke-width:1px;stroke-linecap:butt;
stroke-linej oin:miter;stroke-opacity:1 ;fill -opacity:1"
d="m 308.82783,502.72348 3.57913,4.60174 5.36869,2.04521 5.11305,
3.57914 4.34608,3.83478 -0.76695,3.32348 -4.34609,4.09043 -3.57913,
1.27826 -4.09044,
-1.78956 -3.83478,-2.04522 -3.57913,-0.51131 -1.78956,-4.09043 -0.51131,
-5.62435 1.53391, -6.3913 z"
id="path3833"
inkscape:connector-curvature="0" />
</svg>

我开始放弃了。我不明白:inkscape 是非常流行的免费软件。为什么没有任何教程如何做到这一点?!

最佳答案

看起来你在这里遇到了三个问题:


样式级联问题

Inkscape 正在定义路径 #path3833 的填充在内联样式声明中。这比您的样式表规则更具体,因此它会覆盖它。

MDN has some good information about how the cascade works.

要解决您的问题,请在样式表中使用 !important关于覆盖 Inkscape 的内联样式的声明:

#path3833 {
fill:green !important; /* override inline style */
}

在 HTML 中托管 SVG

请注意 Robert Longson 的回答,使用 <object type="image/svg+xml" data=" [your file] ">而不是 <img>是准确的;您不能更改 img 中托管的 SVG 的任何部分标签。


将 CSS 链接到 SVG

静态链接

要链接样式表,您可以将以下 XML 声明添加到 SVG 文档:

<?xml-stylesheet type="text/css" href="your_style_sheet.css"?>

这应该位于开始 XML 声明之间 <?xml version="1.0" ... , 但在根之前 svg元素。通常这意味着它应该是文件的第二行。

动态链接

要通过 Javascript 添加样式表,您必须创建 XML 处理指令(即 <? ... ?> 标记)。 SVG document对象公开一个 method to do that .但是,获取对 SVG 文档的引用很棘手;你必须通过window.frames .这意味着您必须知道父 HTML 文档的哪个“框架”包含 SVG。如果您有一个 SVG 文件,这很容易。否则,您可能不得不反复试验。

无论如何,大致应该是这样的:

var frameNumber = 0; //this may vary depending on your page
var svgDoc = window.frames[frameNumber].document;
var procInstruction = svgDoc.createProcessingInstruction(
'xml-stylesheet', // the type of processing instruction
'type="text/css" href="your_style_sheet.css"' // the "data" of the PI
);
svgDoc.insertBefore( // the PI must come *before* the SVG root element
procInstruction, svgDoc.childNodes[0]
);

This fiddle演示了上述两种技术,使用数据 URI 而不是文件。我无法让动态部分与数据 URI 一起使用,但如果您可以改用文件,它就可以正常工作。 (Firefox v26/Win7)

关于javascript - 使用 css 和 javascript 更改路径填写 svg 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21080183/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com