gpt4 book ai didi

javascript - 更改要素图层中多边形的顺序? (arcgis js 4.xx)

转载 作者:行者123 更新时间:2023-12-01 16:17:06 25 4
gpt4 key购买 nike

我已尝试在我的初始查询中使用以下内容,并在使用类分隔符绘制多边形之前进行查询。

    query.orderByFields = ["Shape__Area DESC"];

然而这似乎并没有做任何事情。我也尝试过使用 grid_value 字段。

这是我的相关代码,我在其中查询然后进行绘图...主要问题是偶尔大的多边形会遮挡较小的多边形..我大部分都能看到它们,但可见性不是问题..我需要也可以单击它们。如果较小的多边形将绘制在最顶层,或者顶部更高的网格值应该可以解决它。我在文档中找到了 orderByFields 但似乎什么也没做......

query.outFields = ["*"];
//query.orderByFields = ["Shape__Area DESC"];
query.returnDistinctValues = false;
query.returnGeometry = true;
QT.execute(query).then(function (evt) {
evt.features.forEach(function (feature) {
var att = feature.attributes
var test = geometryEngine.convexHull(feature.geometry)
var genpoly = null
if (att.grid_value <= 4.0) {
var rad = att.Shape__Length / 75
genpoly = new Circle({
center: test.centroid,
radius: rad,
radiusUnit: "meters"
})
} else {
genpoly = test
}
var polygonGraphic = new Graphic({
geometry: genpoly,
attributes: att,
type: "polygon"
});
gras.push(polygonGraphic);
});
var renderer = {
type: "class-breaks",
field: "grid_value",
classificationMethod: "esriClassifyManual",
classBreakInfos: [{
minValue: 0,
maxValue: 1.9999,
symbol: {
color: [0, 0, 0, 0],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "I (Not Felt)"
},
{
minValue: 2.0,
maxValue: 3.0,
symbol: {
color: [191, 204, 255, .3],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "II (Weak)"
},
{
minValue: 3.1,
maxValue: 3.9,
symbol: {
color: [153, 153, 255, .4],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "III (Weak)"
},
{
minValue: 4.0,
maxValue: 4.5,
symbol: {
color: [136, 255, 255, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "IV (Light)"
},
{
minValue: 4.5,
maxValue: 4.9999,
symbol: {
color: [125, 248, 148, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "V (Light)"
},
{
minValue: 6.0,
maxValue: 6.9999,
symbol: {
color: [255, 255, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VI (Strong)"
},
{
minValue: 7.0,
maxValue: 7.9999,
symbol: {
color: [255, 221, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VII (Very Strong)"
},
{
minValue: 8.0,
maxValue: 8.9999,
symbol: {
color: [255, 145, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VIII (Severe) "
},
{
minValue: 9.0,
maxValue: 9.9999,
symbol: {
color: [255, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "IX (Violent)"
},
{
minValue: 10.0,
maxValue: 10.9999,
symbol: {
color: [221, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "X"
},
{
minValue: 11.0,
maxValue: 11.9999,
symbol: {
color: [136, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "XI"
},
{
minValue: 12.0,
maxValue: 12.0,
symbol: {
color: [68, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "XII"
}
]
}
var popupTrails = {
outFields: ["*"],
"title": "Shake ID: {id}",
"content": function (feature){
let name_plc;
let dlv = document.createElement("div");
dlv.className = "popd";
dlv.innerHTML = `<b><span class='name_plc'></span></b><br>ID: <span class="ida">${feature.graphic.attributes.id}</span><br> URL: <a href="${feature.graphic.attributes.url}" target="_blank">View</a> <br> Updated: ${feature.graphic.attributes.updated} <br>Grid_value: ${feature.graphic.attributes.grid_value}<br> Event Time: ${feature.graphic.attributes.eventTime} <style>.esri-popup__navigation { display: none;}</style>`;

getName();

function getName() {
let cId = $('span.ida').text();
if (cId) {
//console.log(cId);
let q3 = new Query();
q3.where = "id = '"+ cId +"'";
q3.outFields = ["*"];
QTt.execute(q3).then(function (results) {
results.features.map(function (feat) {
let pID = feat.attributes["id"];
if (cId === pID) {
name_plc = feat.attributes["place"];
console.log(name_plc);
let tx = $('.name_plc').text();
if (tx == 0){
$(".name_plc").append(name_plc);
}
}
});
});
} else {
setTimeout(getName, 230);
}
}
return dlv;
},
};
fl = new FeatureLayer({
source: gras,
objectIdField: "ObjectID",
geometryType: "polygon",
fields: [{
name: "ObjectID",
alias: "ObjectID",
type: "oid"
}, {
name: "id",
alias: "id",
type: "string"
}, {
name: "updated",
alias: "Last Update",
type: "string"
}, {
name: "eventTime",
alias: "eventTime",
type: "string"
}, {
name: "url",
alias: "url",
type: "string"
}, {
name: "grid_value",
alias: "grid_value",
type: "double"
}],
renderer: renderer,
popupEnabled: true,
//outFields: ['*'],
popupTemplate: popupTrails,
visibleElements: [{
featureNavigation: false,
}],
});
map.add(fl);

这是我的完整 CodePen以及..有什么办法可以做这个客户端javascript吗?只需将索引更改为顶部的最小多边形?! 1/3 倍我的一些多边形以正确的顺序呈现。但我需要确保它们始终如此,以便它们可见并且我可以单击它们。


更新:

这是一个更好的截图:例如,我尝试点击中间的绿色形状,最大的蓝色圆圈高亮显示,弹出窗口只显示那个的元数据。无法点击较小的内部。

即点击前。

enter image description here

即在尝试单击绿色的内部小多边形之后——只能访问外部。

enter image description here

也许问题是我的order by 子句 需要在我的过滤器中处理?

 eqLayerView.filter = {
outFields: "*",
orderByFields: "Shape__Area DESC",
where: "id IN (" + sqlExp + ")"
};

最佳答案

看看这个例子,它基于您的代码,我只是删除了很多东西并保留了重要的东西,以查看按区域排序的效果。就像我告诉过你的那样,图层加上渲染器并没有帮助你意识到这一点。只需单击,您就会看到每个功能都已被选中。

<html>

<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no">
<title>OrderByFields - Render order</title>
<style>
html,
body,
#viewDiv {
padding: 0;
margin: 0;
height: 100%;
width: 100%;
}
</style>
<link rel="stylesheet" href="https://js.arcgis.com/4.15/esri/themes/light/main.css">
<script src="https://js.arcgis.com/4.15/"></script>

<script>
require([
"esri/Map",
"esri/views/MapView",
"esri/layers/FeatureLayer",
"esri/geometry/geometryEngine",
"esri/geometry/Circle",
"esri/Graphic",
"esri/symbols/SimpleFillSymbol",
"esri/tasks/QueryTask",
"esri/tasks/support/Query"
], function (
Map,
MapView,
FeatureLayer,
geometryEngine,
Circle,
Graphic,
SimpleFillSymbol,
QueryTask,
Query) {

var map = new Map({
basemap: "gray"
});

var view = new MapView({
container: "viewDiv",
map: map,
center: [-122, 37],
zoom: 2
});

let fl;
let gras = [];
let dVals = [];

const QT = new QueryTask({
url: "https://services9.arcgis.com/RHVPKKiFTONKtxq3/arcgis/rest/services/USGS_Seismic_Data_v1/FeatureServer/1"
});

const query = new Query();
query.where = "eventTime >= CURRENT_TIMESTAMP - 30 AND updated >= CURRENT_TIMESTAMP - 30 AND grid_value > 2 AND id = 'us6000ah9t'";
query.outFields = ["*"];
query.orderByFields = ["Shape__Area DESC"];
query.returnDistinctValues = false;
query.returnGeometry = true;
QT.execute(query).then(function (evt) {
evt.features.forEach(function (feature) {
const att = feature.attributes
console.log(att.Shape__Area);
const test = geometryEngine.convexHull(feature.geometry)
let genpoly = null
if (att.grid_value <= 4.0) {
const rad = att.Shape__Length / 75
genpoly = new Circle({
center: test.centroid,
radius: rad,
radiusUnit: "meters"
})
} else {
genpoly = test
}
att.newArea = geometryEngine.geodesicArea(genpoly);
const polygonGraphic = new Graphic({
geometry: genpoly,
attributes: att,
type: "polygon"
});
gras.push(polygonGraphic);
});

fl = new FeatureLayer({
source: gras.sort((a, b) => {
if (a.attributes.newArea < b.attributes.newArea) {
return 1;
}
if (a.attributes.newArea > b.attributes.newArea) {
return -1;
}
return 0;
}),
objectIdField: "ObjectID",
geometryType: "polygon",
fields: [
{
name: "ObjectID",
alias: "ObjectID",
type: "oid"
}, {
name: "id",
alias: "id",
type: "string"
}, {
name: "grid_value",
alias: "grid_value",
type: "double"
}, {
name: "Shape__Area",
alias: "Original Area",
type: "double"
}, {
name: "newArea",
alias: "Process Area",
type: "double"
}
],
popupTemplate: {
title: "{id}",
content: [
{
type: "fields",
fieldInfos: [
{
fieldName: "grid_value",
label: "Grid Value"
},
{
fieldName: "Shape__Area",
label: "Old Area"
},
{
fieldName: "newArea",
label: "Process Area"
}
]
}
]
},
renderer: {
type: "simple",
symbol: {
type: "simple-fill",
color: [255, 0, 0, 1],
outline: {
width: 1,
color: "black"
}
}
}
});
map.add(fl);
});
});
</script>
</head>

<body>
<div id="viewDiv"></div>
</body>

</html>

更新:

在查看您的更新后,我想我对这个问题有了更好的理解,并且我注意到我之前错过的一些东西,featureNavigation: false。我很确定点击所有功能都被选中,问题是你想要的不是第一个出现的。换句话说,女巫弹出窗口显示点击功能的顺序有问题。

所以,我会向您推荐一个简单的解决方案,手动打开具有所需功能的弹出窗口(在您的情况下,区域较小的弹出窗口)。为此,您需要:

  1. 禁用弹出窗口自动打开
  2. 处理 View 点击事件
  3. 使用view hittest方法获取特征
  4. 打开带有所需功能的弹出窗口

看看我为你做的这个例子,我添加了一个额外的条件来检索一些特征以使其更快

<html>

<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no">
<title>esriFieldTimeDate</title>
<style>
html,
body,
#viewDiv {
padding: 0;
margin: 0;
height: 100%;
width: 100%;
}
</style>
<link rel="stylesheet" href="https://js.arcgis.com/4.15/esri/themes/light/main.css">
<script src="https://js.arcgis.com/4.15/"></script>

<script>
require([
"esri/Map",
"esri/views/MapView",
"esri/layers/FeatureLayer",
"esri/geometry/geometryEngine",
"esri/geometry/Circle",
"esri/Graphic",
"esri/symbols/SimpleFillSymbol",
"esri/tasks/QueryTask",
"esri/tasks/support/Query"
], function (
Map,
MapView,
FeatureLayer,
geometryEngine,
Circle,
Graphic,
SimpleFillSymbol,
QueryTask,
Query) {

var map = new Map({
basemap: "gray"
});

var view = new MapView({
container: "viewDiv",
map: map,
center: [-122, 37],
zoom: 2
});

let fl;
let gras = [];

const QT = new QueryTask({
url: "https://services9.arcgis.com/RHVPKKiFTONKtxq3/arcgis/rest/services/USGS_Seismic_Data_v1/FeatureServer/1"
});

function newAreaCompareFunction(a, b) {
if (a.attributes.newArea < b.attributes.newArea) {
return 1;
}
if (a.attributes.newArea > b.attributes.newArea) {
return -1;
}
return 0;
}

const simpleRenderer = {
type: "simple",
symbol: {
type: "simple-fill",
color: [255, 0, 0, 1],
outline: {
width: 1,
color: "black"
}
}
};
const docRenderer = {
type: "class-breaks",
field: "grid_value",
classificationMethod: "esriClassifyManual",
classBreakInfos: [{
minValue: 0,
maxValue: 1.9999,
symbol: {
color: [0, 0, 0, 0],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "I (Not Felt)"
},
{
minValue: 2.0,
maxValue: 3.0,
symbol: {
color: [191, 204, 255, .3],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "II (Weak)"
},
{
minValue: 3.1,
maxValue: 3.9,
symbol: {
color: [153, 153, 255, .4],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "III (Weak)"
},
{
minValue: 4.0,
maxValue: 4.5,
symbol: {
color: [136, 255, 255, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "IV (Light)"
},
{
minValue: 4.5,
maxValue: 4.9999,
symbol: {
color: [125, 248, 148, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "V (Light)"
},
{
minValue: 6.0,
maxValue: 6.9999,
symbol: {
color: [255, 255, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VI (Strong)"
},
{
minValue: 7.0,
maxValue: 7.9999,
symbol: {
color: [255, 221, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VII (Very Strong)"
},
{
minValue: 8.0,
maxValue: 8.9999,
symbol: {
color: [255, 145, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "VIII (Severe) "
},
{
minValue: 9.0,
maxValue: 9.9999,
symbol: {
color: [255, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "IX (Violent)"
},
{
minValue: 10.0,
maxValue: 10.9999,
symbol: {
color: [221, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "X"
},
{
minValue: 11.0,
maxValue: 11.9999,
symbol: {
color: [136, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "XI"
},
{
minValue: 12.0,
maxValue: 12.0,
symbol: {
color: [68, 0, 0, 1],
outline: {
color: [0, 0, 0, 0],
width: 0.4,
type: "simple-line",
style: "solid"
},
type: "simple-fill",
style: "solid"
},
label: "XII"
}
]
};

const query = new Query();
query.where = "eventTime >= CURRENT_TIMESTAMP - 30 AND updated >= CURRENT_TIMESTAMP - 30 AND grid_value > 2 AND id = 'us6000ah9t'";
query.outFields = ["*"];
query.orderByFields = ["Shape__Area DESC"];
query.returnDistinctValues = false;
query.returnGeometry = true;
QT.execute(query).then(function (evt) {
evt.features.forEach(function (feature) {
const att = feature.attributes
console.log(att.Shape__Area);
const test = geometryEngine.convexHull(feature.geometry)
let genpoly = null
if (att.grid_value <= 4.0) {
const rad = att.Shape__Length / 75
genpoly = new Circle({
center: test.centroid,
radius: rad,
radiusUnit: "meters"
})
} else {
genpoly = test
}
att.newArea = geometryEngine.geodesicArea(genpoly);
const polygonGraphic = new Graphic({
geometry: genpoly,
attributes: att,
type: "polygon"
});
gras.push(polygonGraphic);
});

fl = new FeatureLayer({
source: gras.sort(newAreaCompareFunction),
objectIdField: "ObjectID",
geometryType: "polygon",
fields: [
{
name: "ObjectID",
alias: "ObjectID",
type: "oid"
}, {
name: "id",
alias: "id",
type: "string"
}, {
name: "grid_value",
alias: "grid_value",
type: "double"
}, {
name: "Shape__Area",
alias: "Original Area",
type: "double"
}, {
name: "newArea",
alias: "Process Area",
type: "double"
}
],
popupTemplate: {
title: "{id}",
content: [
{
type: "fields",
fieldInfos: [
{
fieldName: "ObjectID",
label: "Object ID"
},
{
fieldName: "grid_value",
label: "Grid Value"
},
{
fieldName: "Shape__Area",
label: "Old Area"
},
{
fieldName: "newArea",
label: "Process Area"
}
]
}
]
},
renderer: docRenderer
});
map.add(fl);

view.goTo(
gras
.map(f => f.geometry.extent)
.reduce(
(p, c) => p ? p.union(c) : c
)
);

view.popup.autoOpenEnabled = false; // <- disable view popup auto open
view.on("click", function (event) { // <- listen to view click event
view.hitTest(event, { include: fl }) // <- retrieve features
.then(function (response) {
if (response.results.length) {
var feature = response.results // <- get desire feature
.map(result => result.graphic)
.reduce(
(p, c) =>
p ? (c.attributes.newArea < p.attributes.newArea ? c : p) : c
)
;
view.popup.open({ // <- open popup
location: event.mapPoint, // <- use map point of the click event
features: [feature] // <- add the desire feature
});
}
});
});
});
});
</script>
</head>

<body>
<div id="viewDiv"></div>
</body>

</html>

关于javascript - 更改要素图层中多边形的顺序? (arcgis js 4.xx),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62835807/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com