Mi piacerebbe essere in grado di impostare la larghezza del tratto su un elemento SVG in modo che sia "pixel-aware", che sia sempre 1px wide indipendentemente dalle trasformazioni di ridimensionamento correnti applicate. Sono consapevole che questo potrebbe essere impossibile, dal momento che l'intero punto di SVG deve essere indipendente dal pixel.Larghezza della corsa fissa in SVG
Contesto segue:
Ho un elemento SVG con la sua viewBox e preserveAspectRatio attributi impostati. Sembra qualcosa di simile
<svg version="1.1" baseProfile="full"
viewBox="-100 -100 200 200" preserveAspectRatio="xMidYMid meet"
xmlns="http://www.w3.org/2000/svg" >
</svg>
Ciò significa che quando mi scala quell'elemento, le forme effettive al suo interno scala di conseguenza (fin qui tutto bene).
Come potete vedere, ho impostato il viewBox in modo che l'origine sia al centro. Vorrei disegnare un x e un asse y all'interno di tale elemento, che faccio così:
<line x1="-1000" x2="1000" y1="0" y2="0" />
Di nuovo, questo funziona bene. Idealmente, tuttavia, questo asse sarebbe sempre largo solo 1px. Non mi interessa che gli assi diventino più grassi quando scala l'elemento svg genitore.
Quindi sono fregato?
Sfortunatamente questo è in un'app XUL e sembra che non supporti ancora l'effetto vettoriale. Oh bene. – wxs
Questo dovrebbe apparire in Firefox 15 tutto sta andando bene quindi dovresti essere in grado di usarlo una volta che hai creato la tua app XUL su gecko 15. –
IE11 non supporta ancora la proprietà 'vector-effect'. È possibile ottenere lo stesso effetto di "effetto vettoriale: non-scaling-stroke" in IE11? – merlin