var polygonSet = [];//等值线转面后的要素集
                   for(i=0; i<featureSet.length; i++){//featureSet为等值线要素集
                               //绘制等值线    
                                var graphic = new Graphic(featureSet[i].geometry, symbol, featureSet[i].attributes);                            
                                graphicLayer.add(graphic);
                                //标注等值线的值
                                var path = featureSet[i].geometry.paths[0]; //等值线拐点
                                var startPoint = new Point(path[0],new SpatialReference({ wkid:2363 }));//取第一个拐点坐标创建Point
                                var textSymbol = new TextSymbol(
                                            number.format(featureSet[i].attributes.CONTOUR),
                                            new Font("12px",Font.STYLE_NORMAL,Font.VARIANT_NORMAL, Font.WEIGHT_NORMAL, "Arial"),
                                            new Color([0,2,59])
                                    );
                                textSymbol.setOffset(11,-5);
                                textSymbol.setAlign(TextSymbol.ALIGN_START);                                
                                var textGraphic = new Graphic(startPoint, textSymbol);    //创建标注的要素    
                                map.graphics.add(textGraphic);    //将线要素转为面要素,计算面积    
                                if(path.length >= 3){//将线要素转为面要素
                                    var polygonJson={};
                                    polygonJson.rings = featureSet[i].geometry.paths;
                                    (polygonJson.rings[0])[path.length] = path[0];
                                    (polygonJson.rings[0]).reverse();//将坐标串顺序反转
                                    polygonJson.spatialReference = featureSet[i].geometry.spatialReference;
                                    var polygon = new Polygon(polygonJson);
                                
                                    //计算面积
                                    var geo = webMercatorUtils.webMercatorToGeographic(polygon);  //Converts geometry from Web Mercator units to geographic units.               
                     var Area = geodesicUtils.geodesicAreas([geo], esri.Units.SQUARE_METERS);//Determine the area for the input polygons
                     var area=parseFloat(Area[0]);
                                    var polygonFeat={}; //面要素对象
                                    //将线要素属性赋给面要素
                                    polygonFeat.attributes=featureSet[i].attributes;
                                    polygonFeat.geometry=polygon;
                                    polygonFeat.attributes.F_AREA = area;
                                    polygonSet.push(polygonFeat);
                                }
                            }

 

最近在做一个功能,将等值线转成面并计算面积,再转的过程中发现面积总是为负的,因为之前多次使用该计算方法,并未出现问题,因此很纠结。。。。
参考一个帖子,具体地址找不到了,有一个截图:


因为的面要素不是直接从地图服务里读取出来的,是通过转换方式获取的,因此个人认为有可能是坐标串顺序的问题,就把坐标串顺序进行了反转,bingo,OK了!!!
总结,计算面积出现负值可能是因为坐标串顺序的问题,可以尝试该方法;
polygonJson.rings[0]).reverse();//将坐标串顺序反转