WebGIS 8-1 缓冲区分析

加载底图


请参考底部完整代码

单圈缓冲区分析

一.创建一个多边形

  • 多点构成弧段
//            创建一个数组用于此存放点
        var points = new Array();
//              用for循环传入四个点的坐标
        points[0]=new Zondy.Object.Point2D(0.46, 30.1);
        points[1] = new Zondy.Object.Point2D(11.48, 6.22);
        points[2] = new Zondy.Object.Point2D(36.73, 7.6);
        points[3] = new Zondy.Object.Point2D(58.77, 25.51);
        points[4] = new Zondy.Object.Point2D(41, 51);

//            构成区要素的弧段
        var arc = new Zondy.Object.Arc(points);
//            构成折线的弧段
        var arc = new Zondy.Object.Arc(points);
  • 多弧段构成折线
//            构成区要素的折线
        var anyLine = new Zondy.Object.AnyLine([arc]);
  • 多折线构成区
////            构成区要素
        var gRegion = new Zondy.Object.GRegion([anyLine]);

创建区(合并代码)

//        创建多边形
        var gRegion = new Zondy.Object.GRegion([
            new Zondy.Object.AnyLine([
                new Zondy.Object.Arc([
                    new Zondy.Object.Point2D(0.46, 30.1),
                    new Zondy.Object.Point2D(11.48, 6.22),
                    new Zondy.Object.Point2D(36.73, 7.6),
                    new Zondy.Object.Point2D(58.77, 25.51),
                    new Zondy.Object.Point2D(41, 51)
                ])
            ])
        ]);

  • 设置几何参数信息
//                创建构成区要素的几何信息
        var regGeom = new Zondy.Object.FeatureGeometry();
//        传入几何信息
        regGeom.setRegGeom([gRegion]);

  • 设置图形参数信息(前面需要设置符号参数信息)
//            随机输出1-1502之间的整数
        <!--Math.floor 取最大整数-->
        var fillColor = Math.floor(Math.random() * 1502 + 1);

//            设置区的符号信息
        var cRegionInfo = new Zondy.Object.CRegionInfo({
            FillColor: fillColor //设置填充颜色
        });
//              设置图形参数
        var GraphicInfo = new Zondy.Object.WebGraphicsInfo({
            InfoType: 3,      //设为区类型
            RegInfo: cRegionInfo    //传入符号信息
        });
  • 设置属性结构
//        设置属性结构
        var attStruct = new Zondy.Object.CAttStruct({
            FldName: ["ID", "周长", "面积", "name"],
            FldNumber: 4,
            FldType: ["long", "double", "double", "string"]
        });
  • 设置属性值Value
//          设置属性值
        var attValue = [1234845, 45546, 4444444, "mdzz"];
        var valueRow = new Zondy.Object.CAttDataRow(attValue, 1);

  • 创建要素
//            创建要素
        var feature = new Zondy.Object.Feature({
            fGeom: regGeom,                //传入几何信息
            GraphicInfo: GraphicInfo,       //传入图形参数信息
            AttValue: attValue               //传入属性值
        });
  • 设置要素类型
//            将要素设置为区要素
        feature.setFType(3);
  • 创建要素数据集(Zondy.Object.FeatureSet())
//            创建要素数据集
        var featureSet = new Zondy.Object.FeatureSet();
//            设置数据集的属性结构
        featureSet.AttStruct = attStruct;
//            将要素添加到数据集中
        featureSet.addFeature(feature);

  • 创建编辑服务类
//          创建一个编辑服务类
        var editService = new Zondy.Service.EditLayerFeature("gdbp://MapGisLocal/OpenLayerVecterMap/ds/世界地图经纬度/sfcls/世界政区",
                {
                    ip: "127.0.0.1", //服务器ip
                    port: "6163"       //端口
                });

//     将要素数据集添加到图层中并使用回调函数
            editService.add(featureSet);

二.进行缓冲区分析

  • 实例化单圈缓冲区分析对象
//        实例化单圈缓冲区分析对象
        var featureBuffBySR = new Zondy.Service.FeatureBuffBySingleRing({
            ip: "127.0.0.1",
            port: "6163",
            leftRad: 10,//左缓冲半径
            rightRad: 10 //右缓冲半径
        });

  • 设置必要参数
        //设置必要参数
        featureBuffBySR.sfGeometryXML = $.toJSON([regGeom]); //几何信息
        featureBuffBySR.attStructXML = $.toJSON([attStruct]);//属性结构
        featureBuffBySR.attRowsXML = $.toJSON([valueRow]);//属性值
        featureBuffBySR.traceRadius = 0.0001;  //跟踪半径
//        设置生成的缓冲区要素的存放路径及文件名 //必填!!
        featureBuffBySR.resultName = "gdbp://MapGisLocal/OpenLayerVecterMap/sfcls/缓冲结果" + getCurrentTime();

  • 执行缓冲(execute)
