右から左へ流してしまおう

日々刻々と進化する技術を定着させるには、技術レコーディングだ!と思い立ったが吉日ブログ

Geo Location APIで、現在位置を取得する

スマホを持って、Googleマップで現在位置を取得できるのは、かなり一般的になりました。Androidだと、Javaandroid.locationパッケージを利用してもできますが、今回は、PCでwebブラウザから取得できるように、JavaScript書いてみたいと思います。

以下がソースです。

・geolocation.html

・geolocation.js

・geolocation.css

※今回の実機確認は、Androidのwebviewで行っていますが、そのActivityのソースは、今回は掲載を見送ります。

 

次は、JQueryを使用した画像タッチスクロールについて

書いてみたいと思います。

その前に、自PCに、SVN構築しないとな。どんどんソースが書きかわってしまう…。

 

// geolocation.html

<!DOCTYPE html>

<html>

<head>

<meta name="viewport" content="width=device-width, initial-scale=1" />

<title>geolocation API</title>

<script src="http://maps.google.com/maps/api/js?v=3&sensor=true" type="text/javascript" charset="utf-8"></script>

<script src="js/geolocation.js" type="text/javascript" charset="utf-8"></script>

<link rel="stylesheet" href="css/geolocation.css" type="text/css" charset="utf-8"/>

</head>

<body onload="init()">

<div id="map"></div>

</body>

</html>

 

// geolocation.js

 

var map;

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

 

// 初期化。bodyのonloadinit()を指定することで呼び出してます

function init() {

 

    // Google Mapで利用する初期設定用の変数

    var latlng = new google.maps.LatLng(39, 138);

    var opts = {

        // 起動時のズーム設定。これぐらいが、一般的なアプリでよく見る。

        zoom : 18,

        mapTypeId : google.maps.MapTypeId.ROADMAP,

        center : latlng

    };

 

    // getElementById("map")の"map"は、body内の<div id="map">より

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

 

    // W3C Geolocationを使う

    if (navigator.geolocation) {

        navigator.geolocation.getCurrentPosition(handleGeolocation, handleNoGeolocation);

 

    } else {

        alert("W3C Geolocationがありません");

    }

}

 

// getCurrentPositionで行われる処理を記述

function handleGeolocation(position) {

 

    // 位置情報を取得

    var latlng = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);

 

    showInfoWindow(latlng);

    

    var marker = new google.maps.Marker({

        position: latlng,

        map: map

    });

    

}

 

// ふきだしの位置と中身を設定

function showInfoWindow(latlng) {

    // 地図の中心位置を設定

    map.setCenter(latlng);

}

 

// geolocation.css

@CHARSET "UTF-8";

 

html {

    height: 100%;

}

 

body {

    height: 100%;

    margin: 0px;

    padding: 0px;

}

 

div#map {

    position: fixed;

    z-index: 0;

    width: 100%;

    height: 100%;

    top:0px;

    left:0px;

}