arcgis api for silverlight

原文 http://blog.sina.com.cn/s/blog_4638cf7b0100wntt.html

arcgis api for silverlight(1)

(2011-09-21 09:09:26)

转载

标签:

杂谈

分类: 技术

发现了一个很好的学习工具,就是Esri的在线帮助,包括概念,例子,API介绍等等。接下来的学习基本上就是按照例子结合开发方案进行实践学习。

http://help.arcgis.com/en/webapi/silverlight/samples/start.htm

程序的构成 和asp.net结构类似,前台设计代码+后台程序代码。

Xaml+Xaml.cs

Xaml包括控件的引用、设计表格的代码、控件的设置和数据绑定代码。

Xaml则是C#程序代码。

 

首先学习加载图层,添加控制控件。

加载图层服务是在Xaml中添加的,放在代码最下端的是在最上端显示的。图层服务的显示可以在后台程序中控制

可以添加一些控制控件,navigation(导航控件)、scaleLine(比例尺)、mapProgressBar(进度条),直接链接map就可以,非常方便。

 

实际上map控件加载的是server发布的一个地图服务。

图层加载服务有三种:

TiledMap 缓存切片地图服务 适用于在服务器已经做了缓存的地图
DynamicMap 动态地图服务 适用于没做缓存的地图

Image 影像服务

它们都属于MapServer。

FeatureLayer则不是加载服务,而是加载某一个确切的图层。属于graphics layer

在Featurelayer里,加载"Renderer"可以制定矢量要素的各种形状及鼠标的形状。

<Grid.Resources>
   <esri:SimpleRenderer
x:Key="SelectRenderer">
    <esri:SimpleRenderer.Symbol>                           
 //client.SimpleRenderer.Symbol

   
<esri:SimpleMarkerSymbol Color="#7F0F2497"
Size="20"/>  
//制定点的形状

  
 </esri:SimpleRenderer.Symbol>

  </Grid.Resources>

 

尝试了利用FeatureDataGrid显示加载的图层属性数据。但是却显示数据总数,不显示数据,后来对照源代码好像是AutoGenerateColumns选项没选上。

显示鼠标坐在地理真实坐标,需要首先获取鼠标屏幕坐标,再利用map1.ScreenToMap获取真实坐标。

 

原文 http://blog.sina.com.cn/s/blog_4638cf7b0100wq7f.html

arcgis api for silverlight(2)

(2011-09-22 16:49:07)

转载

标签:

杂谈

分类: 技术

通过表格查找要素并且显示属性和高亮地图显示

关键接口:

ESRI.ArcGIS.Client.Tasks.QueryTask 用于查询

QueryTask queryTask = new QueryTask("http..."); 设置查询图层服务

queryTask.ExecuteAsync(query); 执行查询语句

queryTask.ExecuteAsync(query,"user state"); 执行查询语句并带用户状态

ESRI.ArcGIS.Client.Tasks.Query 用于设置查询条件

Query.text 设置查找文本

Query.Where 设置查找条件

Query.Outfield.AddRange or Query.Outfield.Add 设置查询输出字段

Query.OutSpatialReference 设置查询输出控件参考

Query.ReturnGeometry 设置输出要素是否包含集合体

 

datagrid数据绑定:

分两种:一种是横排显示,一种是竖排显示

竖排显示首先在Xaml中要首先设置列字段数据绑定

<Datagrid columns>

<sdk:datagrid.textcolumn Binding="{binding path=key}">//字段

<sdk:datagrid.textcolumn Binding="{binding path=value}">//值

在后台代码中:

dataGrid.ItemsSource = selectedFeature.Attributes;//绑定选择要素的属性

横排显示需要在Xaml中设置列字段数据绑定

<Datagrid columns>

<sdk:datagrid.textcolumn Binding="{binding attributes[]}">//绑定

在后台代码中:

 Binding resultFeaturesBinding = new Binding("LastResult.Features");//绑定属性
resultFeaturesBinding.Source = queryTask;//绑定来源
dataGrid1.SetBinding(DataGrid.ItemsSourceProperty,
resultFeaturesBinding);//绑定

在地图中高亮显示:

首先在Xaml中添加图层<esri:GraphicsLayer
ID="MyGraphicsLayer" />

再在后台程序中:

GraphicsLayer selectionGraphicslayer =
map1.Layers["MySelectionGraphicsLayer"] as GraphicsLayer;

graphicsLayer.Graphics.Add(selectedFeature);//绑定要素图层标记

通过点击图层查找要素并且显示属性和高亮地图显示

定义鼠标勾画结束事件

