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

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

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. 模糊匹配方案参数化查询示例使用场景建议性能优