SuperMap Object 读取SQL数据库中的地图

2016-7-21 14:58:48 0人评论 93次浏览 分类:技术文章

/*
          * 有关说明:
          * 其中专题地图是在SuperMap中做好的.
          * 要想读取各个数据源的数据,也是很简单就能做到的,在SuperMap的帮助文件中有,
          * 这里是在SuperMap的DeskPro中做好的"专题地图". 
          * 其他的变量名称都是自己定义的,基本不用说明.
          * 有什么不明白的地方,欢迎留言!
          */
         private void Load_Map()
         {
             //建立axSuperWorkspace 与SuperMap之间的联系 
             axSuperMap.Connect(axSuperWorkspace.CtlHandle);
             //数据源别名 
             String strAlias;
             //数据引擎类型 
             SuperMapLib.seEngineType nEngineType;
             //数据源绝对路径名 
             String strDataSourceName;
             //数据源对象,指向打开的数据源 
             SuperMapLib.soDataSource objDataSource;
             //数据源里的数据是否只读 
             bool bReadOnly;
             //是否加到最上面 
             //bool bAddToHead;
             // int i; //循环变量 
             //别名可以任意给,建议取成和数据源文件主名 
             strAlias = "MyDataSource";
             //SuperMap支持多种类型,此处为SQLServer类型 
             nEngineType = SuperMapLib.seEngineType.sceSQLServer;
             //远程数据库的地址和数据库名
             strDataSourceName = @"provider = SQLOLEDB;server = ServerName/ServiceName ;database = DataBaseName";
             string strPassword = "UID=UserName;pwd=PassWord";
             bReadOnly = true; //不设为只读 
             //打开数据源           
             string strDataSource = @"Provider = SQLOLEDB;Driver = SQL Server;SERVER = ServerName /ServiceName;Database =DataBaseName;Caption = MyMap;";
             axSuperWorkspace.Open(strDataSource, strPassword);
             objDataSource = axSuperWorkspace.OpenDataSourceEx(strDataSourceName, strAlias, nEngineType, bReadOnly, true, false, true, strPassword);
             if (objDataSource == null)
             {
                 MessageBox.Show("地图信息打开失败,请与技术人员联系!", "打开数据源失败");
                 return;
             }
             else
             {
                 //在这里可以设置是打开DeskPro中设置好的专题地图,还是打开各个数据集,以及叠放次序
                 axSuperMap.OpenMap("专题地图");
                 //设置地图只显示省份
                 //设置自动滚屏关闭
             }
             //修改选中对象风格 
             axSuperMap.selection.Style.PenColor = Convert.ToUInt32(ColorTranslator.ToOle(Color.FromArgb(100, 77, 0)));
             axSuperMap.selection.Style.PenWidth = 1;
             axSuperMap.selection.Style.PenStyle = 1;
             axSuperMap.selection.Style.BrushStyle = 5;
             axSuperMap.selection.Style.BrushBackTransparent = true;
             axSuperMap.selection.Style.BrushColor = Convert.ToUInt32(ColorTranslator.ToOle(Color.FromArgb(115, 69, 140)));
             axSuperMap.selection.Style.BrushBackColor = Convert.ToUInt32(ColorTranslator.ToOle(Color.FromArgb(239, 150, 255)));
             axSuperMap.selection.Style.BrushOpaqueRate = 20;
             //刷新地图窗口 
             axSuperMap.Refresh();
             objDataSource = null;
         }

附件下载

相关资讯

  • Autodesk 3ds Max 2012 安装破解图文教程

    用万地图下载器下载的谷歌地球高程数据,除了可以在电力、水利、通信、石油、国土、农业、林业、环保、环评、矿山、海洋、物探、规划设计、数字城市、道路勘测等GIS行业中使用外,还可以用于在3DS Max中制作三维地形图。Autodesk 3ds Max 2012 安装包请从以下地址下载:http:/…

    2017-11-24 13:53:37
  • 初识地图发布中间件

    如果需要发布海量影像数据快速构建全国离线二维GIS地理信息系统或全球离线三维地球触摸GIS系统,则需要由硬件、软件、数据和GIS平台四部分组成。

    2017-11-14 11:09:17
  • 中间件的项目应用案例 ——《金风科技全球监控中心》

    《水经注地图发布服务中间件》适合所有需要构建全国或全球地图数据服务器并发布海量影像数据的行业,主要包括考古、电力、水利、通信、物流、石油、国土、农业、林业、环保、环评、矿山、海洋、物探、规划设计、数字城市、数字城管、综合应急、智能交通、公共卫生、园林设计、…

    2017-11-13 14:44:15
  • 如何在内网(局域网中)发布OpenLayers地图平台

    这里以中间件作为谷歌地球(GoogleEarth)卫星地图发布引挚,杭州市4到14级谷歌地球卫星地图(WGS84经纬度投影)作为中间件的地图发布数据源,OpenLayers开源平台作为加载中间件发布的卫星影像数据平台,说明如何在内网(局域网)中构建一套基于OpenLayers开发平台的离线WebGIS地理信…

    2017-11-10 10:54:25

共有访客发表了评论 网友评论

验证码: 看不清楚?