Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
L
location share white
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wanglei
location share white
Commits
f3f02b96
Commit
f3f02b96
authored
Oct 16, 2024
by
wanglei
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
init
parent
9d6c8b7e
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
111 additions
and
48 deletions
+111
-48
MapUtils.kt
...src/main/java/com/base/locationsharewhite/map/MapUtils.kt
+35
-8
LocationMapActivity.kt
.../locationsharewhite/ui/locationmap/LocationMapActivity.kt
+45
-1
MainActivity.kt
.../java/com/base/locationsharewhite/ui/main/MainActivity.kt
+5
-9
LocationUtils.kt
...n/java/com/base/locationsharewhite/utils/LocationUtils.kt
+0
-30
avatar_friend.xml
app/src/main/res/layout/avatar_friend.xml
+22
-0
friend.png
app/src/main/res/mipmap-xxhdpi/friend.png
+0
-0
dimens.xml
app/src/main/res/values/dimens.xml
+4
-0
No files found.
app/src/main/java/com/base/locationsharewhite/map/MapUtils.kt
View file @
f3f02b96
package
com.base.locationsharewhite.map
package
com.base.locationsharewhite.map
import
android.annotation.SuppressLint
import
android.content.Context
import
android.content.Context
import
android.location.Criteria
import
android.location.Location
import
android.location.LocationManager
import
android.view.View
import
android.view.View
import
com.base.locationsharewhite.utils.BitmapUtils.getBitmapDescriptorFromLayoutResId
import
com.base.locationsharewhite.utils.BitmapUtils.getBitmapDescriptorFromLayoutResId
import
com.google.android.gms.maps.CameraUpdateFactory
import
com.google.android.gms.maps.CameraUpdateFactory
import
com.google.android.gms.maps.GoogleMap
import
com.google.android.gms.maps.GoogleMap
import
com.google.android.gms.maps.model.LatLng
import
com.google.android.gms.maps.model.LatLng
import
com.google.android.gms.maps.model.LatLngBounds
import
com.google.android.gms.maps.model.MarkerOptions
import
com.google.android.gms.maps.model.MarkerOptions
import
kotlin.math.abs
object
MapUtils
{
object
MapUtils
{
@SuppressLint
(
"MissingPermission"
)
fun
Context
.
getLastKnowLatLng
():
LatLng
{
val
locationManager
=
getSystemService
(
Context
.
LOCATION_SERVICE
)
as
LocationManager
?
if
(
locationManager
!=
null
)
{
val
provider
:
String
?
=
locationManager
.
getBestProvider
(
Criteria
(),
true
)
if
(
provider
!=
null
)
{
val
lastKnownLocation
:
Location
?
=
locationManager
.
getLastKnownLocation
(
provider
)
val
latitude
:
Double
=
lastKnownLocation
?.
latitude
?:
0.0
//维度
val
longitude
:
Double
=
lastKnownLocation
?.
longitude
?:
0.0
//经度
return
LatLng
(
latitude
,
longitude
)
}
}
return
LatLng
(
0.0
,
0.0
)
}
/**
* 添加view为Marker
*/
fun
GoogleMap
.
addLocationMarker
(
fun
GoogleMap
.
addLocationMarker
(
marker
:
View
,
marker
:
View
,
pair
:
Pair
<
Double
,
Double
>
,
latLng
:
LatLng
,
tittle
:
String
=
""
,
tittle
:
String
=
""
,
)
{
)
{
val
latLng
=
LatLng
(
pair
.
first
,
pair
.
second
)
val
bitmapDescriptor
=
getBitmapDescriptorFromLayoutResId
(
marker
)
val
bitmapDescriptor
=
getBitmapDescriptorFromLayoutResId
(
marker
)
addMarker
(
addMarker
(
MarkerOptions
()
MarkerOptions
()
...
@@ -26,11 +53,11 @@ object MapUtils {
...
@@ -26,11 +53,11 @@ object MapUtils {
}
}
fun
GoogleMap
.
moveCameraZoom
(
fun
GoogleMap
.
cameraMovePointsBounds
(
point1
:
LatLng
,
point2
:
LatLng
,
padding
:
Int
)
{
pair
:
Pair
<
Double
,
Double
>,
// 创建包含两个点的边界
zoom
:
Float
=
15f
val
bounds
=
LatLngBounds
.
Builder
().
include
(
point1
).
include
(
point2
).
build
()
)
{
moveCamera
(
CameraUpdateFactory
.
newLatLngBounds
(
bounds
,
padding
))
val
latLng
=
LatLng
(
pair
.
first
,
pair
.
second
)
moveCamera
(
CameraUpdateFactory
.
newLatLngZoom
(
latLng
,
zoom
))
}
}
}
}
\ No newline at end of file
app/src/main/java/com/base/locationsharewhite/ui/locationmap/LocationMapActivity.kt
View file @
f3f02b96
package
com.base.locationsharewhite.ui.locationmap
package
com.base.locationsharewhite.ui.locationmap
import
android.graphics.Color
import
android.graphics.Color
import
android.view.LayoutInflater
import
androidx.activity.addCallback
import
androidx.activity.addCallback
import
com.base.locationsharewhite.R
import
com.base.locationsharewhite.databinding.ActivityLocationMapBinding
import
com.base.locationsharewhite.databinding.ActivityLocationMapBinding
import
com.base.locationsharewhite.helper.BaseActivity
import
com.base.locationsharewhite.helper.BaseActivity
import
com.base.locationsharewhite.map.MapUtils.addLocationMarker
import
com.base.locationsharewhite.map.MapUtils.cameraMovePointsBounds
import
com.base.locationsharewhite.map.MapUtils.getLastKnowLatLng
import
com.base.locationsharewhite.utils.BarUtils
import
com.base.locationsharewhite.utils.BarUtils
import
com.base.locationsharewhite.utils.LogEx
import
com.google.android.gms.maps.GoogleMap
import
com.google.android.gms.maps.OnMapReadyCallback
import
com.google.android.gms.maps.SupportMapFragment
import
com.google.android.gms.maps.model.LatLng
class
LocationMapActivity
:
BaseActivity
<
ActivityLocationMapBinding
>()
{
class
LocationMapActivity
:
BaseActivity
<
ActivityLocationMapBinding
>(),
OnMapReadyCallback
{
private
val
TAG
=
"LocationMapActivity"
private
var
map
:
GoogleMap
?
=
null
override
val
binding
:
ActivityLocationMapBinding
by
lazy
{
override
val
binding
:
ActivityLocationMapBinding
by
lazy
{
ActivityLocationMapBinding
.
inflate
(
layoutInflater
)
ActivityLocationMapBinding
.
inflate
(
layoutInflater
)
...
@@ -18,6 +31,10 @@ class LocationMapActivity : BaseActivity<ActivityLocationMapBinding>() {
...
@@ -18,6 +31,10 @@ class LocationMapActivity : BaseActivity<ActivityLocationMapBinding>() {
BarUtils
.
setStatusBarColor
(
this
,
Color
.
TRANSPARENT
)
BarUtils
.
setStatusBarColor
(
this
,
Color
.
TRANSPARENT
)
// binding.root.updatePadding(top = BarUtils.getStatusBarHeight())
// binding.root.updatePadding(top = BarUtils.getStatusBarHeight())
val
mapFragment
=
supportFragmentManager
.
findFragmentById
(
R
.
id
.
map
)
as
SupportMapFragment
?
mapFragment
?.
getMapAsync
(
this
)
}
}
override
fun
initListener
()
{
override
fun
initListener
()
{
...
@@ -30,4 +47,31 @@ class LocationMapActivity : BaseActivity<ActivityLocationMapBinding>() {
...
@@ -30,4 +47,31 @@ class LocationMapActivity : BaseActivity<ActivityLocationMapBinding>() {
}
}
}
}
override
fun
onMapReady
(
googleMap
:
GoogleMap
)
{
map
=
googleMap
val
sydney
=
LatLng
(-
33.87365
,
151.20689
)
showMeAndFriendLocation
(
sydney
)
val
chunxilu
=
LatLng
(
30.655782251943407
,
104.07701072527895
)
// showMeAndFriendLocation(chunxilu)
}
private
fun
showMeAndFriendLocation
(
friendLatLng
:
LatLng
)
{
val
myPair
:
LatLng
=
getLastKnowLatLng
()
LogEx
.
logDebug
(
TAG
,
"getLastKnowLocation ${myPair.latitude} ${myPair.longitude}"
)
val
myAvatar
=
LayoutInflater
.
from
(
this
).
inflate
(
R
.
layout
.
avatar_me
,
null
)
val
friendAvatar
=
LayoutInflater
.
from
(
this
).
inflate
(
R
.
layout
.
avatar_friend
,
null
)
map
?.
addLocationMarker
(
myAvatar
,
myPair
,
"my"
)
map
?.
addLocationMarker
(
friendAvatar
,
friendLatLng
,
"friend"
)
val
padding
=
resources
.
getDimensionPixelOffset
(
R
.
dimen
.
dp_150
)
map
?.
cameraMovePointsBounds
(
myPair
,
friendLatLng
,
padding
)
}
}
}
\ No newline at end of file
app/src/main/java/com/base/locationsharewhite/ui/main/MainActivity.kt
View file @
f3f02b96
...
@@ -11,21 +11,17 @@ import com.base.locationsharewhite.databinding.ActivityMainBinding
...
@@ -11,21 +11,17 @@ import com.base.locationsharewhite.databinding.ActivityMainBinding
import
com.base.locationsharewhite.helper.BaseActivity
import
com.base.locationsharewhite.helper.BaseActivity
import
com.base.locationsharewhite.helper.MyApplication
import
com.base.locationsharewhite.helper.MyApplication
import
com.base.locationsharewhite.map.MapUtils.addLocationMarker
import
com.base.locationsharewhite.map.MapUtils.addLocationMarker
import
com.base.locationsharewhite.map.MapUtils.
moveCameraZoom
import
com.base.locationsharewhite.map.MapUtils.
getLastKnowLatLng
import
com.base.locationsharewhite.ui.howuse.HowUseActivity
import
com.base.locationsharewhite.ui.howuse.HowUseActivity
import
com.base.locationsharewhite.ui.locationmap.LocationMapActivity
import
com.base.locationsharewhite.ui.locationmap.LocationMapActivity
import
com.base.locationsharewhite.ui.set.SettingActivity
import
com.base.locationsharewhite.ui.set.SettingActivity
import
com.base.locationsharewhite.utils.BarUtils
import
com.base.locationsharewhite.utils.BarUtils
import
com.base.locationsharewhite.utils.LocationUtils.getLastKnowLocation
import
com.base.locationsharewhite.utils.LogEx
import
com.base.locationsharewhite.utils.LogEx
import
com.base.locationsharewhite.utils.PermissionUtils.checkLocationPermission
import
com.base.locationsharewhite.utils.PermissionUtils.checkLocationPermission
import
com.google.android.gms.maps.CameraUpdateFactory
import
com.google.android.gms.maps.CameraUpdateFactory
import
com.google.android.gms.maps.GoogleMap
import
com.google.android.gms.maps.GoogleMap
import
com.google.android.gms.maps.OnMapReadyCallback
import
com.google.android.gms.maps.OnMapReadyCallback
import
com.google.android.gms.maps.SupportMapFragment
import
com.google.android.gms.maps.SupportMapFragment
import
com.google.android.gms.maps.model.BitmapDescriptorFactory
import
com.google.android.gms.maps.model.LatLng
import
com.google.android.gms.maps.model.MarkerOptions
class
MainActivity
:
BaseActivity
<
ActivityMainBinding
>(),
OnMapReadyCallback
{
class
MainActivity
:
BaseActivity
<
ActivityMainBinding
>(),
OnMapReadyCallback
{
...
@@ -103,12 +99,12 @@ class MainActivity : BaseActivity<ActivityMainBinding>(), OnMapReadyCallback {
...
@@ -103,12 +99,12 @@ class MainActivity : BaseActivity<ActivityMainBinding>(), OnMapReadyCallback {
override
fun
onMapReady
(
googleMap
:
GoogleMap
)
{
override
fun
onMapReady
(
googleMap
:
GoogleMap
)
{
map
=
googleMap
map
=
googleMap
val
pair
=
getLastKnowLocation
()
val
latLng
=
getLastKnowLatLng
()
LogEx
.
logDebug
(
TAG
,
"getLastKnowLocation ${
pair.first} ${pair.second
}"
)
LogEx
.
logDebug
(
TAG
,
"getLastKnowLocation ${
latLng.latitude} ${latLng.longitude
}"
)
val
myAvatar
=
LayoutInflater
.
from
(
this
).
inflate
(
R
.
layout
.
avatar_me
,
null
)
val
myAvatar
=
LayoutInflater
.
from
(
this
).
inflate
(
R
.
layout
.
avatar_me
,
null
)
map
?.
moveCamera
Zoom
(
pair
)
map
?.
moveCamera
(
CameraUpdateFactory
.
newLatLngZoom
(
latLng
,
15f
)
)
map
?.
addLocationMarker
(
myAvatar
,
pair
,
"my"
)
map
?.
addLocationMarker
(
myAvatar
,
latLng
,
"my"
)
}
}
}
}
\ No newline at end of file
app/src/main/java/com/base/locationsharewhite/utils/LocationUtils.kt
deleted
100644 → 0
View file @
9d6c8b7e
package
com.base.locationsharewhite.utils
import
android.annotation.SuppressLint
import
android.content.Context
import
android.location.Criteria
import
android.location.Location
import
android.location.LocationManager
import
androidx.core.content.ContextCompat
object
LocationUtils
{
@SuppressLint
(
"MissingPermission"
)
fun
Context
.
getLastKnowLocation
():
Pair
<
Double
,
Double
>
{
val
locationManager
=
getSystemService
(
Context
.
LOCATION_SERVICE
)
as
LocationManager
?
if
(
locationManager
!=
null
)
{
val
provider
:
String
?
=
locationManager
.
getBestProvider
(
Criteria
(),
true
)
if
(
provider
!=
null
)
{
val
lastKnownLocation
:
Location
?
=
locationManager
.
getLastKnownLocation
(
provider
)
val
latitude
:
Double
=
lastKnownLocation
?.
latitude
?:
0.0
//维度
val
longitude
:
Double
=
lastKnownLocation
?.
longitude
?:
0.0
//经度
return
Pair
(
latitude
,
longitude
)
}
}
return
Pair
(
0.0
,
0.0
)
}
}
\ No newline at end of file
app/src/main/res/layout/avatar_friend.xml
0 → 100644
View file @
f3f02b96
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
xmlns:android=
"http://schemas.android.com/apk/res/android"
xmlns:tools=
"http://schemas.android.com/tools"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
>
<ImageView
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"center_horizontal"
android:src=
"@mipmap/dingweibg"
tools:ignore=
"ContentDescription"
/>
<ImageView
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"center_horizontal"
android:layout_marginTop=
"8dp"
android:src=
"@mipmap/friend"
tools:ignore=
"ContentDescription"
/>
</FrameLayout>
\ No newline at end of file
app/src/main/res/mipmap-xxhdpi/friend.png
0 → 100644
View file @
f3f02b96
6.45 KB
app/src/main/res/values/dimens.xml
View file @
f3f02b96
...
@@ -5,4 +5,8 @@
...
@@ -5,4 +5,8 @@
<dimen
name=
"dp_5"
>
5dp
</dimen>
<dimen
name=
"dp_5"
>
5dp
</dimen>
<dimen
name=
"dp_10"
>
10dp
</dimen>
<dimen
name=
"dp_10"
>
10dp
</dimen>
<dimen
name=
"dp_320"
>
320dp
</dimen>
<dimen
name=
"dp_320"
>
320dp
</dimen>
<dimen
name=
"dp_30"
>
30dp
</dimen>
<dimen
name=
"dp_100"
>
100dp
</dimen>
<dimen
name=
"dp_200"
>
200dp
</dimen>
<dimen
name=
"dp_150"
>
150dp
</dimen>
</resources>
</resources>
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment