我有一個包含2個符號的SVG sprite, 第二個符號使用第一個符號。 我需要將它分離成精靈,因爲我多次使用圖標。動畫使用SVG sprite圖標的SVG對象
我的問題是,我不能以我需要的方式爲對象設置動畫,希望有人可以提供幫助。 基本上它帶有一個圖標的按鈕,一旦我點擊它,我改變了20%的比例+爲不同顏色的顏色過渡和筆觸過渡設置了動畫效果。 目前我設法引用jQuery的各種符號部分,我不認爲它正確的方式,因爲我明白它假設是一個獨立的對象。
基本上我需要點擊按鈕來縮放+運輸顏色填充+運輸顏色筆劃 。
$('#shape2').on('click', function(a, v, b) {
$(this).velocity({
scale: 0.99,
duration: 100,
complete: function() {
$(this).velocity({
scale: 1.4
}, {
duration: 1000
});
//i don't want to do this, i want to access it as an object (this), but i cannot
$("#icon_2").find('circle').velocity({
fill: '#00b2ff',
duration: 1000,
complete: function() {
$("#icon_1").find("path").velocity({
stroke: "#fff",
queue: false
}, 1000);
}
});
}
});
})
.st0 {
fill: none;
stroke: #0083ED;
stroke-miterlimit: 5;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.2/velocity.js"></script>
<svg width="0" height="0">
<defs>
<symbol id="icon_1" viewBox="0 0 50 50" class="st0">
<path d="M10.6 29.3h14.5V44H10.6z" />
<path d="M25 29.3h14.5V44H25zm-7.2-14.7h14.5v14.7H17.8zm0 0l3.9-4m10.6 4l3.9-4m-3.9 18l3.9-3.7m-25.6 4.4l4.3-4.4m24.6 4.7l3.9-4M39.5 44l3.9-4M21.2 10.6h15M14.5 24.9h3.3m17.7.6h7.9M36.2 10v15.5m7.2.1V40" />
</symbol>
<symbol id="icon_2">
<circle cx="50" cy="50" r="48" fill="#dcf2f8" stroke="white" stroke-width="2" />
<use x="7" y="5" width="80" height="80" xlink:href="#icon_1"></use>
</symbol>
</defs>
</svg>
<!-- s v g --------------------------------- -->
<svg width='100' height='100' id="shape2">
<use xlink:href="#icon_2"></use>
</svg>
<!-- s v g --------------------------------- -->
感謝!!!!!!!!!! – danikoren