vue+heatmap.js實(shí)現(xiàn)自定義圖片熱力圖并且自適應(yīng)

heatmap.png

基本實(shí)現(xiàn)

如圖就是最終效果伞租,由于做的項(xiàng)目數(shù)據(jù)可視化選擇的是Echarts,所以一開(kāi)始是打算想用Echarts直接實(shí)現(xiàn)對(duì)任意圖片的熱力圖软免,但本人水平有限贰军,用Echarts沒(méi)做出來(lái),所以找到了用heatmap.js來(lái)做份帐。
-語(yǔ)法都很簡(jiǎn)單璃吧,去網(wǎng)站documents看一下一會(huì)就會(huì)了。

<div id="heatmap" style=" width:40%; height: 50%; border: 1px solid;border-color: grey;">
    <img id="baidu-img" src="images/hanzhong.png" style="width: 100%; height: 100%; ">
    <img src="images/hanzhong_re.png " style="width: 100%; height: 100%; top: 0px;position: absolute; z-index: 1">
</div>
$("canvas,heatmap").remove();
                     _this.heatmapInstance = h337.create({
                        container: document.querySelector("#heatmap"),
                        radius: 50,
                        maxOpacity: 0.5,
                        minOpacity: 0,
                        blur: 0.75
                    });
                    var data = {
                        max: _this.max,
                        data: _this.points
                    };
                    _this.heatmapInstance.setData(data);

放一點(diǎn)核心的代碼吧废境。應(yīng)該很容易理解畜挨。

自適應(yīng)大小

重點(diǎn)要說(shuō)一下這里要實(shí)現(xiàn)自適應(yīng)大小怎么做筒繁。這里的data的數(shù)據(jù)結(jié)構(gòu)是[{x:1,y:2,value:3}]這樣的一個(gè)數(shù)組,里邊的x巴元、y分別對(duì)應(yīng)的是從圖片左上角為(0毡咏,0)起點(diǎn),x代表距離左邊的像素距離逮刨,y代表距離上方的像素距離絕對(duì)值呕缭。
1.第一步

  //要用一個(gè)全局變量記錄初始的寬和高
_this.cavWidth = document.getElementById("heatmap").clientWidth;
_this.cavHeight = document.getElementById("heatmap").clientHeight;

2.第二步
通過(guò)Vue的watch監(jiān)聽(tīng)這兩個(gè)值

            cavWidth(curVal, oldVal) {
                var _this = this;
                this.cavWidth = curVal;
                if (oldVal != 0) {
                    for (i = 0; i < this.points.length; i++) {
                        this.points[i].x = (this.points[i].x * curVal / oldVal).toFixed(0);
                    }
                    _this.init();
                }

                console.log("寬=" + curVal, oldVal);
            },
            cavHeight(curVal, oldVal) {
                var _this = this;
                this.cavHeight = curVal;
                if (oldVal != 0) {
                    for (i = 0; i < this.points.length; i++) {
                        this.points[i].y = (this.points[i].y * curVal / oldVal).toFixed(0);
                    }
                    _this.init();
                }
                console.log("高=" + curVal, oldVal);
            },

3.第三步
這樣還沒(méi)有實(shí)現(xiàn)監(jiān)聽(tīng)值變化的效果,還需要用mounted鉤子函數(shù)聲明一下resize方法

       mounted() {
           var _this = this
           window.onresize = () => {
               return (() => {
                   _this.cavWidth = document.getElementById("heatmap").clientWidth;
                   _this.cavHeight = document.getElementById("heatmap").clientHeight;
               })()
           }
       },

這樣就可以實(shí)現(xiàn)自適應(yīng)的了修己。
但是這里有個(gè)問(wèn)題臊旭,由于計(jì)算后的x、y會(huì)是小數(shù)值箩退,這里一旦存在小數(shù)就沒(méi)辦法渲染熱力圖效果了离熏,所以我toFixed(0)了,但是這樣會(huì)存在誤差戴涝,有知道的人可以告訴我一下滋戳。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市啥刻,隨后出現(xiàn)的幾起案子奸鸯,更是在濱河造成了極大的恐慌,老刑警劉巖可帽,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件娄涩,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡映跟,警方通過(guò)查閱死者的電腦和手機(jī)蓄拣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)努隙,“玉大人球恤,你說(shuō)我怎么就攤上這事≥┠鳎” “怎么了咽斧?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)躬存。 經(jīng)常有香客問(wèn)我张惹,道長(zhǎng),這世上最難降的妖魔是什么岭洲? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任宛逗,我火速辦了婚禮,結(jié)果婚禮上钦椭,老公的妹妹穿的比我還像新娘拧额。我一直安慰自己,他們只是感情好彪腔,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布侥锦。 她就那樣靜靜地躺著,像睡著了一般德挣。 火紅的嫁衣襯著肌膚如雪恭垦。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,084評(píng)論 1 291
  • 那天格嗅,我揣著相機(jī)與錄音番挺,去河邊找鬼。 笑死屯掖,一個(gè)胖子當(dāng)著我的面吹牛玄柏,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播贴铜,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼粪摘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了绍坝?” 一聲冷哼從身側(cè)響起徘意,我...
    開(kāi)封第一講書(shū)人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎轩褐,沒(méi)想到半個(gè)月后椎咧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡把介,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年勤讽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拗踢。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡地技,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出秒拔,到底是詐尸還是另有隱情莫矗,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布砂缩,位于F島的核電站作谚,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏庵芭。R本人自食惡果不足惜妹懒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望双吆。 院中可真熱鬧眨唬,春花似錦会前、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至岭妖,卻和暖如春临庇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背昵慌。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工假夺, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人斋攀。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓已卷,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親淳蔼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子悼尾,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容

  • 文章圖片上傳不正常,如需文檔肖方,可聯(lián)系微信:1017429387 目錄 1 安裝... 4 1.1 配置探針... ...
    Mrhappy_a7eb閱讀 6,287評(píng)論 0 5
  • 【Android 動(dòng)畫(huà)】 動(dòng)畫(huà)分類補(bǔ)間動(dòng)畫(huà)(Tween動(dòng)畫(huà))幀動(dòng)畫(huà)(Frame 動(dòng)畫(huà))屬性動(dòng)畫(huà)(Property ...
    Rtia閱讀 6,121評(píng)論 1 38
  • 人每當(dāng)遇事不順時(shí)闺魏,就開(kāi)始為自己尋找理由,情形俯画、時(shí)機(jī)析桥、天氣、運(yùn)勢(shì)艰垂,依靠種種借口來(lái)安慰自己泡仗,心想“不該是這樣的,好想重...
    Psycho_布丁閱讀 1,078評(píng)論 3 3
  • 我曾經(jīng)以為截亦,這會(huì)是一本純粹的游記,記錄大陸那邊一個(gè)遙遠(yuǎn)夢(mèng)幻的地方和一段不真實(shí)的時(shí)空柬讨,記錄一個(gè)跨越五年的夢(mèng)想實(shí)現(xiàn)的最...
    星汨尛Novia閱讀 674評(píng)論 0 2
  • 1.意想不到崩瓤,早上來(lái)后打掃衛(wèi)生的時(shí)候,陳老師去后花園拿拖布沖洗的時(shí)候踩官,突然大聲說(shuō)我去却桶,拖布怎么結(jié)冰了,心想是啊現(xiàn)在...
    云少nn閱讀 125評(píng)論 0 0