Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-08-2015, 14:20   #1
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1385
[Javascript] Aggiungere elemento <a>

Ho la necessità di trasformare alcuni hotspot di immagini SVG in elementi cliccabili.
Non posso sfruttare l'evento onclick perchè le immagini saranno mostrate su android e in webview l'evento onclick non c'è a meno di rinunciare al pan e allo zoom con le dita.

Devo per forza quindi introdurre nelle svg degli elementi <a> al caricamento. In questo modo posso poi cliccarci sopra con ilo dito. Gli hotspot sono rappresentati da dei cerchi e hanno un id.
Ho quindi realizzato questa funzione che disegna un cerchio più grande intorno a quello iniziale e lo mette all'interno di un tag <a> in modo che sia cliccabile.

Il cerchio compare perfettamente ma la zona non è cliccabile. La cosa stranissima è che se tramite console.log prendo le modifiche fatte dal javascript e le copio manualmente nel file allora tutto funziona.

Codice:
<html>
<head>
</head>
<body>

<object width=100%  height=100% id="svgObject" type="image/svg+xml" data="prova.svg"></object>

<script>
function hotspoHyperlink(elemento){
	var a = document.getElementById("svgObject");
	var svgDoc = a.contentDocument;
	var svgItem = svgDoc.getElementById(elemento);
	if (svgItem=="[object SVGCircleElement]"){	
		var r = svgItem.getAttributeNode("r");
		var stroke_width = svgItem.getAttributeNode("stroke-width");
		var transform = svgItem.getAttributeNode("transform");

		var newR = document.createAttribute("r");
		newR.value=2*r.value;
		var newStroke_width = document.createAttribute("stroke-width");
		newStroke_width.value=stroke_width.value;
		var newTransform = document.createAttribute("transform");
		newTransform.value=transform.value;
		var stroke = document.createAttribute("stroke");
		stroke.value="#00FF00";
		var newItem = document.createElementNS("http://www.w3.org/2000/svg","circle");
		var opacity = document.createAttribute("opacity");
		opacity.value= 0.5;
		newItem.setAttributeNode(newR);
		newItem.setAttributeNode(newStroke_width);
		newItem.setAttributeNode(newTransform);
		newItem.setAttributeNode(stroke);
		newItem.setAttributeNode(opacity);
		
		var linkTag = document.createAttribute("xlink:href");
		linkTag.value="https://www.google.it";
		var targetLink = document.createAttribute("target");
		targetLink.value="_top";
		var link = document.createElementNS("http://www.w3.org/2000/svg","a");
		link.setAttributeNode(linkTag);
		link.setAttributeNode(targetLink);
		link.appendChild(newItem);		
		
		svgItem.parentNode.insertBefore(link, svgItem.nextSibling);
	}
}
</script>
 <button onclick="hotspoHyperlink('hotspot1')">Click</button> 
</body>
</html>
Cosa può essere ? Succede lo stesso con firefox e IE.
das è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Si è conclusa la missione lunare ...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
Little Snitch su Linux: finalmente dispo...
John Deere accetta un accordo da 99 mili...
Gli astronauti di Artemis II osservano i...
OpenAI lancia ChatGPT Pro da 100 dollari...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:55.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v