<!DOCTYPE html>

<html>

<head>

<meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>

<style type="text/css">

 html { height : 100% }

 body { height : 100%; margin: 3% 0% 0% 1.5%; padding: 0 }

 #map_canvas { height : 100% }

</style>

<script type = "text/javascript"

 src = "http://maps.googleapis.com/maps/api/js?sensor=false&key=AIzaSyBC54YWLZJavk-9IAJAMEMU-hocEeEAet0">

</script>

<script type = "text/javascript">


var map;

var infowindow = new google.maps.InfoWindow();

var marker =[];

var geocoder;

var geocodemarker = [];



var GreenIcon = new google.maps.MarkerImage(

   "http://labs.google.com/ridefinder/images/mm_20_green.png",

   new google.maps.Size(12, 20),

   new google.maps.Point(0, 0),

   new google.maps.Point(6, 20));

// 녹색 마커 아이콘을 정의하는 부분


function initialize(){


 var latlng = new google.maps.LatLng(37.5240220, 126.9265940);

 var myOptions = {

  zoom: 10,

  center:latlng,

  mapTypeId: google.maps.MapTypeId.ROADMAP   

 };

 

 map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);

 geocoder =  new google.maps.Geocoder();

 google.maps.event.addListener(map, 'click', codeCoordinate);

        /*아랫글에서 설명한 event를 이용 지도를 'click'하면 codeCoordinate함수를 실행합니다.

           codeCoordinate함수는 클릭한 지점의 좌표를 가지고 주소를 찾는 함수입니다. */

}


function Setmarker(latLng) {

     

  if (marker.length > 0)

        {

  marker[0].setMap(null); 

  }

// marker.length는 marker라는 배열의 원소의 개수입니다.

// 만약 이 개수가 0이 아니라면 marker를 map에 표시되지 않게 합니다.

// 이는 다른 지점을 클릭할 때 기존의 마커를 제거하기 위함입니다.


  marker = [];

  marker.length = 0;

// marker를 빈 배열로 만들고, marker 배열의 개수를 0개로 만들어 marker 배열을 초기화합니

// 다.


   marker.push(new google.maps.Marker({

   position: latLng,

   map: map

  } ));

// marker 배열에 새 marker object를 push 함수로 추가합니다.


}

/*클릭한 지점에 마커를 표시하는 함수입니다.

   그런데 이 함수를 잘 봐야 하는 것이 바로 marker를 생성하지 않고 marker라는 배열 안에 Marker 

   obejct  원소를 계속 추가하고 있습니다. 이는 매번 클릭할 때마다 새로운 마커를 생성하기 위함입니

   다. */


//입력 받은 주소를 지오코딩 요청하고 결과를 마커로 지도에 표시합니다.

function codeAddress(event) {


 if (geocodemarker.length > 0)

 {

  for (var i=0;i<geocodemarker.length ;i++ )

  {

   geocodemarker[i].setMap(null);

  }

  geocodemarker =[];

  geocodemarker.length = 0;

 }

        //이 부분도 위와 같이 주소를 입력할 때 표시되는 marker가 매번 새로 나타나게 하기 위함입니

        //다.


 var address = document.getElementById("addr1").value;

        //아래의 주소 입력창에서 받은 정보를 address 변수에 저장합니다.


        //지오코딩하는 부분입니다.

 geocoder.geocode( {'address': address}, function(results, status) {

  if (status == google.maps.GeocoderStatus.OK)  //Geocoding이 성공적이라면,

  {

   alert(results.length + "개의 결과를 찾았습니다.");

   //결과의 개수를 표시하는 창을 띄웁니다. alert 함수는 알림창 함수입니다.

   for(var i=0;i<results.length;i++)

   {

    map.setCenter(results[i].geometry.location);

    geocodemarker.push(new google.maps.Marker({

     center: results[i].geometry.location,

     position: results[i].geometry.location,

     icon: GreenIcon,

     map: map

    }));

   } 

                        //결과가 여러 개일 수 있기 때문에 모든 결과를 지도에 marker에 표시합니다.

  }

  else

  { alert("Geocode was not successful for the following reason: " + status); 

  }

 });

}



//클릭 이벤트 발생 시 그 좌표를 주소로 변환하는 함수입니다.

function codeCoordinate(event) {

        

 Setmarker(event.latLng);

        //이벤트 발생 시 그 좌표에 마커를 생성합니다.


        // 좌표를 받아 reverse geocoding(좌표를 주소로 바꾸기)를 실행합니다.

 geocoder.geocode({'latLng' : event.latLng}, function(results, status) {

  if (status == google.maps.GeocoderStatus.OK)  {

   if (results[1])

   {

    infowindow.setContent(results[1].formatted_address);

    infowindow.open(map,marker[0]);

                                //infowindow로 주소를 표시합니다.

   }

  }

 });

}

//

 

 

</script>

</head>

<body onload="initialize()">

 

 <div id="map_canvas" style="width:80%; height:60%"></div>

 <p> 주소 : <input type="text" size="100" id="addr1" name="address"/>  <input name="submit" type="submit" value="Search" onclick='codeAddress(); return false;' /> </p>

//입력받는 부분을 통해 주소를 입력받고, 버튼을 누르면 codeAddress() 함수를 실행하는 부분입니다.

// <input type="text"는 텍스트 입력을 <input type="submut"은 버튼 입력을 의미합니다.

//<p>와 </p> 사이에 있는 부분이 한 문단을 구성합니다.

 <br>


 

</body>

</html>




<div class="map_cnt" id="map_open">

<div class="map_box">

<div class="map_tltbox">

<div class="map_tltcont">

<span id="map_tltcont_name">대연점</span>

<a href="#close" class="map_close">X</a>

</div>

</div>

<div class="map_cont">

<div id="map-canvas" style="width: 100%;height:400px;"></div>

<!-- <img src="/share/img/map.jpg" alt="지도" width="100%"> -->

</div>

</div>

</div>


<script type="text/javascript">

</script>


<!-- GoogoleMap Asynchronously Loading the API ********************************************* -->

<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false&key=AIzaSyBC54YWLZJavk-9IAJAMEMU-hocEeEAet0"></script>

<script type="text/javascript">

var map_x = "";

var map_y = "";


var map_wr_1 = "";

var map_wr_subject = "";


$(function() {

$(".td_branch_name a.fsch_btn").click(function() {

var map_c = $(this).attr('id').split('__');

var map_xy = map_c[0].split(',');

map_x = map_xy[0];

map_y = map_xy[1]; 

map_wr_1 = map_c[1];

map_wr_subject = map_c[2];

initialize(map_x,map_y,map_wr_1,map_wr_subject);

$("#map_tltcont_name").html(map_wr_1);

});

});



 function initialize(map_x,map_y,map_wr_1,map_wr_subject) {


var mapLocation = new google.maps.LatLng(map_x, map_y);  // 지도에서 가운데로 위치할 위도와 경도

var markLocation = new google.maps.LatLng(map_x, map_y); // 마커가 위치할 위도와 경도

 

var mapOptions = {

 center: mapLocation, // 지도에서 가운데로 위치할 위도와 경도(변수)

 zoom: 18,            // 지도 zoom단계

 mapTypeId: google.maps.MapTypeId.ROADMAP

};

var map = new google.maps.Map(document.getElementById("map-canvas"), // id: map-canvas, body에 있는 div태그의 id와 같아야 함

mapOptions);

 

var size_x = 60; // 마커로 사용할 이미지의 가로 크기

var size_y = 60; // 마커로 사용할 이미지의 세로 크기

 

// 마커로 사용할 이미지 주소

var image = new google.maps.MarkerImage( 'http://www.larva.re.kr/home/img/boximage3.png',

new google.maps.Size(size_x, size_y),

'',

'',

new google.maps.Size(size_x, size_y));

 

var marker;

marker = new google.maps.Marker({

  position: markLocation, // 마커가 위치할 위도와 경도(변수)

  map: map,

  icon: image, // 마커로 사용할 이미지(변수)

              //info: '말풍선 안에 들어갈 내용',

  title: map_wr_1 // 마커에 마우스 포인트를 갖다댔을 때 뜨는 타이틀

});

 

var content = "이곳이 "+map_wr_subject+" 입니다 ^^"; // 말풍선 안에 들어갈 내용

 

// 마커를 클릭했을 때의 이벤트. 말풍선 뿅~

var infowindow = new google.maps.InfoWindow({ content: content});

 

google.maps.event.addListener(marker, "click", function() {

infowindow.open(map,marker);

});

 }

 google.maps.event.addDomListener(window, 'load', initialize);

</script>

'progarm_old > [PHP]' 카테고리의 다른 글

네이버 검색 api를 사용  (0) 2017.09.11
php (없애기)  (0) 2017.08.02
[google] 구글맵 지도 작업  (0) 2017.07.19
날짜~ 살아온 일수 구하기  (0) 2017.03.17
현재 URL 비교하여 찾기  (0) 2016.10.20

 <? $arr = explode(",", $view['wr_8']);?>

<!-- GoogoleMap Asynchronously Loading the API ********************************************* -->

<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false&key=AIzaSyBC54YWLZJavk-9IAJAMEMU-hocEeEAet0"></script>

<script type="text/javascript">

 function initialize() {

var mapLocation = new google.maps.LatLng('<?=$arr[0]?>', '<?=$arr[1]?>');  // 지도에서 가운데로 위치할 위도와 경도

var markLocation = new google.maps.LatLng('<?=$arr[0]?>', '<?=$arr[1]?>'); // 마커가 위치할 위도와 경도

 

var mapOptions = {

 center: mapLocation, // 지도에서 가운데로 위치할 위도와 경도(변수)

 zoom: 18,            // 지도 zoom단계

 mapTypeId: google.maps.MapTypeId.ROADMAP

};

var map = new google.maps.Map(document.getElementById("map-canvas"), // id: map-canvas, body에 있는 div태그의 id와 같아야 함

mapOptions);

 

var size_x = 60; // 마커로 사용할 이미지의 가로 크기

var size_y = 60; // 마커로 사용할 이미지의 세로 크기

 

// 마커로 사용할 이미지 주소

var image = new google.maps.MarkerImage( 'http://www.larva.re.kr/home/img/boximage3.png',

new google.maps.Size(size_x, size_y),

'',

'',

new google.maps.Size(size_x, size_y));

 

var marker;

marker = new google.maps.Marker({

  position: markLocation, // 마커가 위치할 위도와 경도(변수)

  map: map,

  icon: image, // 마커로 사용할 이미지(변수)

              //info: '말풍선 안에 들어갈 내용',

  title: "<?=$view['wr_1']?>" // 마커에 마우스 포인트를 갖다댔을 때 뜨는 타이틀

});

 

var content = "이곳이 <?=$view['wr_subject']?> 입니다 ^^"; // 말풍선 안에 들어갈 내용

 

// 마커를 클릭했을 때의 이벤트. 말풍선 뿅~

var infowindow = new google.maps.InfoWindow({ content: content});

 

google.maps.event.addListener(marker, "click", function() {

infowindow.open(map,marker);

});

 }

 google.maps.event.addDomListener(window, 'load', initialize);

</script>


</div>

'progarm_old > [PHP]' 카테고리의 다른 글

php (없애기)  (0) 2017.08.02
[google] 구글 지도 대박 스크립트로 이게 되네요.  (0) 2017.07.19
날짜~ 살아온 일수 구하기  (0) 2017.03.17
현재 URL 비교하여 찾기  (0) 2016.10.20
신규한자일때  (0) 2016.08.09

http://guslabview.tistory.com/406  <!-- 참고



우선 종류를 고르고~


난뒤에 키 가져오기하면 자동가져옵니다.


끝 ~~ 참 쉽죠


'progarm_old' 카테고리의 다른 글

[소셜] 페이스북 로그인  (0) 2017.11.27
구글지도 튜토리얼  (0) 2017.11.01
알고리즘 사이트  (0) 2017.02.22
가상머신 가상서버 만들기  (0) 2016.10.30
엑셀 읽기 최고입니다. 알고있는것 중에서요.  (0) 2016.05.18

+ Recent posts