Rumah >hujung hadapan web >Tutorial H5 >Pengenalan kepada SVG 2D dalam HTML5 2—Pengenalan dan penggunaan lukisan grafik (bentuk asas)_html5 kemahiran tutorial

Pengenalan kepada SVG 2D dalam HTML5 2—Pengenalan dan penggunaan lukisan grafik (bentuk asas)_html5 kemahiran tutorial

WBOY
WBOYasal
2016-05-16 15:50:051772semak imbas

Bentuk asas
SVG menyediakan banyak bentuk asas Elemen ini boleh digunakan secara langsung, yang jauh lebih baik daripada kanvas. Berhenti bercakap karut dan lihat contoh secara langsung Ini adalah yang paling langsung:

Salin kod
Kodnya adalah sebagai. berikut:







isian = "orange" transparent" stroke-width=" 5"/>




Hasil yang dipaparkan oleh HTML ini adalah seperti berikut:


Contoh ini melukis pelbagai bentuk: segi empat tepat biasa, segi empat tepat dengan bucu bulat, bulatan, elips, garis lurus, poligaris, poligon dan laluan. Ini adalah elemen grafik asas. Walaupun terdapat banyak cara untuk melukis grafik, sebagai contoh, segi empat tepat boleh dilaksanakan menggunakan rect atau path, dsb., kita harus tetap cuba memastikan kandungan SVG pendek, padat dan mudah dibaca .

Berikut adalah arahan untuk menggunakan setiap bentuk (di sini kami hanya memperkenalkan atribut asas yang mengawal bentuk dan kedudukan grafik, dan atribut seperti pengisian akan diringkaskan kemudian).

Segi empat tepat - elemen tegak
Elemen ini mempunyai 6 atribut yang mengawal kedudukan dan bentuk, iaitu:
x: koordinat penjuru kiri sebelah atas segi empat tepat (sistem koordinat pengguna) nilai x.
y: Nilai y bagi koordinat penjuru kiri sebelah atas segi empat tepat (sistem koordinat pengguna).
lebar: lebar segi empat tepat.
tinggi: ketinggian segi empat tepat.
rx: Apabila mencapai kesan bucu bulat, jejari bucu bulat di sepanjang paksi-x.
ry: Apabila mencapai kesan bucu bulat, jejari bucu bulat di sepanjang paksi-y.
Sebagai contoh, dalam contoh di atas, kesan bucu bulat dicapai Anda juga boleh mencapai kesan sudut elips dengan menetapkan rx dan ry kepada nilai yang berbeza.

Bulatan - elemen bulatan
Atribut unsur ini sangat mudah, terutamanya mentakrifkan pusat dan jejari bulatan:
r: jejari bagi bulatan.
cx: nilai x koordinat tengah bulatan.
cy: nilai koordinat pusat bulatan y.

Elips - elemen elips
Ini adalah elemen pekeliling yang lebih umum Anda boleh mengawal panjang paksi separuh utama dan paksi separuh kecil secara berasingan untuk merealisasikan perbezaan elips , adalah mudah untuk berfikir bahawa apabila kedua-dua separuh paksi adalah sama, ia adalah bulatan sempurna.
rx: paksi separuh utama (jejari x).
ry: paksi separuh kecil (jejari y).
cx: nilai x koordinat tengah bulatan.
cy: nilai koordinat pusat bulatan y.

Garis lurus - elemen garis
Garis lurus perlu menentukan titik permulaan dan titik akhir:

x1: x koordinat titik permulaan.
y1: y koordinat titik permulaan.
x2: x koordinat titik akhir.
y2: koordinat y bagi titik akhir.

Polyline - elemen polyline
Polyline mentakrifkan terutamanya titik akhir setiap segmen garis, jadi hanya koleksi titik diperlukan sebagai parameter:

mata: Satu siri titik yang dipisahkan oleh ruang, koma, baris baharu, dsb. Setiap titik mesti mempunyai 2 nombor: nilai x dan nilai y. Jadi tiga titik (0,0), (1,1) dan (2,2) berikut boleh ditulis sebagai: "0 0, 1 1, 2 2".

Polygon - elemen poligon
Elemen ini melakukan satu langkah lagi daripada elemen polyline, menyambungkan titik terakhir ke titik pertama untuk membentuk rajah tertutup. Parameternya adalah sama.
mata: Satu siri titik yang dipisahkan oleh ruang, koma, baris baharu, dsb. Setiap titik mesti mempunyai 2 nombor: nilai x dan nilai y. Jadi tiga titik (0,0), (1,1) dan (2,2) berikut boleh ditulis sebagai: "0 0, 1 1, 2 2".

