ArcGIS Runtime SDK for Android 入门(24):时态数据查询

2024-01-11 07:38

本文主要是介绍ArcGIS Runtime SDK for Android 入门(24):时态数据查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       时态查询功能是通过用户设定的时间范围对要素表中存储的时间信息进行检索,从而获得在特定时态范围内的要素的操作。本实例以台风数据为例,通过设定的时间范围构造时态查询条件,执行Query查询得到要素的时态查询结果,并将结果要素变换为图形对象进行显示。

实现步骤:

1.创建Android项目   

2.添加Runtime SDK依赖   

    前两步本文省略,初学者可参照 ArcGIS Runtime SDK for Android 入门(1):第一个地图应用程序(二维)

3.添加权限及OpenGL ES支持

    在AndroidManifest.xml中添加:

    <!--联网权限 --><uses-permission android:name="android.permission.INTERNET" /><!--OpenGL ES支持 --><uses-featureandroid:glEsVersion="0x00020000"android:required="true" />

4.设置界面布局

    布局XML代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:orientation="horizontal"><Buttonandroid:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:id="@+id/btnSetStartDate"android:text="设定起始日期"/><Buttonandroid:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:id="@+id/btnSetEndDate"android:text="设定结束日期"/></LinearLayout><com.esri.arcgisruntime.mapping.view.MapViewandroid:id="@+id/mapView"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="10"/><LinearLayoutandroid:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:orientation="horizontal"><Buttonandroid:id="@+id/btnQuery"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:text="QUERY" /><Buttonandroid:id="@+id/btnClearGraphics"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:text="清空查询结果"/></LinearLayout></LinearLayout>

5.编写代码

思路:

(1)加载在线要素服务数据。

(2)通过设置两个按钮,弹出日期选择框,设定开始与终止日期。

(3)根据设置的开始与终止日期,执行时态查询。

步骤:

(1)变量准备:

    private ArcGISMap mMap;                                     //地图对象private MapView mMapView;                                   //MapView组件对象private ServiceFeatureTable mServiceFeatureTable;           //要素表服务对象private FeatureLayer mFeaturelayer;                         //要素图层对象private DatePickerDialog mStartDateDialog;                  //设置起始日期的日期选择框private DatePickerDialog mEndDateDialog;                    //设置结束日期的日期选择框private GregorianCalendar mStartDateCalendar;               //起始日期对象private GregorianCalendar mEndDateCalendar;                 //结束日期对象

(2)onCreate方法:

    //Activity初始化时触发事件执行本函数@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);//获得Layout中的MapView组件对象mMapView = (MapView)findViewById(R.id.mapView);//以海洋图为底图创建地图对象mMap = new ArcGISMap(Basemap.createOceans());//通过URL创建台风要素服务的要素表mServiceFeatureTable = new ServiceFeatureTable("https://sampleserver6.arcgisonline.com/arcgis/rest/services/Hurricanes/MapServer/0");//使用ServiceFeatureTable对象创建Featurelayer对象mFeaturelayer = new FeatureLayer(mServiceFeatureTable);//将图层添加到地图中mMap.getOperationalLayers().add(mFeaturelayer);//设置地图在MapView中显示mMapView.setMap(mMap);//初始化日期选择框initDatePickerDialog();//设置各个按钮的点击监听事件findViewById(R.id.btnSetStartDate).setOnClickListener(this);findViewById(R.id.btnSetEndDate).setOnClickListener(this);findViewById(R.id.btnQuery).setOnClickListener(this);findViewById(R.id.btnClearGraphics).setOnClickListener(this);}