//          执行缓冲区分析并调用回调函数
        featureBuffBySR.execute(AnalysisSuccess);
  • 回调函数内将图层添加并显示
//    回调函数
    function AnalysisSuccess(data) {
//          如果获取到结果
        if (data.results) {
//          如果获取的结果数组元素数量不为0
            if (data.results.length != 0) {
//                新建图层存储缓冲区分析结果
                var resultLayer = new Zondy.Map.Layer("结果图层", [data.results[0].Value], {
                    ip: '127.0.0.1',//ip
                    port: '6163',//端口
                    isBaseLayer: false//不为基础图层
                });
                map.addLayer(resultLayer);//将图层添加到地图容器中
            }
        } else {
            alert('缓冲失败,请检查参数');//弹窗提醒
        }
    }

获取当前时间函数
    //              获取当前时间函数
    function getCurrentTime() {
        //实例化一个日期对象
        var now = new Date();

        var year = now.getFullYear();   //四位数字返回年份。
        var month = now.getMonth() + 1; //月份 (0 ~ 11)。
        var day = now.getDate();        //一个月中的某一天 (1 ~ 31)

        var hh = now.getHours();        //获取小时 0-23
        var mm = now.getMinutes();      //获取分钟 0-59
        var ss = now.getSeconds();      //获取秒 0-59

//            定义一个对象存储时间
        var clock = year + "-";   //2016-

//            如果月份小于10则在月份前加0
        if (month < 10) clock += "0";
        clock += month + "-";      //2016-07-
//            如果天数小于10则在天数前加0
        if (day < 10) clock += "0";
        clock += day + "-";         //2016-07-27-
//            如果小时小于10则在小时前加0
        if (hh < 10) clock += "0";
        clock += hh;                //2016-07-27-21
//            如果分钟小于10则在分钟前加0
        if (mm < 10) clock += "0";
        clock += mm;                //2016-07-27-2135
//            如果秒数小于10则在秒数前加0
        if (ss < 10) clock += "0";
        clock += ss;                //2016-07-27-213523
//            返回clock的值
        return (clock);
    }

完整代码


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<link href="../css/mapDefault.css" type="text/css" rel="stylesheet"/>
<script src="../libs/jquery-1.11.2.min.js" type="text/javascript"></script>
<script src="../libs/OpenLayers.js" type="text/javascript"></script>
<script src="../libs/zdclient.js" type="text/javascript"></script>
<script type="text/javascript">

    var map, layer;

    function init() {
        //            添加地图容器
        map = new OpenLayers.Map('map1', {
            controls: [
                new OpenLayers.Control.MousePosition(),//此控件显示鼠标移动时,所在点的地理坐标
                new OpenLayers.Control.Navigation(),//此控件处理伴随鼠标事件的地图浏览
                new OpenLayers.Control.LayerSwitcher(),//图层切换控件
                new OpenLayers.Control.OverviewMap() //鹰眼
            ]
        });
        //创建图层
        layer = new Zondy.Map.Layer("Map", ["gdbp://MapGisLocal/OpenLayerVecterMap/ds/世界地图经纬度/sfcls/世界政区"], {
            ip: "127.0.0.1", //ip
            port: "6163",//端口
            isBaseLayer: true //作为底图
        });

//      将图层添加到地图中
        map.addLayers([layer]);
//        设置地图显示中心及缩放级别
        map.setCenter(new OpenLayers.LonLat(0, 0), 2);

    }





    <!-------------------单圈缓冲区分析------------------- -->
    function singleBuffAnalysis() {

//        创建多边形
        var gRegion = new Zondy.Object.GRegion([
            new Zondy.Object.AnyLine([
                new Zondy.Object.Arc([
                    new Zondy.Object.Point2D(0.46, 30.1),
                    new Zondy.Object.Point2D(11.48, 6.22),
                    new Zondy.Object.Point2D(36.73, 7.6),
                    new Zondy.Object.Point2D(58.77, 25.51),
                    new Zondy.Object.Point2D(41, 51)
                ])
            ])
        ]);

////            创建一个数组用于此存放点
//        var points = new Array();
////              用for循环传入四个点的坐标
//        points[0]=new Zondy.Object.Point2D(0.46, 30.1);
//        points[1] = new Zondy.Object.Point2D(11.48, 6.22);
//        points[2] = new Zondy.Object.Point2D(36.73, 7.6);
//        points[3] = new Zondy.Object.Point2D(58.77, 25.51);
//        points[4] = new Zondy.Object.Point2D(41, 51);
//
////            构成折线的弧段
//        var arc = new Zondy.Object.Arc(points);
////            构成区要素的折线
//        var anyLine = new Zondy.Object.AnyLine([arc]);
////            构成区要素
//        var gRegion = new Zondy.Object.GRegion([anyLine]);


//                创建构成区要素的几何信息
        var regGeom = new Zondy.Object.FeatureGeometry();
//        传入几何信息
        regGeom.setRegGeom([gRegion]);


        //            随机输出1-1502之间的整数
        <!--Math.floor 取最大整数-->
        var fillColor = Math.floor(Math.random() * 1502 + 1);

//            设置区的符号信息
        var cRegionInfo = new Zondy.Object.CRegionInfo({
            FillColor: fillColor //设置填充颜色
        });
//              设置图形参数
        var GraphicInfo = new Zondy.Object.WebGraphicsInfo({
            InfoType: 3,      //设为区类型
            RegInfo: cRegionInfo    //传入符号信息
        });


//        设置属性结构
        var attStruct = new Zondy.Object.CAttStruct({
            FldName: ["ID", "周长", "面积", "name"],
            FldNumber: 4,
            FldType: ["long", "double", "double", "string"]
        });
//          设置属性值
        var attValue = [1234845, 45546, 4444444, "mdzz"];
        var valueRow = new Zondy.Object.CAttDataRow(attValue, 1);


//            创建要素
        var feature = new Zondy.Object.Feature({
            fGeom: regGeom,                //传入几何信息
            GraphicInfo: GraphicInfo,       //传入图形参数信息
            AttValue: attValue               //传入属性值
        });
//            将要素设置为区要素
        feature.setFType(3);

//            创建要素数据集
        var featureSet = new Zondy.Object.FeatureSet();
//            设置数据集的属性结构
        featureSet.AttStruct = attStruct;
//            将要素添加到数据集中
        featureSet.addFeature(feature);

        //          创建一个编辑服务类
        var editService = new Zondy.Service.EditLayerFeature("gdbp://MapGisLocal/OpenLayerVecterMap/ds/世界地图经纬度/sfcls/世界政区",
                {
                    ip: "127.0.0.1", //服务器ip
                    port: "6163"       //端口
                });

//     将要素数据集添加到图层中并使用回调函数
        editService.add(featureSet);





//        实例化单圈缓冲区分析对象
        var featureBuffBySR = new Zondy.Service.FeatureBuffBySingleRing({
            ip: "127.0.0.1",
            port: "6163",
            leftRad: 10,//左缓冲半径
            rightRad: 10 //右缓冲半径
        });


        //设置必要参数
        featureBuffBySR.sfGeometryXML = $.toJSON([regGeom]); //几何信息
        featureBuffBySR.attStructXML = $.toJSON([attStruct]);//属性结构
        featureBuffBySR.attRowsXML = $.toJSON([valueRow]);//属性值
        featureBuffBySR.traceRadius = 0.0001;  //跟踪半径
//        设置生成的缓冲区要素的存放路径及文件名 //必填!!
        featureBuffBySR.resultName = "gdbp://MapGisLocal/OpenLayerVecterMap/sfcls/缓冲结果" + getCurrentTime();

//          执行缓冲区分析并调用回调函数
        featureBuffBySR.execute(AnalysisSuccess);



    }