Path - elemen laluan
Ini adalah elemen yang paling serba boleh dan berkuasa dengan menggunakan elemen ini, anda boleh merealisasikan mana-mana grafik lain, bukan sahaja Bentuk asas di atas juga boleh dicapai bentuk kompleks seperti lengkung Bezier di samping itu, menggunakan laluan boleh mencapai segmen garisan peralihan yang lancar Walaupun polyline juga boleh digunakan untuk mencapai kesan ini, terdapat banyak mata yang perlu disediakan, dan kesan pembesaran adalah tidak baik. Elemen ini mengawal kedudukan dan bentuk dengan hanya satu parameter:
d: satu siri arahan lukisan dan parameter lukisan (titik) digabungkan.

Arahan lukisan terbahagi kepada dua jenis: arahan koordinat mutlak dan arahan koordinat relatif Huruf yang digunakan dalam kedua-dua arahan ini adalah sama, tetapi huruf besar adalah berbeza Arahan mutlak menggunakan huruf besar, dan koordinat juga mutlak koordinat; arahan relatif menggunakan huruf kecil yang sepadan dan koordinat titik mewakili offset.

Arahan lukisan koordinat mutlak
Parameter kumpulan arahan ini mewakili koordinat mutlak. Dengan mengandaikan bahawa kedudukan semasa berus ialah (x0, y0), maksud arahan koordinat mutlak berikut adalah seperti berikut:

指令 参数 说明
M x y 将画笔移动到点(x,y)
L x y 画笔从当前的点绘制线段到点(x,y)
H 画笔从当前的点绘制水平线段到点(x,y0)
V 画笔从当前的点绘制竖直线段到点(x0,y)
A rx ry x-axis-rotation large-arc-flag sweep-flag x y 画笔从当前的点绘制一段圆弧到点(x,y)
C x1 y1, x2 y2, x y 画笔从当前的点绘制一段三次贝塞尔曲线到点(x,y)
S x2 y2, x y 特殊版本的三次贝塞尔曲线(省略第一个控制点)
Q x1 y1, x y  绘制二次贝塞尔曲线到点(x,y)
T x y 特殊版本的二次贝塞尔曲线(省略控制点)
Z 无参数 绘制闭合图形,如果d属性不指定Z命令,则绘制线段,而不是封闭图形。

Gerakkan perintah berus M, lukis arahan garis lurus: L, H, V, perintah tutup Z agak mudah; mari fokus pada beberapa arahan untuk melukis lengkung.

Arahan lukisan arka: A rx ry x-axis-rotation large-arc-flag sweep-flag x y
Menggunakan arka untuk menyambung 2 titik adalah lebih rumit dan terdapat banyak situasi, jadi ini Perintah mempunyai 7 parameter, yang mengawal pelbagai atribut lengkung. Berikut menerangkan maksud nilai:
rx,ry ialah panjang paksi separuh utama dan paksi separuh kecil lengkok
putaran paksi-x ialah sudut antara paksi-x di mana ini arka terletak dan arah mendatar, iaitu, paksi-x Sudut putaran lawan jam, nombor negatif mewakili sudut putaran mengikut arah jam.
bendera-lengkok besar ialah 1 untuk lengkok sudut besar dan 0 untuk lengkok sudut kecil.
Bendera sapuan ialah 1, yang bermaksud lengkok mengikut arah jam mengelilingi pusat dari titik permulaan ke titik penamat, dan 0, iaitu arah lawan jam.
x,y ialah koordinat terminal arka.
Saya tidak akan menerangkan secara terperinci tentang dua parameter pertama dan dua parameter terakhir, ia sangat mudah, mari kita bercakap tentang tiga parameter tengah:
x-axis-rotation mewakili sudut putaran arka dalam contoh di bawah Perbezaannya:

Salin kod
Kodnya adalah seperti berikut:





HTML di atas melukis grafik berikut:

Anda boleh melihat dari gambar bahawa parameter putaran yang berbeza bagi elips membawa kepada arah yang berbeza bagi lengkok yang dilukis Sudah tentu, parameter ini tidak mempunyai kesan pada bulatan sempurna.

bendera-lengkok besar dan bendera sapuan mengawal saiz dan arah lengkok. Alami perbezaan lengkok dalam contoh berikut:



