arcgis TextSymbol 换行问题

原创 2015年07月08日 20:07:06

首先 找到 这个  文件 esri.symbol.MultiLineTextSymbol.js

然后 替换 



require(["esri/layers/LabelLayer"], function(ll)
{
    if( typeof esri.layers.LabelLayer.prototype._addLabel == 'function' )
    {
        esri.layers.LabelLayer.prototype._addLabel2 = esri.layers.LabelLayer.prototype._addLabel;
        esri.layers.LabelLayer.prototype._addLabel = function(a,b,c,e,g,k,m)
        {
            // replace \n by <br>
            a = a.replace(/\n/g, "<br />");
            this._addLabel2(a,b,c,e,g,k,m);
        }
    }
});


require(["esri/symbols/TextSymbol", "dojox/gfx/svg"], function(ts, svg)
{
    if( typeof dojox.gfx.svg.Text.prototype.setShape == 'function' )
    {
        dojox.gfx.svg.Text.prototype.setShape = function(p)
        {
            this.shape = dojox.gfx.makeParameters(this.shape, p);
            this.bbox = null;
            var r = this.rawNode, s = this.shape;
            r.setAttribute("x", s.x);
            r.setAttribute("y", s.y);
            r.setAttribute("text-anchor", s.align);
            r.setAttribute("text-decoration", s.decoration);
            r.setAttribute("rotate", s.rotated ? 90 : 0);
            r.setAttribute("kerning", s.kerning ? "auto" : 0);
            r.setAttribute("text-rendering", "optimizeLegibility");
            
            while(r.firstChild)
                r.removeChild(r.firstChild);


            if(s.text)
            { 
                var texts = s.text.replace(/<br\s*\/?>/ig, "\n").split("\n");
                var lineHeight = 1.1 * parseInt(document.defaultView.getComputedStyle(r, "").getPropertyValue("font-size"), 10); 
                if( isNaN(lineHeight) || !isFinite(lineHeight) )
                    lineHeight = 15;
                    
                for(var i = 0, n = texts.length; i < n; i++)
                { 
                    var tspan = (document.createElementNS ? document.createElementNS(dojox.gfx.svg.xmlns.svg, "tspan") : document.createElement("tspan"));
                    tspan.setAttribute("dy", i ? lineHeight : -(texts.length-1)*lineHeight/2); 
                    tspan.setAttribute("x", s.x);
                    tspan.appendChild((dojox.gfx.useSvgWeb ? document.createTextNode(texts[i], true) : document.createTextNode(texts[i]))); 
                    r.appendChild(tspan);
                }
            }


            return this;
        }
    }
});



然后在 页面中把该js文件引入。

用\n来进行换行





相关文章推荐

换行TextSymbol源代码

  • 2014年09月20日 16:59
  • 4KB
  • 下载

《ArcGIS Runtime SDK for Android开发笔记》——问题集:使用TextSymbol做标注显示乱码

1、前言 在14年的时候写过一篇博客关于ArcGIS for Android 10.1.1API 中文标注导致程序异常崩溃问题,但是当时并没有很好的解决这样一个问题,也并没有深入研究分析这样的一个异...
  • esricd
  • esricd
  • 2015年09月24日 20:54
  • 1899

ArcGIS API for Silverlight 动态添加点的同时,添加文字说明(利用TextSymbol添加多文字信息 )

在前面的博客中提到动态添加点,地址:http://blog.csdn.net/taomanman/article/details/7354103 这里根据需要,在添加点的同时,动态添加文字信息。 ...

arcgis js api改进textSymbol不能显示多行的不足

问题描述如题。 查阅相关资料后,发现都是同一篇文档。这种方案采用的是amd的模式,并不适合本人的应用环境,于是对textSymbol进行了继承,实现了多行标记类MultiLineTextSymbol...

扩展ArcGIS API for Silverlight/WPF 中的TextSymbol支持角度标注

在ArcGIS API for Silverlight/WPF中原版的TextSymbol只能支持文字正向显示。在很多实际项目中,往往需要文字标注有一些角度甚至是沿线标注,下面我们来看一下原装的Tex...
  • esricd
  • esricd
  • 2012年05月21日 15:03
  • 4237

Arcgis Label 换行显示VBS代码

  • 2012年07月08日 12:26
  • 333B
  • 下载

ArcGIS API For JS 文本标注换行

ArcGIS API For JS 文本标注换行
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:arcgis TextSymbol 换行问题
举报原因:
原因补充:

(最多只允许输入30个字)