Baru -baru ini, saya terpaksa membina halaman laporan yang dapat menunjukkan peta Itali di mana setiap rantau mempunyai nada warna yang berbeza mengikut beberapa nilai yang diambil dari pangkalan data. Terima kasih kepada SVG, tugas ini sangat mudah.
Takeaways Key
Setiap rantau ditarik sebagai objek tunggal, dan masing -masing mempunyai tahap sendiri, dengan nama yang sepadan dengan kod yang digunakan dalam pangkalan data untuk mengenal pasti data relatifnya (contohnya: "TOS" untuk Tuscany).
Akhirnya peta mesti disimpan sebagai fail SVG. Anda perlu memberi perhatian untuk menetapkan pilihan "CSS Property" kepada "Elemen Gaya" dalam Illustrator, seperti yang ditunjukkan di bawah:
Membuka fail yang baru dibuat, anda akan melihatnya mengandungi satu set tag G yang ID yang sepadan dengan nama tahap ilustrator.
Setiap item yang terkandung dalam tag G mempunyai kelas ST0 supaya strok dan mengisi sifat CSS dapat diberikan kepada mereka:
Sekarang, kita boleh menggunakan kod itu untuk membina fail HTML kami dengan SVG sebaris seperti yang ditunjukkan di bawah (kod telah dipendekkan untuk kemudahan):
<span><span><!doctype html></span> </span><span><span><span><html</span>></span> </span><span><span><span><head</span>></span> </span> <span><span><span><meta</span> charset<span>="UTF-8"</span>></span> </span> <span><span><span><title</span>></span>Map Sample<span><span></title</span>></span> </span> <span><span><span><style</span> type<span>="text/css"</span> media<span>="all"</span>></span><span> </span></span><span><span> <span><span>.map svg</span> { </span></span></span><span><span> <span>height: auto; </span></span></span><span><span> <span>width: 350px; </span></span></span><span><span> <span>} </span></span></span><span><span> <span><span>.map g</span> { </span></span></span><span><span> <span>fill: #ccc; </span></span></span><span><span> <span>stroke: #333; </span></span></span><span><span> <span>stroke-width: 1; </span></span></span><span><span> <span>} </span></span></span><span><span> </span><span><span></style</span>></span> </span><span><span><span></head</span>></span> </span><span><span><span><body</span>></span> </span> <span><span><span><div</span> class<span>="map"</span>></span> </span> <span><span><span><svg</span> version<span>="1.1"</span> id<span>="Livello_1"</span> xmlns<span>="https://www.w3.org/2000/svg"</span> <span>xmlns:xlink</span><span>="https://www.w3.org/1999/xlink"</span> x<span>="0px"</span> y<span>="0px"</span> viewBox<span>="0 -21.6 761 919"</span> <span>style<span>="<span>enable-background:new 0 -21.6 761 919;</span>"</span></span> <span>xml:space</span><span>="preserve"</span>></span> </span> <span><span><span><g</span> id<span>="sar"</span>></span> </span> <span><span><span><polygon</span> class<span>="st0"</span> points<span>="193,463 ... "</span>/></span> </span> <span><span><span></g</span>></span> </span> <span><!-- etc ... --> </span> <span><span><span></svg</span>></span> </span> <span><span><span></div</span>></span> </span><span><span><span></body</span>></span> </span><span><span><span></html</span>></span></span>
Anda dapat melihat bahawa atribut gaya di dalam tag SVG telah dipadamkan dan digantikan oleh yang baru yang terletak di dalam kepala dokumen; Semua elemen G pada mulanya dipenuhi dengan kelabu muda.
Kelas ST0 tidak lagi digunakan (anda boleh mengeluarkannya dari kod SVG anda) dan ia telah digantikan oleh pemilih .map g. Bagaimanapun, ini tidak wajib, anda boleh menggunakan pemilih CSS yang anda suka.
Langkah kedua terdiri daripada mengikat peta kami ke beberapa data yang diambil dari pangkalan data kami. Dalam contoh ini, matlamat kami adalah untuk melukis peta mengikut populasi setiap rantau.
Data diambil dalam format JSON dan disisipkan secara langsung di dalam fail HTML kami (di dunia nyata, tentu saja, data akan diambil menggunakan AJAX atau serupa).
sekarang halaman kami akan mengandungi JSON dalam fail JavaScript kami yang kelihatan seperti ini (sekali lagi, disingkat):
<span>var regions=[ </span> <span>{ </span> <span>"region_name": "Lombardia", </span> <span>"region_code": "lom", </span> <span>"population": 9794525 </span> <span>}, </span> <span>{ </span> <span>"region_name": "Campania", </span> <span>"region_code": "cam", </span> <span>"population": 5769750 </span> <span>}, </span> <span>// etc ... </span> <span>];</span>
Selepas itu, warna dipilih (dalam kes ini, #0B68AA), dan kami memberikannya ke rantau ini dengan nilai penduduk tertinggi. Kawasan lain akan berwarna dengan nada warna utama mengikut peratusan penduduknya.
Seterusnya kita boleh menambah beberapa JavaScript.
Pertama sekali, kita perlu menentukan rantau ini dengan nilai penduduk maksimum. Ini boleh dilakukan dengan beberapa baris kod.
Setelah array sementara yang mengandungi nilai populasi telah dibina, kita boleh menggunakan kaedah matematik.
<span>var temp_array= regions.map( function( item ) { </span> <span>return item.population; </span><span>}); </span> <span>var highest_value = Math.max.apply( Math, temp_array );</span>
populasi / nilai maksimum (dengan sedikit bantuan dari jQuery):
<span>$(function() { </span> <span>for(i=0; i < regions.length; i++) { </span> <span>$('#'+ regions[i].region_code).css({'fill': 'rgba(11, 104, 170,' </span> <span>+ regions[i].population/highest_value </span> <span>+ ')'}); </span> <span>} </span><span>});</span>
Menambah interaktiviti dengan CSS dan JQuery
Pertama, kami menambah peraturan CSS untuk G: Hover dan kelas info_panel baru untuk gaya kotak maklumat kami:
Pengubahsuaian penting dalam .map g: hover diperlukan untuk memperbaiki kekhususan
<span><span>.map g:hover</span> { </span> <span>fill: #fc0 !important; </span> <span>cursor: help; </span><span>} </span> <span><span>.info_panel</span> { </span> <span>background-color: <span>rgba(255,255,255, .7)</span>; </span> <span>padding: .3em; </span> <span>font-size: .8em; </span> <span>font-family: Helvetica, Arial, sans-serif; </span> <span>position: absolute; </span><span>} </span> <span><span>.info_panel::first-line</span> { </span> <span>font-weight: bold; </span><span>}</span>
peraturan pengisian, jika tidak, ia akan dilangkau dengan disuntik CSS. maka kita perlu mengubah suai sebelumnya untuk kitaran, menambah .data () untuk menyimpan maklumat yang akan dipaparkan pada hover:
Akhirnya, kami dapat menyelesaikan skrip kami dengan menambahkan beberapa kesan tetikus:
<span>for (i = 0; i < regions.length; i++) { </span> <span>$('#'+ regions[i].region_code) </span> <span>.css({'fill': 'rgba(11, 104, 170,' </span> <span>+ regions[i].population/highest_value </span> <span>+')'}).data('region', regions[i]); </span><span>}</span>
Bagaimana ia berfungsi: inilah hasil akhir pada codepen: lihat pena kdhfh oleh sitepoint (@sitePoint) pada codepen. Membuat responsif peta SVG anda melibatkan penetapan lebar dan ketinggian SVG hingga 100% dan memastikan atribut viewBox ditetapkan dengan betul. Atribut Viewbox membolehkan anda menentukan bahawa kawasan tertentu peta dapat dilihat dan nisbah aspek dipelihara apabila meningkat atau turun. Anda juga boleh menggunakan pertanyaan media untuk menyesuaikan saiz dan kedudukan peta berdasarkan saiz skrin. digunakan dengan perpustakaan JavaScript lain seperti D3.js, Raphael, dan Snap.svg. Perpustakaan ini menyediakan fungsi tambahan untuk mewujudkan dan memanipulasi grafik SVG. Walau bagaimanapun, pelaksanaan mungkin berbeza dari jQuery, jadi anda perlu merujuk kepada dokumentasi perpustakaan masing -masing. Peta SVG menggunakan JavaScript atau JQuery. Ini termasuk ciri -ciri seperti tooltip, zooming, panning, dan kawasan yang boleh diklik. Sebagai contoh, anda boleh menggunakan acara 'Mouseover' dan 'Mouseout' untuk memaparkan petua, dan acara 'klik' untuk membuat kawasan diklik. 🎜> Peta SVG boleh digunakan untuk visualisasi data dengan mewarna kawasan berdasarkan nilai data, teknik yang dikenali sebagai pemetaan choropleth. Anda boleh menggunakan JavaScript untuk mengikat data ke elemen SVG anda dan menggunakan skala warna. Perpustakaan seperti D3.js menyediakan fungsi terbina dalam untuk membuat peta choropleth. Jika kawasan peta SVG anda tidak dipaparkan dengan betul, ia mungkin disebabkan oleh beberapa sebab. Fail SVG mungkin tidak diformatkan dengan betul, atau mungkin terdapat ralat dalam kod JavaScript anda. Semak konsol untuk sebarang mesej ralat dan pastikan fail SVG anda sah. Bagaimana saya boleh menghidupkan peta SVG saya? Ini termasuk menghidupkan warna, bentuk, dan kedudukan elemen SVG anda. Perlu diingat bahawa animasi yang kompleks boleh memberi kesan kepada prestasi, jadi gunakannya dengan berhati -hati. SVG disokong dalam pandangan web Android dan iOS, dan boleh digunakan dalam aplikasi mudah alih hibrid menggunakan rangka kerja seperti Cordova atau React Native. Walau bagaimanapun, perlu diingat bahawa prestasi boleh menjadi masalah pada peranti lama atau peta kompleks.
Soalan Lazim (Soalan Lazim) pada Peta Geo Dinamik dengan SVG dan JQuery
Bagaimana saya boleh membuat peta SVG saya responsif?
Bagaimana saya boleh membuat peta svg tersuai? Adobe Illustrator atau Inkscape, dan kemudian mengeksportnya sebagai fail SVG. Anda kemudian boleh menggunakan JavaScript atau JQuery untuk memanipulasi elemen SVG dan menambah interaktiviti. Perlu diingat bahawa membuat peta tersuai memerlukan pemahaman yang baik mengenai data SVG dan geografi.
Kenapa kawasan peta SVG saya tidak memaparkan dengan betul?
Bolehkah saya menggunakan peta SVG dalam semua pelayar? Safari, dan tepi. Walau bagaimanapun, versi lama Internet Explorer (IE8 dan ke bawah) tidak menyokong SVG. Jika anda perlu menyokong penyemak imbas ini, anda boleh menggunakan polyfill seperti Raphaël atau menukar SVG anda ke format lain seperti VML. Peta untuk prestasi boleh melibatkan beberapa teknik. Ini termasuk meminimumkan saiz fail SVG anda, menggunakan CSS untuk gaya dan bukannya atribut sebaris, dan menggunakan JavaScript dengan cekap. Anda juga boleh menggunakan alat seperti SVGO untuk mengoptimumkan fail SVG anda.
Atas ialah kandungan terperinci Peta Geo Dinamik dengan SVG dan JQuery. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!