-
Notifications
You must be signed in to change notification settings - Fork 3k
/
LocationSourceDemoActivity.kt
114 lines (100 loc) · 3.71 KB
/
LocationSourceDemoActivity.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// Copyright 2020 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.example.kotlindemos
import android.Manifest.permission
import android.annotation.SuppressLint
import android.content.pm.PackageManager
import android.location.Location
import android.os.Bundle
import android.util.Log
import androidx.appcompat.app.AppCompatActivity
import androidx.core.app.ActivityCompat
import androidx.lifecycle.Lifecycle
import androidx.lifecycle.LifecycleObserver
import androidx.lifecycle.OnLifecycleEvent
import androidx.lifecycle.lifecycleScope
import com.google.android.gms.maps.GoogleMap
import com.google.android.gms.maps.GoogleMap.OnMapLongClickListener
import com.google.android.gms.maps.LocationSource
import com.google.android.gms.maps.LocationSource.OnLocationChangedListener
import com.google.android.gms.maps.SupportMapFragment
import com.google.android.gms.maps.model.LatLng
import com.google.maps.android.ktx.awaitMap
/**
* This shows how to use a custom location source.
*/
class LocationSourceDemoActivity : AppCompatActivity() {
private val locationSource = LongPressLocationSource()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_basic_map_demo)
val mapFragment = supportFragmentManager.findFragmentById(R.id.map) as SupportMapFragment
lifecycleScope.launchWhenCreated {
val map = mapFragment.awaitMap()
init(map = map)
}
lifecycle.addObserver(locationSource)
}
@SuppressLint("MissingPermission")
private fun init(map: GoogleMap) {
map.setLocationSource(locationSource)
map.setOnMapLongClickListener(locationSource)
if (ActivityCompat.checkSelfPermission(this, permission.ACCESS_FINE_LOCATION)
!= PackageManager.PERMISSION_GRANTED
&& ActivityCompat.checkSelfPermission(this, permission.ACCESS_COARSE_LOCATION)
!= PackageManager.PERMISSION_GRANTED) {
return
}
map.isMyLocationEnabled = true
}
}
/**
* A [LocationSource] which reports a new location whenever a user long presses the map
* at
* the point at which a user long pressed the map.
*/
private class LongPressLocationSource : LocationSource, OnMapLongClickListener, LifecycleObserver {
private var listener: OnLocationChangedListener? = null
/**
* Flag to keep track of the activity's lifecycle. This is not strictly necessary in this
* case because onMapLongPress events don't occur while the activity containing the map is
* paused but is included to demonstrate best practices (e.g., if a background service were
* to be used).
*/
private var paused = false
override fun activate(listener: OnLocationChangedListener) {
this.listener = listener
}
override fun deactivate() {
listener = null
}
override fun onMapLongClick(point: LatLng) {
if (paused) {
return
}
val location = Location("LongPressLocationProvider")
location.latitude = point.latitude
location.longitude = point.longitude
location.accuracy = 100f
listener?.onLocationChanged(location)
}
@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
fun onPause() {
paused = true
}
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
fun onResume() {
paused = false
}
}