billboardChekInfo.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <template>
  2. <div style="width: 400px; padding: 5px; height: 100%">
  3. <el-row>
  4. <span style="color: white">{{ info.billboardType }}</span>
  5. </el-row>
  6. <el-row
  7. ><span style="color: aqua">{{ info.billboardName }}</span></el-row
  8. >
  9. <el-table :data="tableData" border style="width: 100%">
  10. <el-table-column type="index"> </el-table-column>
  11. <el-table-column prop="ReviewContent" label="审查项"> </el-table-column>
  12. <el-table-column prop="ReviewMethod" label="审查方式"> </el-table-column>
  13. <el-table-column fixed="right" label="结果" width="100">
  14. <template slot-scope="scope">
  15. <el-radio
  16. :disabled="shenchazhaugntai('符合', scope.row)"
  17. v-model="scope.row.ruleResult"
  18. label="true"
  19. >符合</el-radio
  20. >
  21. <el-radio
  22. :disabled="shenchazhaugntai('不符合', scope.row)"
  23. v-model="scope.row.ruleResult"
  24. label="false"
  25. >不符合</el-radio
  26. >
  27. </template>
  28. </el-table-column>
  29. </el-table>
  30. <el-row>
  31. <el-input
  32. v-model="ReviewComments"
  33. type="textarea"
  34. placeholder="请输入审查意见"
  35. ></el-input>
  36. </el-row>
  37. <el-row>
  38. <el-button size="mini" type="primary" @click="setReview(true)"
  39. >通过</el-button
  40. >
  41. <el-button size="mini" @click="setReview(false)">不通过</el-button>
  42. </el-row>
  43. </div>
  44. </template>
  45. <script>
  46. import {
  47. cartesian3ToWGS84,
  48. mapQuery,
  49. flatten,
  50. mercator2lonLat,
  51. undergroundMode,
  52. } from "@/utils/MapHelper/MapHelper.js";
  53. import { pointToLineDistance, point, lineString } from "@turf/turf";
  54. export default {
  55. data() {
  56. return {
  57. tableData: [],
  58. ReviewComments: "",
  59. };
  60. },
  61. props: {
  62. info: {
  63. type: Object,
  64. default: () => {
  65. return {};
  66. },
  67. },
  68. layerid: {
  69. type: String,
  70. default: "",
  71. },
  72. lydata: {
  73. type: Object,
  74. default: () => {
  75. return {};
  76. },
  77. },
  78. lyoption: {
  79. type: Object,
  80. default: () => {
  81. return {};
  82. },
  83. },
  84. },
  85. mounted() {
  86. this.init();
  87. },
  88. methods: {
  89. async init() {
  90. let that = this;
  91. debugger;
  92. let ltData = await this.getloutiData(that.info);
  93. //过滤规则
  94. let billboardReviewList = flatten(window.window.billboardReviewList);
  95. //获取当前广告牌类型的规则
  96. let billboardReviewTree = billboardReviewList.find(
  97. (c) => c.billboardType == that.info.billboardType
  98. );
  99. if (billboardReviewTree) {
  100. let billboardReviews = flatten([billboardReviewTree]);
  101. //临时加
  102. //默认
  103. let mr = billboardReviewList.find((c) => c.code == "001");
  104. billboardReviews.splice(0, 0, mr);
  105. billboardReviews.forEach((billboardReview) => {
  106. if (billboardReview.ReviewItems) {
  107. billboardReview.ReviewItems.forEach((ReviewItem) => {
  108. //获取到的单个规则,并对规则判断是否合规
  109. if (ReviewItem.ReviewMethod == "自动审查") {
  110. let ruleResult = "true";
  111. switch (ReviewItem.code) {
  112. case "001234": //筑高度不超过24米的多层建筑墙面和高层建筑裙楼的主体墙面
  113. if (ltData.length > 0) {
  114. //多层高
  115. let MHEIGHT = ltData[0].data.find(
  116. (c) => c.label == "MHEIGHT"
  117. );
  118. if (MHEIGHT && MHEIGHT.value) {
  119. if (Number(MHEIGHT.value) > 24) {
  120. ruleResult = "false";
  121. } else {
  122. ruleResult = "true";
  123. }
  124. }
  125. }
  126. break;
  127. case "0010101": //户外广告上沿不得突出墙面(包括女儿墙)的外轮廓线
  128. //广告上沿高度
  129. let ggsygd = that.info.z + that.info.yL / 2;
  130. //楼高
  131. if (ltData.length > 0) {
  132. //多层高
  133. let MHEIGHT = ltData[0].data.find(
  134. (c) => c.label == "MHEIGHT"
  135. );
  136. if (MHEIGHT && MHEIGHT.value) {
  137. if (ggsygd > Number(MHEIGHT.value)) {
  138. ruleResult = "false";
  139. } else {
  140. ruleResult = "true";
  141. }
  142. }
  143. }
  144. break;
  145. case "0010104": //广告设施宽度应与墙面相协调,周围不应超出墙面外轮廓线,垂直方向突出墙面距离不宜大于0.5米
  146. debugger;
  147. let points = [];
  148. if (ltData.length > 0) {
  149. ltData[0].geometry.points.forEach((point) => {
  150. points.push([point.x, point.y]);
  151. });
  152. var pt = point([this.info.x, this.info.y]);
  153. var line = lineString(points);
  154. var distance = (
  155. pointToLineDistance(pt, line, {
  156. units: "kilometers",
  157. }) * 1000
  158. ).toFixed(4);
  159. let jl = Number(distance) + that.info.zL / 2;
  160. if (jl > 0.5) {
  161. ruleResult = "false";
  162. } else {
  163. ruleResult = "true";
  164. }
  165. }
  166. break;
  167. case "0010105": //户外广告下端距地面净高不得低于3米,且不得防碍行人安全;
  168. //广告下沿高度
  169. let ggxygd = that.info.z - that.info.yL / 2;
  170. if (ggxygd > 3) {
  171. ruleResult = "true";
  172. } else {
  173. ruleResult = "false";
  174. }
  175. break;
  176. case "001020102": //宽度应以建筑开间为单元,且广告高度不得大于3米
  177. let gggd = that.info.xL;
  178. if (gggd > 3) {
  179. ruleResult = "false";
  180. } else {
  181. ruleResult = "true";
  182. }
  183. break;
  184. case "00102020102": //一层建筑层高≤4.5m并且广告高度≤1.5m 或者一层建筑层高>4.5m并且广告高度小于等于2m
  185. if (ltData.length > 0) {
  186. //层高
  187. let FLOORH = ltData[0].data.find(
  188. (c) => c.label == "FLOORH"
  189. );
  190. //广告上沿高度
  191. let ggsygd = that.info.z + that.info.yL / 2;
  192. if (FLOORH && FLOORH.value) {
  193. if (Number(FLOORH.value) > ggsygd) {
  194. if (Number(FLOORH.value) <= 4.5) {
  195. if (that.info.yL <= 1.5) {
  196. ruleResult = "true";
  197. } else {
  198. ruleResult = "false";
  199. }
  200. } else if (Number(FLOORH.value) > 4.5) {
  201. if (that.info.yL <= 2) {
  202. ruleResult = "true";
  203. } else {
  204. ruleResult = "false";
  205. }
  206. }
  207. } else {
  208. ruleResult = "false";
  209. }
  210. }
  211. }
  212. break;
  213. case "00102020104": //户外广告外表面距离墙面不得超过0.3米(霓虹灯户外广告则外表面距离墙面不得超过0.5米)
  214. debugger;
  215. var points1 = [];
  216. if (ltData.length > 0) {
  217. ltData[0].geometry.points.forEach((point) => {
  218. points1.push([point.x, point.y]);
  219. });
  220. var pt1 = point([this.info.x, this.info.y]);
  221. var line1 = lineString(points1);
  222. var distance1 = (
  223. pointToLineDistance(pt1, line1, {
  224. units: "kilometers",
  225. }) * 1000
  226. ).toFixed(4);
  227. var jl1 = Number(distance1) + that.info.zL / 2;
  228. if (jl1 > 0.3) {
  229. ruleResult = "false";
  230. } else {
  231. ruleResult = "true";
  232. }
  233. }
  234. break;
  235. default:
  236. break;
  237. }
  238. ReviewItem.ruleResult = ruleResult;
  239. } else {
  240. ReviewItem.ruleResult = "";
  241. }
  242. that.tableData.push(ReviewItem);
  243. });
  244. }
  245. });
  246. }
  247. },
  248. /**
  249. * 审核状态提交
  250. */
  251. setReview(isPass) {
  252. let item = window.billboardModelList.find((c) => c.id == this.info.id);
  253. item.ReviewComments = this.ReviewComments;
  254. if (isPass) {
  255. item.ReviewStatus = "已通过";
  256. } else {
  257. item.ReviewStatus = "未通过";
  258. }
  259. this.lyoption.cancel();
  260. this.$layer.close(this.layerid);
  261. },
  262. /**
  263. * 获取楼体数据
  264. */
  265. async getloutiData(info) {
  266. let layerDataList = [];
  267. //获取模型信息
  268. let queryBySQLParameters = {
  269. getFeatureMode: "BUFFER",
  270. datasetNames: [
  271. window.billboardModelLT.dataSourceName +
  272. ":" +
  273. window.billboardModelLT.datasetName,
  274. ],
  275. geometry: {
  276. parts: [1],
  277. points: [{ y: info.y, x: info.x }],
  278. type: "POINT",
  279. },
  280. bufferDistance: 0.000005,
  281. hasGeometry: true,
  282. };
  283. let e = await mapQuery(
  284. window.billboardModelLT.dataurl +
  285. "/featureResults.json?returnContent=true",
  286. queryBySQLParameters
  287. );
  288. if (e && e.totalCount > 0) {
  289. e.features.forEach((feature) => {
  290. let layerData = { data: [], geometry: feature.geometry };
  291. feature.fieldNames.forEach((fieldName, i) => {
  292. let Field = e.datasetInfos
  293. ? e.datasetInfos[0].fieldInfos.find(
  294. (c) =>
  295. c.name && c.name.toUpperCase() == fieldName.toUpperCase()
  296. )
  297. : null;
  298. if (Field) {
  299. layerData.data.push({
  300. label: fieldName,
  301. labelCN: Field ? Field.caption : fieldName,
  302. value: feature.fieldValues[i],
  303. });
  304. }
  305. });
  306. layerDataList.push(layerData);
  307. });
  308. }
  309. return layerDataList;
  310. },
  311. /**
  312. * 审查状态禁止选中
  313. */
  314. shenchazhaugntai(zt, row) {
  315. if (zt == "符合") {
  316. if (row.ReviewMethod != "自动审查") {
  317. return false;
  318. } else if (row.ReviewMethod == "自动审查" && row.ruleResult == "true") {
  319. return false;
  320. } else if (
  321. row.ReviewMethod == "自动审查" &&
  322. row.ruleResult == "false"
  323. ) {
  324. return true;
  325. }
  326. } else {
  327. if (row.ReviewMethod != "自动审查") {
  328. return false;
  329. } else if (
  330. row.ReviewMethod == "自动审查" &&
  331. row.ruleResult == "false"
  332. ) {
  333. return false;
  334. } else if (row.ReviewMethod == "自动审查" && row.ruleResult == "true") {
  335. return true;
  336. }
  337. }
  338. },
  339. },
  340. };
  341. </script>
  342. <style scoped>
  343. div
  344. .el-row
  345. .el-table
  346. .el-row
  347. .el-table-column
  348. .el-radio__label
  349. .el-table-column {
  350. font-size: 10px;
  351. }
  352. </style>