private void MyDrawFace_DrawComplete (object sender,
ESRI.ArcGIS.Client.DrawEventArgs args)
{

QueryTask queryTask = new QueryTask("http:“);//定义查找数据源

query.Geometry = args.Geometry;//定义查找图形

queryTask.ExecuteAsync(query);执行查找

}

在地图中高亮显示多个要素:

foreach (Graphic feature in featureSet.Features)
{
graphicsLayer.Graphics.Insert(0, feature);
}

原文 http://blog.sina.com.cn/s/blog_4638cf7b0100xgzn.html

arcgis api for silverlight(3)发布

(2011-10-11 08:52:52)

转载

标签:

杂谈

分类: 技术
  1. win7的IIS配置。win7默认的IIS是7.5.
  2. silverlight程序发布,比较简单,在vs2010下,右键单击Web工程后点击发布即可。
  3. 设置IIS,首先新建网站,然后在新建网站上添加应用程序,路径设置为工程所在文件夹,应用程序池选择asp.net4.0。
  4. arcgis api for silverlight程序获取Server服务,在服务器的IIS目录下,必须放置这两个文件(crossdomain.xml和clientaccesspolicy.xml)?跨域访问文件
  5. 防火墙一定要关闭或者设置好。
  6. webconfig,加默认文档前要加<clear />。
时间: 2024-09-02 17:41:42

arcgis api for silverlight的相关文章

ArcGIS API for Silverlight开发入门

你用上3G手机了吗?你可能会说,我就是喜欢用nokia1100,ABCDEFG跟我 都没关系.但你不能否认3G是一种趋势,最终我们每个人都会被包裹在3G网络中.1100也不是一成不变,没准哪天为了打击犯罪,会在你的1100上强制 装上GPS.GIS工作既然建立在计算机的基础上,当然也得随着IT行业与时俱进.       看看现在计算机应用的趋势吧.云(计算),这个东西可讲不清楚,因为云嘛,飘忽不定的.不过可以这样来看它,以后计算机网络上就有一坨(或者几坨)万能的 云,有什么需求云都可以满足我们,

ArcGIS API for Silverlight 之ElementLayer使用及TextSymbol的模板使用

原文:ArcGIS API for Silverlight 之ElementLayer使用及TextSymbol的模板使用 在开发中动态在地图上添加文字信息,可以使用TextSymbol添加文字 //动态添加文本 TextSymbol textSymbol = new TextSymbol() { FontFamily = new System.Windows.Media.FontFamily("Microsoft YaHei"), Foreground = new System.Wi

ArcGIS API for Silverlight 调用WebService出现跨域访问报错的解决方法

原文:ArcGIS API for Silverlight 调用WebService出现跨域访问报错的解决方法       群里好几个朋友都提到过这样的问题,说他们在Silverlight中调用了WebService方法,总报这个错误,贴图如下: 解决办法:      1.确定你的Silverlight项目及承载Silverlight的Web程序根目录下都包含2个跨域文件,分别是crossdomain.xml和clientaccesspolicy.xml:  crossdomain.xml文件,

ArcGIS API for Silverlight 调用GP服务准备---GP模型建立、发布、测试

原文:ArcGIS API for Silverlight 调用GP服务准备---GP模型建立.发布.测试                                                                                                                      第一篇.GP降雨量等值线建模.发布及测试          在水利.气象等行业中,要在WebGIS中实现空间分析功能,如绘制等值线.等高线.等直面.缓冲区等都

使用Visifire+ArcGIS API for Silverlight实现Graphic信息的动态图表显示

原文:使用Visifire+ArcGIS API for Silverlight实现Graphic信息的动态图表显示   首先来看一看实现的效果: PS:原始的程序中更新曲线数据时添加了过渡的效果,具体可查看官网的示例: http://www.visifire.com/silverlight_spline_charts_gallery.php 点击其中的一个例子,然后点击Live Updates,就可看到数据更新时的过渡效果.但是蛋疼的博客园,不知道为什么,我插入了我原始的xap文件,过渡效果却

ArcGIS API for Silverlight开发入门准备

原文:ArcGIS API for Silverlight开发入门准备          微软的Silverlight提供了跨浏览器和跨平台开发环境,在Web中可用于创建和展现富互联网应用(RIA,Rich  Internet Application).          ArcGIS API for Silverlight 能够让的Silverlight应用程序具有集成ArcGIS Server.ESRI MapIt和Bing Maps服务的能力.利用 ArcGIS Server 和Bing

ArcGIS API for Silverlight学习笔记

ArcGIS API for Silverlight学习笔记(一):为什么要用Silverlight API(转) 你用上3G手机了吗?你可能会说,我就是喜欢用nokia1100,ABCDEFG跟我都没关系.但你不能否认3G是一种趋势,最终我们每个人都会 被包裹在3G网络中.1100也不是一成不变,没准哪天为了打击犯罪,会在你的1100上强制装上GPS.GIS工作既然建立在计算机的基础上,当然也得 随着IT行业与时俱进.       看看现在计算机应用的趋势吧.云(计算),这个东西可讲不清楚,因

解决ArcGIS API for Silverlight 加载地图的内外网访问问题

原文:解决ArcGIS API for Silverlight 加载地图的内外网访问问题 先上一个类,如下: public class BaseClass { public static string getFullUri(string oldUriString) { string newUriString = oldUriString; //处理相对地址============================================================ if (newUri

ArcGIS API for Silverlight 使用GP服务实现要素裁剪功能

原文:ArcGIS API for Silverlight 使用GP服务实现要素裁剪功能      昨天一QQ好友问了一个关于裁剪的问题,感觉自己也没有帮上什么忙,之后自己做了一个裁剪的例子,不过在做这个例子的时候还遇到了不少的问题,在此和大家分享一下. 1.裁剪功能的实现过程 这里的裁剪功能很简单,只需要一个Clip(裁剪)工具即可. 但是这里需要注意的问题是裁剪工具的参数: 裁剪工具有两个输入参数: a.输入要素:这里指的是你用什么来裁剪目标要素,也就是你用什么裁剪 b.裁剪要素:这里指的被