(3)日期选择框初始化方法:

    //初始化日期选择框private void initDatePickerDialog(){//创建时间选择框对象并设置监听mStartDateDialog = new DatePickerDialog(MainActivity.this, new DatePickerDialog.OnDateSetListener() {@Overridepublic void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) { ;mStartDateCalendar=new GregorianCalendar(year, monthOfYear, dayOfMonth);}}, 2000, 7, 1);mEndDateDialog = new DatePickerDialog(MainActivity.this, new DatePickerDialog.OnDateSetListener() {@Overridepublic void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) { ;mEndDateCalendar=new GregorianCalendar(year, monthOfYear, dayOfMonth);}},2000,7,1);//设置日期选择框的时间范围Calendar startCalendar = Calendar.getInstance();Calendar endCalendar = Calendar.getInstance();startCalendar.set(2000,7,1);endCalendar.set(2000,9,31);mStartDateDialog.getDatePicker().setMinDate(startCalendar.getTime().getTime());mStartDateDialog.getDatePicker().setMaxDate(endCalendar.getTime().getTime());mEndDateDialog.getDatePicker().setMinDate(startCalendar.getTime().getTime());mEndDateDialog.getDatePicker().setMaxDate(endCalendar.getTime().getTime());}

(4)执行时态查询的核心方法:

    //执行Query时态查询操作,并对查询结果进行展示private void queryByTimeExtent(){//创建查询参数对象QueryParameters queryParameters = new QueryParameters();//设置where子句为查询所有要素queryParameters.setWhereClause("1=1");// 创建时间范围对象并设置起始与结束时间TimeExtent timeExtent = new TimeExtent(mStartDateCalendar,mEndDateCalendar);//设置查询参数的时间范围queryParameters.setTimeExtent(timeExtent);//进行要素查询final ListenableFuture<FeatureQueryResult> future = mServiceFeatureTable.queryFeaturesAsync(queryParameters);//当异步查询结果返回时,使用addDoneListener触发进行接收future.addDoneListener(new Runnable() {@Overridepublic void run() {try {//调用get方法获取查询结果FeatureQueryResult result = future.get();//创建用于显示查询结果的GraphicOverlay对象GraphicsOverlay graphicsOverlay=new GraphicsOverlay();//创建要素迭代器实现对查询结果的遍历Iterator<Feature> iterator=result.iterator();//检查并遍历查询结果while(iterator.hasNext()) {//对迭代器中的要素进行遍历Feature feature =iterator.next();//获取结果要素的几何形状对象Geometry geometry=feature.getGeometry();//创建用于显示查询结果的Symbol符号SimpleMarkerSymbol markerSymbol=new SimpleMarkerSymbol(SimpleMarkerSymbol.Style.CIRCLE, Color.RED, 8);//创建用于显示查询结果的Graphic图形,并加入至GraphicOverlayGraphic graphic=new Graphic(geometry,markerSymbol);graphicsOverlay.getGraphics().add(graphic);}//显示查询结果mMapView.getGraphicsOverlays().clear();mMapView.getGraphicsOverlays().add(graphicsOverlay);Envelope envelope = graphicsOverlay.getExtent();mMapView.setViewpointGeometryAsync(envelope, 100);} catch (Exception e) {Toast.makeText(MainActivity.this, "查询失败"  + ". Error=" + e.getMessage(),Toast.LENGTH_SHORT).show();Log.e(getResources().getString(R.string.app_name),"Feature search failed " + ". Error=" + e.getMessage());}}});}

(5)点击事件监听:

    //点击事件监听@Overridepublic void onClick(View view) {switch (view.getId()){case R.id.btnSetStartDate://当点击“设置起始日期”按钮时,弹出起始日期选择框mStartDateDialog.show();break;case R.id.btnSetEndDate://当点击“设置结束日期”按钮时,弹出结束日期选择框mEndDateDialog.show();break;case R.id.btnQuery://当点击“QUERY”按钮时,执行时态查询queryByTimeExtent();break;case R.id.btnClearGraphics://当点击“清空查询结果”按钮时,删除MapView中的图形mMapView.getGraphicsOverlays().clear();break;}}

6.运行App:能够实现简单的时态查询操作。

这篇关于ArcGIS Runtime SDK for Android 入门(24):时态数据查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/593614

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN