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

简介: 原文 http://blog.csdn.net/esricd/article/details/7587136 在ArcGIS API for Silverlight/WPF中原版的TextSymbol只能支持文字正向显示。

原文 http://blog.csdn.net/esricd/article/details/7587136

在ArcGIS API for Silverlight/WPF中原版的TextSymbol只能支持文字正向显示。在很多实际项目中,往往需要文字标注有一些角度甚至是沿线标注,下面 我们来看一下原装的TextSymbol和扩展后的TextSymbol的比较和实现思路。

要实现右图的效果只需要从TextSymbol继承一个Symbol并增加Rotation属性,并加载相应的控件模板就行了。

以下是控件模板的代码:

[html] view plain copy
  1. <ControlTemplate xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"   
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
  3. xmlns:esri="http://schemas.esri.com/arcgis/client/2009"  
  4. xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows">  
  5.     <TextBlock Text="{Binding Symbol.Text}"   
  6.                FontFamily="{Binding Symbol.FontFamily}"   
  7.                FontSize="{Binding Symbol.FontSize}"   
  8.                Foreground="{Binding Symbol.Foreground}">  
  9.         <TextBlock.RenderTransform>  
  10.             <CompositeTransform Rotation="{Binding Symbol.TextRotation}"/>  
  11.         </TextBlock.RenderTransform>  
  12.     </TextBlock>  
  13. </ControlTemplate>  

控件模板中需要绑定对象中的文本、字体、字号、颜色、角度五个属性。

对象类的加载XAML代码如下:

[csharp] view plain copy
  1. base.ControlTemplate = XamlReader.Load(LoadXaml("LabelSymbol.xaml")) as ControlTemplate;  
  2.   
  3.   
  4.   
  5.   
  6.   
  7. public static string LoadXaml(string FileName)  
  8.          {  
  9.             string xamlstring;  
  10.             var assemblyName = new AssemblyName(Assembly.GetExecutingAssembly().FullName);  
  11.             string CurrentAssemblyName = assemblyName.Name;  
  12.             string resourceName = string.Format("{0};component{1}{2}", CurrentAssemblyName, "/", FileName);  
  13.             Uri uri = new Uri(resourceName, UriKind.Relative);  
  14.             StreamResourceInfo streamResourceInfo = Application.GetResourceStream(uri);  
  15.             using (Stream resourceStream = streamResourceInfo.Stream)  
  16.             {  
  17.                 using (StreamReader streamReader = new StreamReader(resourceStream))  
  18.                 {  
  19.                     xamlstring = streamReader.ReadToEnd();  
  20.                 }  
  21.             }  
  22.             return xamlstring;  
  23.         }  

对象类中再定义对应的五个属性就能实现有倾斜角度的标注了。最终实现效果如图:

 

 

后话:

这个扩展的Symbol仅仅是对文字符号增加旋转角度,其中还有不完善的地方,在线路转角的地方标注的时候往往会与线交叉,如:

如果再深入完善一下,稍做修改可以将标注做成真正的沿线标注,如:

沿线文本在网上有大量的资料,在这里就不再啰嗦了,希望本文对各位ArcGIS API for Silverlight开发人员有帮助。

目录
相关文章
|
2月前
ArcGIS修改图层标签标注(Label)对应字段与内容的方法
ArcGIS修改图层标签标注(Label)对应字段与内容的方法
|
7月前
|
定位技术
ArcGIS:如何对Shapefile文件进行符号系统修改、标注、合并、分割、拓扑编辑等?
ArcGIS:如何对Shapefile文件进行符号系统修改、标注、合并、分割、拓扑编辑等?
157 0
|
4月前
|
人工智能 数据可视化 API
ArcGIS API for Python
ArcGIS API for Python
26 0
|
7月前
ArcGIS:要素标注时报错:未找到要素,无法验证表达式
ArcGIS:要素标注时报错:未找到要素,无法验证表达式
93 0
|
8月前
|
JavaScript 前端开发 应用服务中间件
Arcgis api for javascript 详细部署
Arcgis api for javascript 详细部署
|
10月前
|
人工智能 数据可视化 数据管理
ArcGIS API for Python
ArcGIS API for Python
70 0
|
JavaScript 前端开发 定位技术
ArcGIS API For JavaScript官方文档(六)之设置范围
ArcGIS API For JavaScript官方文档(六)之设置范围
|
存储 JSON 前端开发
ArcGIS API For JavaScript官方文档(一)之默认API配置
ArcGIS API For JavaScript官方文档(一)之默认API配置
|
数据可视化 数据管理 API
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
arcgis api 3.X 修改自带弹窗样式 2022年6月12日
自带的弹窗介绍: arcgis api 3.X 修改自带弹窗样式插图 /*修改原有弹窗的css样式*/ /* 弹窗整体 */ .esriPopup { font-size: 16px; box-shadow: 10px 10px 5px #888888; } .esriPopup .sizer { position: relative; width: 400px; /* 弹窗宽度 */ z-index: 1; } /* 标题部分 */ .esriPopup .titlePane { background-color: rgba(7

相关产品

  • 云迁移中心