ArcGIS api for JavaScript 4+版本tooltip控件

話不多說(shuō),先上效果圖

效果圖

Paste_Image.png

代碼

define([
    "./Custom"
], function (Custom) {
    var _tpl = dojo.string.substitute;

    var ROOT_TEMPLATE = '<div class="esri-custom-tooltip esri-custom-visible_hide" id="${id}">${content}</div>';
    var CONTENT_TEMPLATE = '<div class="esri-custom-tooltip-content">${content}</div>';
    var ARROW_TEMPLATE = '<div class="esri-custom-tooltop-arrow"></div>'

    var Tooltip = Custom.createSubclass({
        declaredClass: "esri.custom._Tooltip",
        normalizeCtorArgs: function (view, options) {
            this.options = (options || (options = {}));
            this._mapView = view;
            this._randomId = 'tooltip-' + Math.random().toString().split('.')[1];

            this._createTooltip();
            if (options.visible) {
                this.show();
            }
            this.registerEvents();
        },
        properties: {

        },
        registerEvents: function () {
            var me = this;
            this._handlers = [this._mapView.watch('extent', this.debounce(function (event) {
                if (me.options.visible) {
                    me.show();
                }
            }, 0))];
        },
        _createTooltip: function () {
            var contentHtml = _tpl(CONTENT_TEMPLATE, { content: this.options.content });
            var html = _tpl(ROOT_TEMPLATE, { content: contentHtml + ARROW_TEMPLATE, id: this._randomId });
            dojo.query(this._mapView.container).query('.esri-view-root').addContent(html);
        },
        show: function (param) {
            var rootNode = dojo.query('#' + this._randomId);
            rootNode.removeClass('esri-custom-visible_hide');
            var arrowNode = rootNode.query('.esri-custom-tooltop-arrow');
            this.options = param = dojo.mixin(this.options, param, {
                visible: true
            });
            if (param.location) {
                var screenPoint = this._mapView.toScreen(param.location);
                var arrowLeft = rootNode.style('width')[0] / 2 - 6;
                rootNode.style({
                    'left': (screenPoint.x - arrowLeft - 6) + 'px',
                    'top': (screenPoint.y - 48) + 'px'
                });
                arrowNode.style({
                    'left': arrowLeft + 'px'
                });
            }
        },
        hide: function () {
            dojo.query('#' + this._randomId).addClass('esri-custom-visible_hide');
        }
    });

    Tooltip.getInterPointFromRing = Custom.getInterPointFromRing;

    return Tooltip;

});

小結(jié)

該控件并沒(méi)有寫得多么強(qiáng)大买鸽,有些東西定得比較死,大家有興趣可以自己去修改

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末贯被,一起剝皮案震驚了整個(gè)濱河市眼五,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌彤灶,老刑警劉巖看幼,帶你破解...
    沈念sama閱讀 216,692評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異幌陕,居然都是意外死亡诵姜,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門搏熄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)棚唆,“玉大人暇赤,你說(shuō)我怎么就攤上這事∩螅” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 162,995評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵契邀,是天一觀的道長(zhǎng)摆寄。 經(jīng)常有香客問(wèn)我,道長(zhǎng)坯门,這世上最難降的妖魔是什么微饥? 我笑而不...
    開(kāi)封第一講書人閱讀 58,223評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮古戴,結(jié)果婚禮上欠橘,老公的妹妹穿的比我還像新娘。我一直安慰自己现恼,他們只是感情好肃续,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,245評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著叉袍,像睡著了一般始锚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上喳逛,一...
    開(kāi)封第一講書人閱讀 51,208評(píng)論 1 299
  • 那天瞧捌,我揣著相機(jī)與錄音,去河邊找鬼润文。 笑死姐呐,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的典蝌。 我是一名探鬼主播曙砂,決...
    沈念sama閱讀 40,091評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼骏掀!你這毒婦竟也來(lái)了麦轰?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,929評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤砖织,失蹤者是張志新(化名)和其女友劉穎款侵,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體侧纯,經(jīng)...
    沈念sama閱讀 45,346評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡新锈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,570評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了眶熬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片妹笆。...
    茶點(diǎn)故事閱讀 39,739評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡块请,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出拳缠,到底是詐尸還是另有隱情墩新,我是刑警寧澤,帶...
    沈念sama閱讀 35,437評(píng)論 5 344
  • 正文 年R本政府宣布窟坐,位于F島的核電站海渊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏哲鸳。R本人自食惡果不足惜臣疑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,037評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望徙菠。 院中可真熱鬧讯沈,春花似錦、人聲如沸婿奔。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,677評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)萍摊。三九已至儒老,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間记餐,已是汗流浹背驮樊。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,833評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留片酝,地道東北人囚衔。 一個(gè)月前我還...
    沈念sama閱讀 47,760評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像雕沿,于是被迫代替她去往敵國(guó)和親练湿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,647評(píng)論 2 354

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,082評(píng)論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)审轮、插件肥哎、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,095評(píng)論 4 62
  • 文/嚯嚯 黃昏雨后天氣濕潤(rùn)的空氣里 聽(tīng)風(fēng)吹落葉尖上欲滴的甘露 偶爾被淋上一滴 水的氛圍里冰涼的侵襲 心如秋日天空明...
    小嚯嚯閱讀 364評(píng)論 0 0
  • .......
    剛正好閱讀 187評(píng)論 0 0
  • 感覺(jué)挺煩惱的单旁。整天感覺(jué)狀態(tài)不是很好涤垫,可能是感冒了吧,吃了藥以后席镀,全身昏昏沉沉的榴捡,特別想睡覺(jué)杈女。可能是因?yàn)楦忻傲耍ぷ?..
    小坤爸閱讀 144評(píng)論 0 0