提交 453b3fe2 编写于 作者: Q qiang

feat(h5): openLocation use google map

上级 1b0dffd7
......@@ -7652,10 +7652,12 @@ var index$d = /* @__PURE__ */ defineBuiltInComponent({
};
}
});
const ICON_PATH_ORIGIN = "";
var MapType;
(function(MapType2) {
MapType2["QQ"] = "qq";
MapType2["GOOGLE"] = "google";
MapType2["UNKNOWN"] = "";
})(MapType || (MapType = {}));
const props$6 = {
id: {
......@@ -8196,7 +8198,6 @@ var MapControl = /* @__PURE__ */ defineSystemComponent({
}
});
const CONTEXT_ID = "MAP_LOCATION";
const ICON_PATH = "";
var MapLocation = /* @__PURE__ */ defineSystemComponent({
name: "MapLocation",
setup() {
......@@ -8213,7 +8214,7 @@ var MapLocation = /* @__PURE__ */ defineSystemComponent({
},
"width": "44",
"height": "44",
"iconPath": ICON_PATH
"iconPath": ICON_PATH_ORIGIN
}, state), null, 16, ["iconPath"]) : null;
};
}
......@@ -8225,11 +8226,11 @@ const props$2 = {
},
latitude: {
type: [String, Number],
default: 39.90374
default: 0
},
longitude: {
type: [String, Number],
default: 116.397827
default: 0
},
scale: {
type: [String, Number],
......
此差异已折叠。
export interface Point {
latitude: number
longitude: number
}
export const ICON_PATH_LOCTAION =
'M13.3334375 16 q0.033125 1.1334375 0.783125 1.8834375 q0.75 0.75 1.8834375 0.75 q1.1334375 0 1.8834375 -0.75 q0.75 -0.75 0.75 -1.8834375 q0 -1.1334375 -0.75 -1.8834375 q-0.75 -0.75 -1.8834375 -0.75 q-1.1334375 0 -1.8834375 0.75 q-0.75 0.75 -0.783125 1.8834375 ZM30.9334375 14.9334375 l-1.1334375 0 q-0.5 -5.2 -4.0165625 -8.716875 q-3.516875 -3.5165625 -8.716875 -4.0165625 l0 -1.1334375 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 1.1334375 q-5.2 0.5 -8.716875 4.0165625 q-3.5165625 3.516875 -4.0165625 8.716875 l-1.1334375 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l1.1334375 0 q0.5 5.2 4.0165625 8.716875 q3.516875 3.5165625 8.716875 4.0165625 l0 1.1334375 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -1.1334375 q5.2 -0.5 8.716875 -4.0165625 q3.5165625 -3.516875 4.0165625 -8.716875 l1.1334375 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 ZM17.0665625 27.6665625 l0 -2.0665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 2.0665625 q-4.3 -0.4665625 -7.216875 -3.383125 q-2.916875 -2.916875 -3.3834375 -7.216875 l2.0665625 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 l-2.0665625 0 q0.4665625 -4.3 3.3834375 -7.216875 q2.9165625 -2.916875 7.216875 -3.3834375 l0 2.0665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -2.0665625 q4.3 0.4665625 7.216875 3.3834375 q2.9165625 2.9165625 3.383125 7.216875 l-2.0665625 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l2.0665625 0 q-0.4665625 4.3 -3.383125 7.216875 q-2.916875 2.9165625 -7.216875 3.383125 Z'
export const ICON_PATH_ORIGIN =
''
export const ICON_PATH_TARGET =
''
export enum MapType {
QQ = 'qq',
GOOGLE = 'google',
UNKNOWN = '',
}
export function getMapInfo() {
let type: MapType = MapType.UNKNOWN
let key: string = ''
if (__uniConfig.qqMapKey) {
type = MapType.QQ
key = __uniConfig.qqMapKey
} else if (__uniConfig.googleMapKey) {
type = MapType.GOOGLE
key = __uniConfig.googleMapKey
}
return {
type,
key,
}
}
......@@ -12,11 +12,14 @@ import {
ScrollView,
} from '@dcloudio/uni-components'
import { usePreventScroll } from '../../../../helpers/usePreventScroll'
import {
Point,
ICON_PATH_LOCTAION,
ICON_PATH_TARGET,
} from '../../../../helpers/location'
import { Map } from '../../../../view/components'
import { getJSONP } from '../../../../helpers/getJSONP'
import { getLocation } from '../../location/getLocation'
const ICON_PATH_LOCTAION =
'M13.3334375 16 q0.033125 1.1334375 0.783125 1.8834375 q0.75 0.75 1.8834375 0.75 q1.1334375 0 1.8834375 -0.75 q0.75 -0.75 0.75 -1.8834375 q0 -1.1334375 -0.75 -1.8834375 q-0.75 -0.75 -1.8834375 -0.75 q-1.1334375 0 -1.8834375 0.75 q-0.75 0.75 -0.783125 1.8834375 ZM30.9334375 14.9334375 l-1.1334375 0 q-0.5 -5.2 -4.0165625 -8.716875 q-3.516875 -3.5165625 -8.716875 -4.0165625 l0 -1.1334375 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 1.1334375 q-5.2 0.5 -8.716875 4.0165625 q-3.5165625 3.516875 -4.0165625 8.716875 l-1.1334375 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l1.1334375 0 q0.5 5.2 4.0165625 8.716875 q3.516875 3.5165625 8.716875 4.0165625 l0 1.1334375 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -1.1334375 q5.2 -0.5 8.716875 -4.0165625 q3.5165625 -3.516875 4.0165625 -8.716875 l1.1334375 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 ZM17.0665625 27.6665625 l0 -2.0665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 l0 2.0665625 q-4.3 -0.4665625 -7.216875 -3.383125 q-2.916875 -2.916875 -3.3834375 -7.216875 l2.0665625 0 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 q0 -0.4665625 -0.3 -0.7665625 q-0.3 -0.3 -0.7665625 -0.3 l-2.0665625 0 q0.4665625 -4.3 3.3834375 -7.216875 q2.9165625 -2.916875 7.216875 -3.3834375 l0 2.0665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 q0.4665625 0 0.7665625 -0.3 q0.3 -0.3 0.3 -0.7665625 l0 -2.0665625 q4.3 0.4665625 7.216875 3.3834375 q2.9165625 2.9165625 3.383125 7.216875 l-2.0665625 0 q-0.4665625 0 -0.7665625 0.3 q-0.3 0.3 -0.3 0.7665625 q0 0.4665625 0.3 0.7665625 q0.3 0.3 0.7665625 0.3 l2.0665625 0 q-0.4665625 4.3 -3.383125 7.216875 q-2.916875 2.9165625 -7.216875 3.383125 Z'
const props = {
latitude: {
......@@ -40,10 +43,7 @@ function distance(distance: number): string {
return ''
}
}
interface Point {
latitude: number
longitude: number
}
interface State {
latitude: number
longitude: number
......@@ -205,10 +205,10 @@ export default /*#__PURE__*/ defineSystemComponent({
type: 'gcj02',
success: move,
fail: () => {
move({
latitude: 39.90960456049752,
longitude: 116.3972282409668,
})
// move({
// latitude: 0,
// longitude: 0,
// })
},
})
}
......@@ -267,7 +267,10 @@ export default /*#__PURE__*/ defineSystemComponent({
// @ts-ignore
onRegionchange={onRegionChange}
>
<div class="map-location" />
<div
class="map-location"
style={`background-image: url("${ICON_PATH_TARGET}")`}
/>
<div class="map-move" onClick={moveToLocation}>
{createSvgIconVNode(ICON_PATH_LOCTAION, '#000000', 24)}
</div>
......
......@@ -6,6 +6,7 @@ import {
GetLocationProtocol,
GetLocationOptions,
} from '@dcloudio/uni-api'
import { MapType, getMapInfo } from '../../../helpers/location'
import { getJSONP } from '../../../helpers/getJSONP'
import { request } from '../network/request'
......@@ -14,19 +15,7 @@ type GeoRes = (coords: GeolocationCoordinates, skip?: boolean) => void
export const getLocation = <API_TYPE_GET_LOCATION>defineAsyncApi(
API_GET_LOCATION,
({ type, altitude }, { resolve, reject }) => {
enum MapType {
QQ = 'qq',
GOOGLE = 'google',
}
let mapType: string
let mapKey: string
if (__uniConfig.qqMapKey) {
mapType = MapType.QQ
mapKey = __uniConfig.qqMapKey
} else if (__uniConfig.googleMapKey) {
mapType = MapType.GOOGLE
mapKey = __uniConfig.googleMapKey
}
const mapInfo = getMapInfo()
new Promise((resolve: GeoRes, reject) => {
if (navigator.geolocation) {
......@@ -44,9 +33,9 @@ export const getLocation = <API_TYPE_GET_LOCATION>defineAsyncApi(
})
.catch((error) => {
return new Promise((resolve: GeoRes, reject) => {
if (mapType === MapType.QQ) {
if (mapInfo.type === MapType.QQ) {
getJSONP(
`https://apis.map.qq.com/ws/location/v1/ip?output=jsonp&key=${mapKey}`,
`https://apis.map.qq.com/ws/location/v1/ip?output=jsonp&key=${mapInfo.key}`,
{
callback: 'callback',
},
......@@ -66,10 +55,10 @@ export const getLocation = <API_TYPE_GET_LOCATION>defineAsyncApi(
},
() => reject(new Error('network error'))
)
} else if (mapType === MapType.GOOGLE) {
} else if (mapInfo.type === MapType.GOOGLE) {
request({
method: 'POST',
url: `https://www.googleapis.com/geolocation/v1/geolocate?key=${mapKey}`,
url: `https://www.googleapis.com/geolocation/v1/geolocate?key=${mapInfo.key}`,
success(res) {
const data: AnyObject = res.data as AnyObject
if ('location' in data) {
......@@ -98,14 +87,14 @@ export const getLocation = <API_TYPE_GET_LOCATION>defineAsyncApi(
.then((coords: GeolocationCoordinates, skip?: boolean) => {
if (
(type && type.toUpperCase() === 'WGS84') ||
mapType !== MapType.QQ ||
mapInfo.type !== MapType.QQ ||
skip
) {
return coords
}
return new Promise((resolve: GeoRes) => {
getJSONP(
`https://apis.map.qq.com/jsapi?qt=translate&type=1&points=${coords.longitude},${coords.latitude}&key=${mapKey}&output=jsonp&pf=jsapi&ref=jsapi`,
`https://apis.map.qq.com/jsapi?qt=translate&type=1&points=${coords.longitude},${coords.latitude}&key=${mapInfo.key}&output=jsonp&pf=jsapi&ref=jsapi`,
{
callback: 'cb',
},
......
import { Ref, ref, ExtractPropTypes, reactive, computed } from 'vue'
import { ExtractPropTypes, reactive, watch } from 'vue'
import { createSvgIconVNode, ICON_PATH_BACK } from '@dcloudio/uni-core'
import { defineSystemComponent } from '@dcloudio/uni-components'
import { usePreventScroll } from '../../../../helpers/usePreventScroll'
import {
Point,
ICON_PATH_LOCTAION,
ICON_PATH_ORIGIN,
ICON_PATH_TARGET,
MapType,
getMapInfo,
} from '../../../../helpers/location'
import { Map } from '../../../../view/components'
import { getLocation } from '../../location/getLocation'
const ICON_PATH_NAV =
'M28 17c-6.49396875 0-12.13721875 2.57040625-15 6.34840625V5.4105l6.29859375 6.29859375c0.387875 0.387875 1.02259375 0.387875 1.4105 0 0.387875-0.387875 0.387875-1.02259375 0-1.4105L12.77853125 2.36803125a0.9978125 0.9978125 0 0 0-0.0694375-0.077125c-0.1944375-0.1944375-0.45090625-0.291375-0.70721875-0.290875l-0.00184375-0.0000625-0.00184375 0.0000625c-0.2563125-0.0005-0.51278125 0.09640625-0.70721875 0.290875a0.9978125 0.9978125 0 0 0-0.0694375 0.077125l-7.930625 7.9305625c-0.387875 0.387875-0.387875 1.02259375 0 1.4105 0.387875 0.387875 1.02259375 0.387875 1.4105 0L11 5.4105V29c0 0.55 0.45 1 1 1s1-0.45 1-1c0-5.52284375 6.71571875-10 15-10 0.55228125 0 1-0.44771875 1-1 0-0.55228125-0.44771875-1-1-1z'
const props = {
latitude: {
......@@ -26,75 +39,136 @@ const props = {
export type Props = ExtractPropTypes<typeof props>
interface State {
center: Point
marker: Point
location: Point
}
function useState(props: Props) {
const state: State = reactive({
center: {
latitude: 0,
longitude: 0,
},
marker: {
id: 1,
latitude: 0,
longitude: 0,
iconPath: ICON_PATH_TARGET,
width: 32,
height: 52,
},
location: {
id: 2,
latitude: 0,
longitude: 0,
iconPath: ICON_PATH_ORIGIN,
width: 44,
height: 44,
},
})
function updatePosition() {
if (props.latitude && props.longitude) {
state.center.latitude = props.latitude
state.center.longitude = props.longitude
state.marker.latitude = props.latitude
state.marker.longitude = props.longitude
}
}
watch([() => props.latitude, () => props.longitude], updatePosition)
updatePosition()
return state
}
export default /*#__PURE__*/ defineSystemComponent({
name: 'LocationView',
props,
emits: ['close'],
setup(props, { emit }) {
const state = useState(props)
usePreventScroll()
const mapRef: Ref<HTMLIFrameElement | null> = ref(null)
const key = __uniConfig.qqMapKey
const referer = 'uniapp'
const poimarkerSrc = 'https://apis.map.qq.com/tools/poimarker'
const src = computed(() => {
const { latitude, longitude, name, address } = props
return latitude && longitude
? `${poimarkerSrc}?type=0&marker=coord:${latitude},${longitude};title:${name};addr:${address};&key=${key}&referer=${referer}`
: ''
})
const state = reactive({
src,
isPoimarkerSrc: true,
})
function check() {
const map = mapRef.value as HTMLIFrameElement
if (map.src.indexOf(poimarkerSrc) === 0) {
state.isPoimarkerSrc = true
} else {
state.isPoimarkerSrc = false
function onRegionChange(event: { detail: { centerLocation: Point } }) {
const centerLocation = event.detail.centerLocation
if (centerLocation) {
state.center.latitude = centerLocation.latitude
state.center.longitude = centerLocation.longitude
}
}
function nav() {
const map = mapRef.value as HTMLIFrameElement
const url = `https://map.qq.com/nav/drive#routes/page?transport=2&epointy=${
props.latitude
}&epointx=${props.longitude}&eword=${encodeURIComponent(
props.name || '目的地'
)}&referer=${referer}`
map.src = url
const mapInfo = getMapInfo()
let url = ''
if (mapInfo.type === MapType.GOOGLE) {
const origin: string = state.location.latitude
? `&origin=${state.location.latitude}%2C${state.location.longitude}`
: ''
url = `https://www.google.com/maps/dir/?api=1${origin}&destination=${props.latitude}%2C${props.longitude}`
} else if (mapInfo.type === MapType.QQ) {
const fromcoord: string = state.location.latitude
? `&fromcoord=${state.location.latitude}%2C${state.location.longitude}`
: ''
url = `https://apis.map.qq.com/uri/v1/routeplan?type=drive${fromcoord}&tocoord=${
props.latitude
}%2C${props.longitude}&from=${encodeURIComponent(
'我的位置'
)}&to=${encodeURIComponent(props.name || '目的地')}&ref=${mapInfo.key}`
}
window.open(url)
}
function back() {
const map = mapRef.value as HTMLIFrameElement
if (map.src.indexOf(poimarkerSrc) !== 0) {
map.src = state.src
} else {
emit('close')
}
check()
emit('close')
}
function move({ latitude, longitude }: Point) {
state.location.latitude = latitude
state.location.longitude = longitude
setCenter({ latitude, longitude })
}
function setCenter({ latitude, longitude }: Point) {
state.center.latitude = latitude
state.center.longitude = longitude
}
function moveToLocation() {
getLocation({
type: 'gcj02',
success: move,
fail: () => {
// move({
// latitude: 0,
// longitude: 0,
// })
},
})
}
return () => {
return (
<div class="uni-system-open-location">
<div
class={{
'map-content': true,
'fix-position': state.isPoimarkerSrc,
}}
<Map
latitude={state.center.latitude}
longitude={state.center.longitude}
class="map"
markers={[state.marker, state.location]}
onRegionchange={onRegionChange}
>
<iframe
ref={mapRef}
src={state.src}
allow="geolocation"
sandbox="allow-scripts allow-same-origin allow-forms allow-top-navigation allow-modals allow-popups"
frameborder="0"
onLoad={check}
/>
{/* <!-- 去这里 --> */}
{state.isPoimarkerSrc && <div class="actTonav" onClick={nav} />}
<div class="map-move" onClick={moveToLocation}>
{createSvgIconVNode(ICON_PATH_LOCTAION, '#000000', 24)}
</div>
</Map>
<div class="info">
<div class="name" onClick={() => setCenter(state.marker)}>
{props.name}
</div>
<div class="address" onClick={() => setCenter(state.marker)}>
{props.address}
</div>
<div class="nav" onClick={nav}>
{createSvgIconVNode(ICON_PATH_NAV, '#ffffff', 26)}
</div>
</div>
<div class="nav-btn-back" onClick={back}>
{createSvgIconVNode(ICON_PATH_BACK, '#ffffff', 26)}
......
......@@ -7,6 +7,7 @@ import {
getLocation,
} from '../../../service/api'
//#endif
import { ICON_PATH_ORIGIN } from '../../../helpers/location'
import { Maps, Map } from './maps'
import MapMarker from './MapMarker'
......@@ -34,9 +35,6 @@ export interface Context {
type AddMapChidlContext = (context: Context) => void
type RemoveMapChidlContext = (context: Context) => void
const ICON_PATH =
''
export default /*#__PURE__*/ defineSystemComponent({
name: 'MapLocation',
setup() {
......@@ -91,7 +89,7 @@ export default /*#__PURE__*/ defineSystemComponent({
anchor={{ x: 0.5, y: 0.5 }}
width="44"
height="44"
iconPath={ICON_PATH}
iconPath={ICON_PATH_ORIGIN}
{...state}
/>
) : null
......
......@@ -16,6 +16,7 @@ import {
useCustomEvent,
} from '@dcloudio/uni-components'
import { callOptions } from '@dcloudio/uni-shared'
import { Point } from '../../../helpers/location'
import { Maps, Map, loadMaps, LatLng } from './maps'
import MapMarker, {
Props as MapMarkerProps,
......@@ -29,11 +30,6 @@ import MapLocation, {
CONTEXT_ID as MAP_LOCATION_CONTEXT_ID,
} from './MapLocation'
interface Point {
latitude: number
longitude: number
}
const props = {
id: {
type: String,
......@@ -41,11 +37,11 @@ const props = {
},
latitude: {
type: [String, Number],
default: 39.90374,
default: 0,
},
longitude: {
type: [String, Number],
default: 116.397827,
default: 0,
},
scale: {
type: [String, Number],
......
import { MapType, getMapInfo } from '../../../../helpers/location'
export * from './types'
import { QQMaps } from './qq/types'
import { GoogleMaps } from './google/types'
......@@ -17,11 +18,6 @@ interface QQMapsWithCallout extends QQMaps, MapsWithCallout {}
export type Maps = GoogleMapsWithCallout | QQMapsWithCallout
export enum MapType {
QQ = 'qq',
GOOGLE = 'google',
}
let maps: Maps
const callbacksMap: Partial<Record<MapType, Array<(maps: Maps) => void>>> = {}
const GOOGLE_MAP_CALLBACKNAME = '__map_callback__'
......@@ -30,23 +26,20 @@ interface WindowExt extends Window {
}
export function loadMaps(callback: (maps: Maps) => void) {
let type: MapType
let key: string
if (__uniConfig.qqMapKey) {
type = MapType.QQ
key = __uniConfig.qqMapKey
} else if (__uniConfig.googleMapKey) {
type = MapType.GOOGLE
key = __uniConfig.googleMapKey
} else {
const mapInfo = getMapInfo()
if (!mapInfo.key) {
console.error('Map key not configured.')
return
}
const callbacks = (callbacksMap[type] = callbacksMap[type] || [])
const callbacks = (callbacksMap[mapInfo.type] =
callbacksMap[mapInfo.type] || [])
if (maps) {
callback(maps)
} else if ((window as WindowExt)[type] && (window as WindowExt)[type].maps) {
maps = (window as WindowExt)[type].maps
} else if (
(window as WindowExt)[mapInfo.type] &&
(window as WindowExt)[mapInfo.type].maps
) {
maps = (window as WindowExt)[mapInfo.type].maps
maps.Callout = maps.Callout || createCallout(maps)
callback(maps)
} else if (callbacks.length) {
......@@ -54,20 +47,20 @@ export function loadMaps(callback: (maps: Maps) => void) {
} else {
callbacks.push(callback)
const globalExt = window as WindowExt
const callbackName = GOOGLE_MAP_CALLBACKNAME + type
const callbackName = GOOGLE_MAP_CALLBACKNAME + mapInfo.type
globalExt[callbackName] = function () {
delete globalExt[callbackName]
maps = (window as WindowExt)[type].maps
maps = (window as WindowExt)[mapInfo.type].maps
maps.Callout = createCallout(maps)
callbacks.forEach((callback) => callback(maps))
callbacks.length = 0
}
const script = document.createElement('script')
const src =
type === MapType.GOOGLE
mapInfo.type === MapType.GOOGLE
? 'https://maps.googleapis.com/maps/api/js?'
: 'https://map.qq.com/api/js?v=2.exp&libraries=geometry&'
script.src = `${src}key=${key}&callback=${callbackName}`
script.src = `${src}key=${mapInfo.key}&callback=${callbackName}`
script.onerror = function () {
console.error('Map load failed.')
}
......
......@@ -25,7 +25,6 @@
height: 52px;
margin-left: -16px;
cursor: pointer;
background-image: url("");
background-size: 100%;
}
......
......@@ -9,6 +9,79 @@
z-index: 999;
}
.uni-system-open-location .map {
position: absolute;
top: 0;
left: 0;
width: 100%;
bottom: 80px;
height: auto;
}
.uni-system-open-location .info {
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 80px;
background-color: white;
padding: 15px;
box-sizing: border-box;
line-height: 1.5;
}
.uni-system-open-location .info>.name {
font-size: 17px;
color: #111111;
}
.uni-system-open-location .info>.address {
font-size: 14px;
color: #666666;
}
.uni-system-open-location .info>.nav {
position: absolute;
top: 50%;
right: 15px;
width: 50px;
height: 50px;
border-radius: 50%;
margin-top: -25px;
background-color: #007aff;
}
.uni-system-open-location .info>.nav>svg {
display: block;
width: 100%;
height: 100%;
padding: 10px;
box-sizing: border-box;
}
.uni-system-open-location .map-move {
position: absolute;
bottom: 50px;
right: 10px;
width: 40px;
height: 40px;
box-sizing: border-box;
line-height: 40px;
background-color: white;
border-radius: 50%;
pointer-events: auto;
cursor: pointer;
box-shadow: 0px 0 5px 1px rgba(0, 0, 0, 0.3);
}
.uni-system-open-location .map-move>svg {
display: block;
width: 100%;
height: 100%;
box-sizing: border-box;
padding: 8px;
}
.uni-system-open-location .nav-btn-back {
position: absolute;
box-sizing: border-box;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册