当前位置:   article > 正文

基于SpringBoot和PotsGIS的各省地震震发可视化分析

基于SpringBoot和PotsGIS的各省地震震发可视化分析

目录

前言

一、后台接口研发

1、控制层实现

2、Mapper访问层

3、空间查询分析

 二、前端可视化展示

1、主体地图定义        

2、行政区划列表定义

3、行政区划定位

三、数据分析

1、北京市

2、广东省

3、青海省

 4、湖南省

总结


前言

        在之前的博文中,我们对全球地震信息进行了可视化展示。地震对人类的生命财产安全造成了严重的威胁,但目前又缺乏科学准确的预测。在无法准确预测的前提下,我们对现今发生的地震信息结合我国的行政区划进行统一展示。目前采集的数据是截止到2023年12月6日的。2023年12月6日以后的,暂时没有采集。

        本文使用SpringBoot框架进行开发,将深度分析全国各省的地震震发情况,按照省级行政区划的方式进行空间统计分析,空间数据库依然采用我们熟悉的PostGIS数据库。通过本文可以对全国各省的地震分布有一个大致的了解,快来看看你所在省份是否是地震高发区呢。跟着本文一起来看看吧。

一、后台接口研发

        本文后台采用SpringBoot开发框架,数据访问层采用Mybatis-Plus插件。下面将按照MVC开发模式对各层进行设计和实现。

1、控制层实现

        控制层主要提供三个方法,第一个方法是跳转到具体的地图展示页面,第二个方法是根据行政区划code查询地震信息列表,第三个方法是查询行政区划的geojson边界数据。关键代码如下:

  1. package com.yelang.project.extend.earthquake.controller;
  2. import java.util.List;
  3. import org.apache.shiro.authz.annotation.RequiresPermissions;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.stereotype.Controller;
  6. import org.springframework.web.bind.annotation.GetMapping;
  7. import org.springframework.web.bind.annotation.PathVariable;
  8. import org.springframework.web.bind.annotation.PostMapping;
  9. import org.springframework.web.bind.annotation.RequestMapping;
  10. import org.springframework.web.bind.annotation.ResponseBody;
  11. import com.yelang.framework.web.controller.BaseController;
  12. import com.yelang.framework.web.domain.AjaxResult;
  13. import com.yelang.framework.web.page.TableDataInfo;
  14. import com.yelang.project.extend.earthquake.domain.EarthquakeInfo;
  15. import com.yelang.project.extend.earthquake.domain.Province;
  16. import com.yelang.project.extend.earthquake.service.IEarthquakeInfoService;
  17. import com.yelang.project.extend.earthquake.service.IProvinceService;
  18. @Controller
  19. @RequestMapping("/eq/province")
  20. public class ProvinceController extends BaseController{
  21. private String prefix = "earthquake/province";
  22. @Autowired
  23. private IProvinceService provinceService;
  24. @Autowired
  25. private IEarthquakeInfoService earthQuakeInfoService;
  26. @RequiresPermissions("eq:province:view")
  27. @GetMapping()
  28. public String map(){
  29. return prefix + "/map";
  30. }
  31. @RequiresPermissions("eq:province:list")
  32. @PostMapping("/list")
  33. @ResponseBody
  34. public TableDataInfo list(Province province){
  35. startPage();
  36. List<Province> list = provinceService.selectList(province);
  37. return getDataTable(list);
  38. }
  39. @RequiresPermissions("eq:province:geom")
  40. @GetMapping("/geojson/{id}")
  41. @ResponseBody
  42. public AjaxResult getGeojson(@PathVariable("id") Long id){
  43. Province province = provinceService.findGeoJsonById(id, null);
  44. return AjaxResult.success().put("data", province.getGeomJson());
  45. }
  46. @RequiresPermissions("eq:province:statview")
  47. @GetMapping("/statview")
  48. public String statview(){
  49. return prefix + "/statview";
  50. }
  51. @RequiresPermissions("eq:province:quakelist")
  52. @GetMapping("/quakelist/{code}")
  53. @ResponseBody
  54. public AjaxResult quakelist(@PathVariable("code") String code){
  55. List<EarthquakeInfo> list = earthQuakeInfoService.findListByPcode(code);
  56. AjaxResult ar = AjaxResult.success();
  57. ar.put("data", list);
  58. return ar;
  59. }
  60. }

