Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-08-2015, 15:20   #1
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1383
[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


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Roscosmos ha lanciato il satellite meteo...
Starship Troopers: Ultimate Bug Wars, to...
Il razzo spaziale europeo Ariane 6, per ...
Oracle Fusion Cloud Applications si pote...
OHB Italia svilupperà un satellit...
Fortinet: "Ora abbiamo una chance d...
Linux Mint chiude con gli aggiornamenti ...
Compressori portatili auto in sconto su ...
Durante il lancio della missione USSF-87...
Dopo il ritiro di Intel da Magdeburgo, l...
Xiaomi 15T scende a 388€ su Amazon: 12GB...
MSI Afterburner: arriva il monitoraggio ...
Missione cinese Chang'e-6: confermata l'...
Addio esenzione sotto i 150 euro: l'UE i...
Allarme riavvii su Windows 11 dopo il ri...
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: 19:21.


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