"Christmas - the time to fix the computers of your loved ones" « Lord Wyrm

[Javascript] Grafik entlang einer Kurve verzerren

tinker 26.05.2016 - 19:21 2052 4
Posts

tinker

SQUEAK
Avatar
Registered: Nov 2005
Location: NÖ
Posts: 5221
Ahoi!

Ich arbeite gerade an einem Projekt bei dem es darum geht Winddaten durch Pfeile zu visualisieren. Dazu werden Streamlines berechnet um dann Pfeile entlang dieser Linien zu zeichnen. Die einfache Möglichkeit wäre wohl an das Ende einer solchen Streamline einen Pfeilmarker zu setzen. Aber ich würd lieber eine Pfeilgrafik entland der Linie verzerren.

Hab mir dazu mal nen SVG Pfeil in Inkscape gezeichnet. Dort kann ich den dann auch unter "Path Effect Editor" -> "Bend" mittels Bezier Kurve beliebig verzerren. Schaut dann zb. so aus:
arrow_example_214217.png

Jetzt such ich ne Javascript Library die genau das kann. Aber irgendwie werd ich nicht fündig. Entweder gibts sowas tatsächlich nicht oder ich finds nicht. CSS3 kann sowas mit Text, aber für beliebige SVG-Grafiken wirds damit nicht funktionieren. Und alles was ich an javascript-Libraries im Zusammenhang mit SVG finde, is entweder sehr basic (zeichnen von einfachen Shapes) oder kann zwar alle möglichen Animationen, aber keine Verzerrung entlang einer Kurve.

Hat hier vllt jemand ne Idee?

tia!

pinkey

Here to stay
Registered: Nov 2003
Location: Tirol/Wien
Posts: 2274
würd mich wundern wenn sowas mit z.B. d3 nicht geht

edit: sowas z.b.: http://bl.ocks.org/larskotthoff/7830074 bzw. http://jsfiddle.net/manojmcet/BcW8z/

hat halt leicht anderen anwendungsfall aber der beispielcode sollte reichen um pfeile in diversen formen zu zeichnen :)
Bearbeitet von pinkey am 26.05.2016, 20:05

tinker

SQUEAK
Avatar
Registered: Nov 2005
Location: NÖ
Posts: 5221
Danke, damit sind einfachen Pfeile problemlos möglich. Bei dem Pfeil aus meinem Beispiel oben bin ich mir aber nicht ganz sicher. Der besteht ja aus 7 Knoten mit Pfaden dazwischen die entsprechend verzerrt werden müssen.

Wobei, ich könnt den auch aus zwei einfachen zusammen setzen. Also ein größerer blauer mit nem kleineren weißen innerhalb. Werd mich mal rumspielen. Danke auf jeden Fall, hat mir gleich nen neuen Ansatz gebracht! :D

Vinci

hatin' on summer
Registered: Jan 2003
Location: Wien
Posts: 5821
Eventuell blöde Frage, aber muss es JavaScript sein?

Sonst nämlich Python + Matlab Plot :p
Bearbeitet von Vinci am 26.05.2016, 20:59

tinker

SQUEAK
Avatar
Registered: Nov 2005
Location: NÖ
Posts: 5221
Ja, da auf cesiumjs aufgebaut wird. :)
Kontakt | Unser Forum | Über overclockers.at | Impressum | Datenschutz