2、Mapper访问层

        系统的业务层比较简单,只是将控制层的参数传递到数据库中。因此这里不对业务层代码进行深度介绍,由于Mapper访问层是对空间数据库的访问,有必要在此进行一些介绍,让广大朋友知道空间分析函数的基本使用方法。

  1. package com.yelang.project.extend.earthquake.mapper;
  2. import java.util.List;
  3. import org.apache.ibatis.annotations.Param;
  4. import org.apache.ibatis.annotations.Select;
  5. import com.baomidou.mybatisplus.core.mapper.BaseMapper;
  6. import com.yelang.project.extend.earthquake.domain.EarthquakeInfo;
  7. /**
  8. * 地震信息数据操作接口
  9. * @author wuzuhu
  10. *
  11. */
  12. public interface EarthQuakeInfoMapper extends BaseMapper<EarthquakeInfo>{
  13. static final String FIND_LISTBY_PCODE = "<script>"
  14. + "select t.* from biz_province p,biz_earthquake_info t where p.code = #{code} "
  15. + "and _st_contains(p.geom, ST_GeomFromText(format('point(%s %s)',t.eq_lng,t.eq_lat),4326)) "
  16. + "</script>";
  17. /**
  18. * 根据省级行政区划查询对应的地震信息发生列表
  19. * @param code 省份编码
  20. * @return 对应的地震信息列表
  21. */
  22. @Select(FIND_LISTBY_PCODE)
  23. List<EarthquakeInfo> findListByPcode(@Param("code")String code);
  24. }

3、空间查询分析

        在本文的需求中,我们需要对省级行政区划内的地震震发信息进行可视化统计,需要使用到st_contains函数。这里需要判断点是否在面数据中,使用数据库客户端来验证一下:

  1. select t.* from biz_province p,biz_earthquake_info t where p.code = '110000'
  2. and st_contains(p.geom, ST_GeomFromText(format('point(%s %s)',t.eq_lng,t.eq_lat),4326));

        其中,110000是北京市的行政编号,通过行政编码来进行行政区划的过滤。执行上述sql语句后可以看到,北京市的震发数量是18条数据。

 二、前端可视化展示

        前端空间数据展示使用Leaflet组件展示,静态标注使用Leaflet.canvaslabel.js,图例组件采用leaflet.legend.js。下面来看看前端可视化代码的具体实现过程。

1、主体地图定义        

  1. //矢量文本标签渲染器
  2. var canvasLabel = new L.CanvasLabel({
  3. defaultLabelStyle: {
  4. collisionFlg: true,
  5. scale: 1.1,
  6. //strokeStyle: "#000",
  7. strokeStyle: "red",
  8. fillStyle: "#fff",
  9. //lineWidth:3
  10. lineWidth:15
  11. }
  12. });
  13. $("#mapid").height($(window).height());//动态设置高度
  14. L.CRS.CustomEPSG4326 = L.extend({}, L.CRS.Earth, {
  15. code: 'EPSG:4326',
  16. projection: L.Projection.LonLat,
  17. transformation: new L.Transformation(1 / 180, 1, -1 / 180, 0.5),
  18. scale: function (zoom) {
  19. return 256 * Math.pow(2, zoom - 1);
  20. }
  21. });
  22. var showGroup = L.layerGroup();
  23. var quakeGroup = L.layerGroup();
  24. //限制地图的拖动范围是正负90到正负180,这样才合理。
  25. var maxBounds = L.latLngBounds(L.latLng(-90, -180), L.latLng(90, 180)); //构建视图限制范围 第一个参数是左上角经纬度 第二个参数是右下点经纬度
  26. var mymap = L.map('mapid',{renderer: canvasLabel,crs:L.CRS.CustomEPSG4326,maxBounds:maxBounds,attributionControl:false}).setView([29.052934, 104.0625], 5);
  27. var showLayerGroup =L.featureGroup().addTo(mymap);
  28. L.tileLayer('http://192.168.31.64:8086/data/basemap_nowater/1_10_tms/{z}/{x}/{y}.jpg', {minZoom:1,
  29. maxZoom: 16,
  30. id: 'baseMap-nowater',
  31. tileSize: 256,
  32. zoomOffset: -1
  33. }).addTo(mymap);
  34. //标签
  35. L.tileLayer('http://192.168.31.64:8086/data/basemap_nowater/1-10label/{z}/{x}/{y}.png', {maxZoom: 10,minZoom:1,
  36. id: 'mapbox/label',tileSize: 256,zoomOffset: -1
  37. }).addTo(mymap);

2、行政区划列表定义

  1. function initSidebar(){//初始化sidebar页面
  2. var sidebar = L.control.sidebar('sidebar', {position: 'right'}).addTo(mymap);
  3. //默认sidebar打开,并展示一个tab页
  4. sidebar.open();
  5. $("#xz_info").addClass("active");
  6. $("#home").addClass("active");
  7. //初始化行政区划表格
  8. initHnTownTable();
  9. }
  10. function initHnTownTable(){
  11. var options = {
  12. url: prefix + "/list",
  13. createUrl: prefix + "/add",
  14. updateUrl: prefix + "/edit/{id}",
  15. modalName: "乡镇行政区划",
  16. columns: [
  17. {
  18. field: 'id',
  19. title: '',
  20. visible: false
  21. },
  22. {
  23. field: 'name',
  24. title: '省份'
  25. },
  26. {
  27. field: 'type',
  28. title: '类别'
  29. },
  30. {
  31. title: '操作',
  32. align: 'center',
  33. formatter: function(value, row, index) {
  34. var actions = [];
  35. actions.push('<a class="btn btn-success btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="previewTown(\'' + row.id + '\',\''+row.code+'\')"><i class="fa fa-dot-circle-o"></i>查看</a>');
  36. return actions.join('');
  37. }
  38. }]
  39. };
  40. $.table.init(options);
  41. }

