Esri for Window Phone 7(一) 加载BingMap

最近在学习Esri for Windows Phone 7 地图开发方面的东西来提升自己,同进也是工作中的耐要。通过一段时间的了解与接触,感觉地图数据是一个很庞大的后台支撑。其实开发是一个简单的过程,看看API大部分东西都能搞定。目前我们知道最大的几个地图公司有google,百度,BingMap,他们的数据是相当全面的,对数据进行了定期与不定期的更新操作,听别人说过做后台数据支持的就有一万多人的团队。

最近在学习关于手机上的地图开发,特写文章记录下来,同时也与大家一起见证我学习过程中的不足。

一、环境搭建

  1. 首先到Esri 官网上下载Esri for windows phone 7 SDK; http://help.arcgis.com/en/arcgismobile/10.0/apis/windowsphone/index.html
  2. 新建一个windows phone 7的工程项目文件。并在项目中引有DLL,如下图所示:

image

二、加载 BingMap 地图

1.XMAL 代码如下:

 <phone:PhoneApplicationPage.ApplicationBar>
        <shell:ApplicationBar IsVisible="True"
                              IsMenuEnabled="True">
            <shell:ApplicationBarIconButton IconUri="/Images/appbar.add.rest.png"
                                            Text="添加" />
            <shell:ApplicationBar.MenuItems>
                <shell:ApplicationBarMenuItem Text="AerialWithLabels"
                                              Click="ApplicationBarMenuItem_Click" />
                <shell:ApplicationBarMenuItem Text="Aerial"
                                              Click="ApplicationBarMenuItem_Click" />
                <shell:ApplicationBarMenuItem Text="Road"
                                              Click="ApplicationBarMenuItem_Click" />
            </shell:ApplicationBar.MenuItems>
        </shell:ApplicationBar>
    </phone:PhoneApplicationPage.ApplicationBar>
    <!--LayoutRoot is the root grid where all page content is placed-->
    <Grid x:Name="LayoutRoot"
          Background="Transparent">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto" />
            <RowDefinition Height="*" />
        </Grid.RowDefinitions>
        <!--TitlePanel contains the name of the application and page title-->
        <StackPanel x:Name="TitlePanel"
                    Grid.Row="0"
                    Margin="12,17,0,28">
            <TextBlock x:Name="ApplicationTitle"
                       Text="我的应用程序"
                       Style="{StaticResource PhoneTextNormalStyle}" />
            <TextBlock x:Name="PageTitle"
                       Text="Esri Bing Map"
                       Margin="9,-7,0,0"
                       Style="{StaticResource PhoneTextTitle1Style}" />
        </StackPanel>

        <!--ContentPanel - place additional content here-->
        <Grid x:Name="ContentPanel"
              Grid.Row="1"
              Margin="12,0,12,0">
            <esri:Map x:Name="Mymap"
                      Background="White">
                <esriBing:TileLayer Culture="zh-CN"
                                    LayerStyle="Road"
                                    ServerType="Production"
                                    Token="AtSa3tpGJQyqYL3atzK7l6AfZhT0f24rJmk0mnWwJJwYLQjkn0y98_jKT23ycG14"
                                    ID="titleLayerRoad">
                </esriBing:TileLayer>
            </esri:Map>
        </Grid>
    </Grid>

整个页面用到三个菜单来进行不能的数据回载,工用一个事件命令。

2.CS   代码如下:

private void ApplicationBarMenuItem_Click(objectsender, EventArgse)
       {
           vartext = (sender asApplicationBarMenuItem).Text;
           varlayer = Mymap.Layers[0];
           switch(text)
           {
               case"AerialWithLabels":
                   (layer asTileLayer).LayerStyle = TileLayer.LayerType.AerialWithLabels;
                   break;
               case"Aerial":
                   (layer asTileLayer).LayerStyle = TileLayer.LayerType.Aerial;
                   break;
               case"Road":
                   (layer asTileLayer).LayerStyle = TileLayer.LayerType.Road;
                   break;

           }
       }

三、运行结果如下:

image                           image                          image

四、结束语

在学习的过程中要用到BingMap的KEY,要得到KEY必须到live上去申请。https://www.bingmapsportal.com/

参考资料:

  1. http://help.arcgis.com/en/arcgismobile/10.0/apis/windowsphone/help/index.html#/Using_Bing_Imagery_Geocode_and_Route_services/011v00000018000000/     esri for windows Phone 7API

 

posted @ 2011-04-27 22:59  阳光追梦  阅读(1487)  评论(2编辑  收藏  举报
/*快速评论*/ #div_digg { position: fixed; bottom: 10px; right: 15px; border: 2px solid #ECD7B1; padding: 10px; width: 140px; background-color: #fff; border-radius: 5px 5px 5px 5px !important; box-shadow: 0 0 0 1px #5F5A4B, 1px 1px 6px 1px rgba(10, 10, 0, 0.5); } /** 不知道为什么页面加载完成时还读不到div_digg。可能也是动态生成的。 所以这里只能用定时器 不断的读取,当读取到了再给它动态添加快捷按钮 **/ //自定义 定时器[当元素加载完成是执行回调函数] function customTimer(inpId,fn) { if ($(inpId).length) { fn(); } else { var intervalId = setInterval(function () { if ($(inpId).length) { //如果存在了 clearInterval(intervalId); // 则关闭定时器 customTimer(inpId,fn); //执行自身 } }, 100); } } //页面加载完成是执行 $(function () { customTimer("#div_digg", function () { var div_html = "
\ 关注\  | \ 顶部\  | \ 评论\
"; $("#div_digg").append(div_html); //tbCommentBody }); });