Как создать SVG-подсказку?
Учитывая существующий действительный документ SVG, какой лучший способ создать "информационные всплывающие окна", так что, когда вы наводите или нажимаете на определенные элементы (скажем), вы выпадаете в поле с произвольной суммой (т.е. не только с одной строкой подсказка) дополнительной информации?
Это должно отображаться правильно, по крайней мере, в Firefox и быть невидимым, если изображение было растрировано в растровый формат.
Ответы
Ответ 1
<svg>
<text id="thingyouhoverover" x="50" y="35" font-size="14">Mouse over me!</text>
<text id="thepopup" x="250" y="100" font-size="30" fill="black" visibility="hidden">Change me
<set attributeName="visibility" from="hidden" to="visible" begin="thingyouhoverover.mouseover" end="thingyouhoverover.mouseout"/>
</text>
</svg>
Дальнейшее объяснение можно найти здесь.
Ответ 2
Этот вопрос был задан в 2008 году. SVG быстро улучшился в течение четырех лет. Теперь всплывающие подсказки полностью поддерживаются на всех платформах, о которых я знаю. Используйте тег <title>
(не атрибут), и вы получите встроенную подсказку.
Вот документы:
https://developer.mozilla.org/en-US/docs/SVG/Element/title
Ответ 3
Поскольку элемент <set>
не работает с Firefox 3, я думаю, вам нужно использовать ECMAScript.
Если вы добавите в свой SVG следующий элемент script:
<script type="text/ecmascript"> <![CDATA[
function init(evt) {
if ( window.svgDocument == null ) {
// Define SGV
svgDocument = evt.target.ownerDocument;
}
tooltip = svgDocument.getElementById('tooltip');
}
function ShowTooltip(evt) {
// Put tooltip in the right position, change the text and make it visible
tooltip.setAttributeNS(null,"x",evt.clientX+10);
tooltip.setAttributeNS(null,"y",evt.clientY+30);
tooltip.firstChild.data = evt.target.getAttributeNS(null,"mouseovertext");
tooltip.setAttributeNS(null,"visibility","visible");
}
function HideTooltip(evt) {
tooltip.setAttributeNS(null,"visibility","hidden");
}
]]></script>
Вам нужно добавить onload="init(evt)"
в элемент SVG, чтобы вызвать функцию init().
Затем, до конца SVG, добавьте текст всплывающей подсказки:
<text id="tooltip" x="0" y="0" visibility="hidden">Tooltip</text>
Наконец, каждому элементу, который вы хотите добавить функцию mouseover, добавьте:
onmousemove="ShowTooltip(evt)"
onmouseout="HideTooltip(evt)"
mouseovertext="Whatever text you want to show"
Я написал более подробное объяснение с улучшенной функциональностью на http://www.petercollingridge.co.uk/interactive-svg-components/tooltip
Я еще не включил многострочные подсказки, для которых потребуется несколько элементов <tspan>
и ручная перенос слов.
Ответ 4
Это должно работать:
nodeEnter.append("svg:element")
.style("fill", function(d) { return d._children ? "lightsteelblue" : "#fff"; })
.append("svg:title")
.text(function(d) {return d.Name+"\n"+d.Age+"\n"+d.Dept;}); // It shows the tool tip box with item [Name,Age,Dept] and upend to the svg dynamicaly