Salin. kod Kod adalah seperti berikut:







HTML ini melukis gambar berikut:

Seperti yang dapat dilihat daripada di atas, parameter ini sebenarnya adalah satu-satunya parameter yang diperlukan untuk menentukan lengkok. Kami juga melihat di sini bahawa arka dalam SVG adalah lebih rumit daripada dalam kanvas.


Arahan untuk melukis lengkung Bezier kubik: C x1 y1, x2 y2, x y Keluk Bezier kubik mempunyai dua titik kawalan, iaitu (x1, y1) dan (x2, y2) yang terakhir (x, y) mewakili titik akhir lengkung. Alami contoh berikut:



Salin kodKodnya adalah seperti berikut:

< laluan d="M70 10 C 70 20, 120 20, 120 10" stroke="black" fill="transparent"/>









Coretan HTML ini melukis grafik berikut:

Daripada perkara di atas kita dapat melihat bahawa titik kawalan mengawal lengkok lengkok.

Versi khas lengkung Bezier kubik: S x2 y2, x y

Banyak kali, untuk melukis lengkung yang licin, perlu melukis lengkungan beberapa kali secara berterusan. Pada masa ini, untuk melicinkan peralihan, titik kawalan lengkung kedua selalunya merupakan titik pemetaan titik kawalan lengkung pertama di sisi lain lengkung. Versi ringkas ini boleh digunakan pada masa ini. Apa yang perlu diperhatikan di sini ialah jika tiada arahan S atau arahan C lain sebelum arahan S, kedua-dua titik kawalan akan dianggap sama pada masa ini dan merosot menjadi lengkung Bezier kuadratik jika arahan S digunakan dalam yang lain Selepas arahan S atau arahan C, titik kawalan pertama bagi arahan S berikutnya akan ditetapkan secara lalai kepada titik pemetaan titik kawalan kedua lengkung sebelumnya 🎜>

Salin kod
Kod adalah seperti berikut:



Serpihan HTML ini melukis grafik berikut:

Arahan S di atas hanya mempunyai titik kawalan kedua, dan titik kawalan pertama menggunakan titik pemetaan titik kawalan kedua arahan lengkung sebelumnya.

Arahan untuk melukis lengkung Bezier kuadratik: Q x1 y1, x y, T x y (versi khas lengkung Bezier kuadratik)


Lengkung Bezier Kuadratik sahaja Titik kawalan (x1, y1) , biasanya seperti yang ditunjukkan di bawah:

Jika anda melukis lengkung berterusan, anda juga boleh menggunakan versi mudah T. Begitu juga, apabila T didahului oleh perintah Q atau T, titik kawalan perintah T seterusnya akan ditetapkan ke titik pemetaan titik kawalan lengkung sebelumnya secara lalai:



Salin kod
Kod adalah seperti berikut:



Serpihan HTML ini dilukis seperti Grafik berikut:

Begitu juga, jika arahan T tidak didahului dengan arahan Q atau T, ia dianggap tiada titik kawalan dan dilukis garis lurus.


Arahan lukisan koordinat relatif

mempunyai huruf yang sama dengan arahan lukisan koordinat mutlak, kecuali semuanya huruf kecil. Parameter yang melibatkan koordinat dalam parameter set arahan ini mewakili koordinat relatif, yang bermaksud bahawa parameter mewakili offset dari titik semasa ke titik sasaran Nombor positif mewakili offset positif kepada paksi, dan nombor negatif mewakili a anjakan terbalik. Walau bagaimanapun, untuk arahan Z, tiada perbezaan antara huruf besar dan kecil.
Perlu diperhatikan di sini bahawa
arahan koordinat mutlak dan arahan koordinat relatif boleh dicampur

. Kadang-kadang pencampuran boleh membawa kepada kaedah lukisan yang lebih fleksibel.

Nota melukis laluan SVG:

Apabila melukis grafik dengan lubang, sila ambil perhatian: tepi luar perlu dilukis mengikut turutan lawan jam dan tepi dalam lubang Urutan mesti mengikut arah jam. Hanya dengan cara ini kesan pengisian grafik yang dilukis adalah betul.
Rujukan praktikal:

Indeks skrip: http://msdn.microsoft.com/zh-cn/library/ff971910(v=vs.85).aspx
Pusat Pembangunan: https://developer.mozilla.org/en/SVG
Rujukan Popular: http://www.chinasvg.com/
Dokumentasi rasmi: http://www.w3.org/TR/SVG11/

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn