kakao map 1

엄혜영·2023년 5월 6일
0

kakao developers - 지도 SDK 사용
참고 : https://pub.dev/packages/kakaomap_webview

기본 설정


AndroidManifest.xml

	<!-- Internet permission is required -->
	<uses-permission android:name="android.permission.INTERNET">
    </uses-permission>
    
	<!-- Add android:usesCleartextTraffic="true" in application tag -->
    <application
  		android:label="your app name"
  		android:icon="@mipmap/ic_launcher"
  		android:usesCleartextTraffic="true">

build.gradle

android {
	compileSdkVersion 33    
    	defaultConfig{
    		minSdkVersion 21'
    	}
}

main.dart

import 'package:flutter/material.dart';
import 'package:kakaomap_webview/kakaomap_webview.dart';
const String kakaoMapKey = 'javascriptKey';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  
  Widget build(BuildContext context) {
    return MaterialApp(
        debugShowCheckedModeBanner: false,
        title: 'MaterialApp',
        home: Scaffold(
          body: Column(
            children: [
              KakaoMapView(
                  width: 400,
                  height: 400,
                  kakaoMapKey: kakaoMapKey,
                  lat: 33.450701,
                  lng: 126.570667,
                  showMapTypeControl: true,
                  showZoomControl: true,
                  markerImageURL:
                  'https://t1.daumcdn.net/localimg/localimages/07/mapapidoc/marker_red.png',
                  onTapMarker: (message) async {
                    ScaffoldMessenger.of(context).showSnackBar(
                        SnackBar(content: Text('Marker is clicked')));

                    //await _openKakaoMapScreen(context);
                  }),
            ],
          ),
        ));
  }
}




주의!
MaterialApp 위젯을 제외하고 작성시 에러 발생

import 'package:flutter/material.dart';
import 'package:example/kakaomap_screen.dart';

const String kakaoMapKey = 'javascriptKey';

class KakaoMapTest extends StatelessWidget {
  
  Widget build(BuildContext context) {
    Size size = MediaQuery.of(context).size;
    return Scaffold(
      appBar: AppBar(title: Text('Kakao map webview test')),
      body: Column(
        mainAxisAlignment: MainAxisAlignment.spaceEvenly,
        children: [
          KakaoMapView(
              width: size.width,
              height: 400,
              kakaoMapKey: kakaoMapKey,
              lat: 33.450701,
              lng: 126.570667,
              showMapTypeControl: true,
              showZoomControl: true,
              markerImageURL:
                  'https://t1.daumcdn.net/localimg/localimages/07/mapapidoc/marker_red.png',
              onTapMarker: (message) async {
                ScaffoldMessenger.of(context)
                    .showSnackBar(SnackBar(content: Text('Marker is clicked')));

                //await _openKakaoMapScreen(context);
              }),
  
        ],
      ),
    );
  }
}

profile
누워있는게 좋은 완벽주의자

0개의 댓글

관련 채용 정보