Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / HTML, JavaScript, VBScript, CSS [игнор отключен] [закрыт для гостей] / SVG, USE и смена стиля из JavaScript (JQuery) / 1 сообщений из 1, страница 1 из 1
13.12.2016, 09:53
    #39365467
Игорь Ч
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
SVG, USE и смена стиля из JavaScript (JQuery)
только начал изучать SVG поэтому строго не судите за корявости.
Цель такая, на страничке нужно показать несколько аналоговых часиков, которые должны показывать разное время.
с оформлением часиков проблем не возникло. нарисовал циферблат, три стрелки, для каждой стрелки создал свой стиль, для указания угла поворота. С помощью <USE> сделал клон и передал в стиле угловые параметры стрелок, все работает. Проблема возникает со сменой стиля из jquery... стиль ни в какую не меняется, что я не так делаю?
Код: html
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
			<svg id="clock" width="200px" height="100px" version="1.1" xmlns="http://www.w3.org/2000/svg">
				<defs>
					<g id="cl" viewBox="0, 0, 100, 100">
						<circle id="ciferblat" cx="50" cy="50" r="45" fill="skyblue" style="stroke-width: 1; stroke: black;"/>
						<g id="riska">
							<line x1="50" y1="5" x2="50" y2="10" style="stroke-width: 1; stroke: black;"/>
							<line id="riska1" x1="50" y1="5" x2="50" y2="8" style="stroke-width: 0.5; stroke: black;" transform="rotate(6, 50, 50)"/>
							<use xlink:href="#riska1" transform="rotate(6, 50, 50)"/>
							<use xlink:href="#riska1" transform="rotate(12, 50, 50)"/>
							<use xlink:href="#riska1" transform="rotate(18, 50, 50)"/>
						</g>	
						<text x="43" y="22" font-size="12">12</text>
						<use xlink:href="#riska" transform="rotate(30, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(30, 50, 50) rotate(-30, 50, 17.5)">1</text>
						<use xlink:href="#riska" transform="rotate(60, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(60, 50, 50) rotate(-60, 50, 17.5)">2</text>
						<use xlink:href="#riska" transform="rotate(90, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(90, 50, 50) rotate(-90, 50, 17.5)">3</text>
						<use xlink:href="#riska" transform="rotate(120, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(120, 50, 50) rotate(-120, 50, 17.5)">4</text>
						<use xlink:href="#riska" transform="rotate(150, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(150, 50, 50) rotate(-150, 50, 17.5)">5</text>
						<use xlink:href="#riska" transform="rotate(180, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(180, 50, 50) rotate(-180, 50, 17.5)">6</text>
						<use xlink:href="#riska" transform="rotate(210, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(210, 50, 50) rotate(-210, 50, 17.5)">7</text>
						<use xlink:href="#riska" transform="rotate(240, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(240, 50, 50) rotate(-240, 50, 17.5)">8</text>
						<use xlink:href="#riska" transform="rotate(270, 50, 50)"/>
						<text x="46.5" y="22" font-size="12" transform="rotate(270, 50, 50) rotate(-270, 50, 17.5)">9</text>
						<use xlink:href="#riska" transform="rotate(300, 50, 50)"/>
						<text x="43" y="22" font-size="12" transform="rotate(300, 50, 50) rotate(-300, 50, 17.5)">10</text>
						<use xlink:href="#riska" transform="rotate(330, 50, 50)"/>
						<text x="43" y="22" font-size="12" transform="rotate(330, 50, 50) rotate(-330, 50, 17.5)">11</text>
						<line id="hour_hand" x1="50" y1="30" x2="50" y2="60" style="stroke-width: 3; stroke: black; transform:rotate(var(--hour-hand));transform-origin: 50px 50px;"/>
						<line id="minute_hand" x1="50" y1="14" x2="50" y2="60" style="stroke-width: 2; stroke: black; transform:rotate(var(--minute-hand));transform-origin: 50px 50px;"/>
						<circle cx="50" cy="50" r="3" fill="black"/>
						<line id="second_hand" x1="50" y1="10" x2="50" y2="60" style="stroke-width: 1; stroke: red; transform:rotate(var(--second-hand));transform-origin: 50px 50px;"/>
						<circle cx="50" cy="50" r="2" fill="red"/>
					</g>	
				</defs>	
				<use id="#cl0" xlink:href="#cl" x="0" y="0" style="--hour-hand:215deg; --minute-hand:135deg; --second-hand:75deg"/>
				<use id="#cl2" xlink:href="#cl" x="100" y="0"/>
			</svg>


Код: javascript
1.
2.
3.
				function clock_set(jsn){
					$('#cl0').css("--second-hand", "180deg");
				}
...
Рейтинг: 0 / 0
Форумы / HTML, JavaScript, VBScript, CSS [игнор отключен] [закрыт для гостей] / SVG, USE и смена стиля из JavaScript (JQuery) / 1 сообщений из 1, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]