//    回调函数
    function AnalysisSuccess(data) {
//          如果获取到结果
        if (data.results) {
//          如果获取的结果数组元素数量不为0
            if (data.results.length != 0) {
//                新建图层存储缓冲区分析结果
                var resultLayer = new Zondy.Map.Layer("结果图层", [data.results[0].Value], {
                    ip: '127.0.0.1',//ip
                    port: '6163',//端口
                    isBaseLayer: false//不为基础图层
                });
                map.addLayer(resultLayer);//将图层添加到地图容器中
            }
        } else {
            alert('缓冲失败,请检查参数');//弹窗提醒
        }
    }


    //              获取当前时间函数
    function getCurrentTime() {
        //实例化一个日期对象
        var now = new Date();

        var year = now.getFullYear();   //四位数字返回年份。
        var month = now.getMonth() + 1; //月份 (0 ~ 11)。
        var day = now.getDate();        //一个月中的某一天 (1 ~ 31)

        var hh = now.getHours();        //获取小时 0-23
        var mm = now.getMinutes();      //获取分钟 0-59
        var ss = now.getSeconds();      //获取秒 0-59

//            定义一个对象存储时间
        var clock = year + "-";   //2016-

//            如果月份小于10则在月份前加0
        if (month < 10) clock += "0";
        clock += month + "-";      //2016-07-
//            如果天数小于10则在天数前加0
        if (day < 10) clock += "0";
        clock += day + "-";         //2016-07-27-
//            如果小时小于10则在小时前加0
        if (hh < 10) clock += "0";
        clock += hh;                //2016-07-27-21
//            如果分钟小于10则在分钟前加0
        if (mm < 10) clock += "0";
        clock += mm;                //2016-07-27-2135
//            如果秒数小于10则在秒数前加0
        if (ss < 10) clock += "0";
        clock += ss;                //2016-07-27-213523
//            返回clock的值
        return (clock);
    }


</script>


<body onload="init()">
<div>
    <input type="button" class="ButtonLib" value="单层缓冲区分析" onclick="singleBuffAnalysis()">
</div>
<div id="map1">

</div>

</body>
</html>

效果

Paste_Image.png
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容