3、行政区划定位

        在地图右侧列表中,点击定位按钮,可以展示当前省级行政区域的空间范围,同时可以查看对应行政区划范围内的地震震发情况。

  1. function initEarthInfo(code){
  2. $.ajax({
  3. type: "get",
  4. url: prefix + "/quakelist/"+ code,
  5. data: {},
  6. success: function(rsData) {
  7. quakeGroup.clearLayers();
  8. var earthData = rsData.data;
  9. for (var i = 0; i < earthData.length; i++) {
  10. var info = earthData[i];
  11. var eqLevel = info.eqLevel;
  12. var strokeStyleSet = "green";
  13. if(parseFloat(eqLevel) > 3.5 && parseFloat(eqLevel) <= 5.0){
  14. strokeStyleSet = "yellow";
  15. }
  16. if(parseFloat(eqLevel) > 5.0){
  17. strokeStyleSet = "red";
  18. }
  19. var marker = L.circleMarker(new L.LatLng(info.eqLat, info.eqLng), {radius: 8,
  20. labelStyle: {
  21. text: info.eqLevel+'级'+info.eqLocation,
  22. rotation: 0,
  23. zIndex: i,
  24. strokeStyle :strokeStyleSet
  25. }});
  26. var content = "<strong>发震时间:</strong>"+info.eqTime + "<br/><strong>震中位置:</strong>"+info.eqLocation;
  27. content += "<br/><strong>震源深度(千米):</strong>"+info.eqDepth + "<br/><strong>震级:</strong>"+info.eqLevel;
  28. marker.bindPopup(content);
  29. quakeGroup.addLayer(marker);
  30. }
  31. mymap.addLayer(quakeGroup);
  32. }
  33. });
  34. }

三、数据分析

        经过后台相关接口的开发,以及前端webgis的界面开发,基本已经完成整个各省行政区划内震发数据的可视化过程,下面结合各省份进行分别说明。由于省份信息众多,这里不全部展开,分别按照区域进行选取一些典型省份进行数据分型说明。

1、北京市

        北京市是国家首都,首先来看一下北京市的震发情况,点击操作栏中的查看按钮,地图会自动定位到北京市的行政区划范围,同时将北京市内的所有震发点进行展示。

 可以看到,北京的地震震发情况比较少,而且震级也不高。一共是18次(以数据库中发布的地震信息为准,仅供参考),最高的震级是3.6级。整体来说,安全系数还是比较高。

2、广东省

        广东省是我们国家的经济大省,也是南方的城市。来看一下南方城市的地震震发情况如何,首先来看一下总体情况。

         截止2023年12月6日,广东的地震次数是61次,最大的震级是4.3级。震级不是很高,还算是比较小的。可以看到在省会附近地震震发很少。

3、青海省

        看完北部的省份和南方的城市,再来看一下西部的城市,这里选取青海省作为示例。相信从地图上就可以一眼直观的看到地震震发较多。同时通过图例可以知道,红色是大于5级的地震,在青海省超过5级的地震就有好几个。最大是青海果洛州玛多县的7.4级地震

        通过在后台查询,青海省的地震次数有466次,比南方和北方省份多了不少。 通过下图可以看到,这附近的大地震还不少。

 4、湖南省

        最后来看一下中部省份湖南省的地震情况。地震震发情况如下:

         可以看到,作为中部省份,湖南省的地震情况是非常少的。有一些是矿震引起的,不是地质运动引起的。在数据中可以查到一共有8条地震信息,其中最大的震级是3.4级,发生在湖南娄底市双峰县。

        通过gis发现了一些时空分布的规律,当我们把地震活动和空间分析结合在一起,就可以发现,在我们国家的西部地区,也就是喜马拉雅一带,地震活动比较频繁,这也与世界地震带分布有对应关系。

总结

        以上就是本文的主要内容,本文使用SpringBoot框架进行开发,将深度分析全国各省的地震震发情况,按照省级行政区划的方式进行空间统计分析,空间数据库依然采用我们熟悉的PostGIS数据库。通过本文可以对全国各省的地震分布有一个大致的了解,快来看看你所在省份是否是地震高发区呢?通过gis可视化,对我们理解地理分布和活动规律有更多的参考和指导。让我们一起用gis去发现更多有意思的分布情况吧。博文使用数据来源于互联网,如有错误,请指出,必将及时修正,欢迎在评论区留言指导,万分感谢。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/368133
推荐阅读
相关标签
  

闽ICP备14008679号