Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例
一、前言
用過echart的人都會遇到一個(gè)問題,就算是代碼中寫了window.onresize = echart.resize,也只是橫向自適應(yīng)拉伸填充頁面,垂直方向不會變化,除非指定高度才可以,這就比較郁悶了,為何echart本身不會自適應(yīng)呢?按道理不應(yīng)該啊,莫非實(shí)現(xiàn)起來很困難?好吧先不管這個(gè)了,這個(gè)問題搜索出來一大堆解決方案,在Qt的瀏覽器控件中也有這個(gè)問題,為了解決這個(gè)問題想了兩個(gè)策略,一種是程序本身檢測尺寸變化,然后重新設(shè)置高度并載入網(wǎng)頁,一種是js函數(shù)設(shè)置對應(yīng)的寬高,什么時(shí)候執(zhí)行呢,就是在程序界面尺寸變化的時(shí)候,兩種辦法對比下來,最終選用的后者,因?yàn)樾Ч容^好,還是異步執(zhí)行的,無需重新加載網(wǎng)頁,那個(gè)每次高度變化了就重新加載網(wǎng)頁的辦法在早期的作品中用過,看起來好傻逼比的。
二、功能特點(diǎn)
- 同時(shí)支持閃爍點(diǎn)圖、遷徙圖、區(qū)域地圖、儀表盤等。
- 可以設(shè)置標(biāo)題、提示信息、背景顏色、文字顏色、線條顏色、區(qū)域顏色等各種顏色。
- 可設(shè)置城市的名稱、值、經(jīng)緯度 集合。
- 可設(shè)置地圖的放大倍數(shù)、是否允許鼠標(biāo)滾輪縮放。
- 內(nèi)置世界地圖、全國地圖、省份地圖、地區(qū)地圖,可以精確到縣,所有地圖全部離線使用。
- 內(nèi)置了各省市json數(shù)據(jù)文件轉(zhuǎn)js文件功能,如有數(shù)據(jù)更新自行轉(zhuǎn)換即可,支持單個(gè)文件轉(zhuǎn)換和一鍵轉(zhuǎn)換所有文件。
- 內(nèi)置了從json文件或者js文件獲取該區(qū)域的所有名稱和經(jīng)緯度信息集合的功能,可以通過該方法獲取到信息用來顯示。
- 依賴瀏覽器組件顯示地圖,提供的demo支持webkit、webengine、ie 三種方式加載網(wǎng)頁。
- 拓展性極強(qiáng),可以依葫蘆畫瓢自行增加各種精美的echarts組件,做出牛逼的效果。
- 內(nèi)置的儀表盤組件提供交互功能,demo演示中包含了對應(yīng)的代碼。
- 函數(shù)接口友好和統(tǒng)一,使用簡單方便,就一個(gè)類。
- 支持任意Qt版本、任意系統(tǒng)、任意編譯器。
三、體驗(yàn)地址
體驗(yàn)地址:https://pan.baidu.com/s/1Ie1xGLv7tSL-9vfsv28w1Q 提取碼: wf4f?? 文件名:bin_map.zip
國內(nèi)站點(diǎn):https://gitee.com/feiyangqingyun
國際站點(diǎn):https://github.com/feiyangqingyun
四、效果圖
五、相關(guān)代碼
//設(shè)置窗口大小變動(dòng)echarts自動(dòng)拉伸填充,此方法只能橫向拉伸 list << QString(" window.onresize = echart.resize;"); //下面的方法用來設(shè)置畫布的寬度高度 list << QString(" function resize(width, height) {"); list << QString(" var chart = document.getElementById('chart');"); list << QString(" chart.style.width = width + \"px\";"); list << QString(" chart.style.height = height + \"px\";"); list << QString(" echart.resize();"); list << QString(" }"); void frmEcharts::resizeMap() { if (isLoad) { #ifdef webkit QString js = QString("resize(%1, %2)").arg(webView->width()).arg(webView->height()); webView->page()->mainFrame()->evaluateJavaScript(js); #elif webengine QString js = QString("resize(%1, %2)").arg(webView->width()).arg(webView->height()); webView->page()->runJavaScript(js); #endif } }
到此這篇關(guān)于Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言詳解如何應(yīng)用模擬字符串和內(nèi)存函數(shù)
這篇文章主要介紹了C語言詳解如何應(yīng)用模擬字符串和內(nèi)存函數(shù),文章有點(diǎn)長,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02解析內(nèi)存對齊 Data alignment: Straighten up and fly right的詳解
對于所有直接操作內(nèi)存的程序員來說,數(shù)據(jù)對齊都是很重要的問題.數(shù)據(jù)對齊對你的程序的表現(xiàn)甚至能否正常運(yùn)行都會產(chǎn)生影響2013-05-05FFmpeg實(shí)戰(zhàn)之利用ffplay實(shí)現(xiàn)自定義輸入流播放
ffplay是FFmpeg提供的一個(gè)極為簡單的音視頻媒體播放器,可以用于音視頻播放、可視化分析。本文將利用ffplay實(shí)現(xiàn)自定義輸入流播放,需要的可以參考一下2022-12-12C語言演示對歸并排序算法的優(yōu)化實(shí)現(xiàn)
這篇文章主要介紹了C語言演示對歸并排序算法的優(yōu)化實(shí)現(xiàn),歸并排序的最差時(shí)間復(fù)雜度為(n\log n),最優(yōu)時(shí)間復(fù)雜為(n),存在可以改進(jìn)的空間,需要的朋友可以參考下2016-05-05