{"id":9184,"date":"2025-12-11T15:27:13","date_gmt":"2025-12-11T06:27:13","guid":{"rendered":"https:\/\/rakkokeyword.com\/techo\/?p=9184"},"modified":"2026-01-30T11:03:45","modified_gmt":"2026-01-30T02:03:45","slug":"tool-location-share","status":"publish","type":"post","link":"https:\/\/rakkokeyword.com\/techo\/tool-location-share\/","title":{"rendered":"\u4f4d\u7f6e\u60c5\u5831\u5171\u6709\u30c4\u30fc\u30eb"},"content":{"rendered":"\n<!-- \u73fe\u5728\u5730\u5171\u6709\u30fb\u78ba\u8a8d\u30c4\u30fc\u30eb\uff08OpenStreetMap\u7248 - \u30b7\u30f3\u30d7\u30eb\u8868\u793a\uff09 -->\n<div id=\"locshare-container\" style=\"width: 100%; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;\">\n  <!-- Leaflet CSS -->\n  <link rel=\"stylesheet\" href=\"https:\/\/unpkg.com\/leaflet@1.9.4\/dist\/leaflet.css\">\n\n  <!-- \u8aac\u660e\u30c6\u30ad\u30b9\u30c8 -->\n  <div style=\"margin-bottom: 16px; padding: 14px; background-color: #f9f9f9; border-left: 4px solid #13284B; border-radius: 4px;\">\n    <p style=\"margin: 0; font-size: 13px; line-height: 1.5; color: #555;\">\n      \u3042\u306a\u305f\u306e\u73fe\u5728\u5730\u3092\u53d6\u5f97\u2192GoogleMap\u306eURL\u3092\u5171\u6709\u3067\u304d\u307e\u3059\n    <\/p>\n  <\/div>\n\n  <!-- \u73fe\u5728\u5730\u53d6\u5f97\u30dc\u30bf\u30f3 -->\n  <div style=\"margin-bottom: 16px;\">\n    <button id=\"locshare-get-location\" aria-label=\"\u73fe\u5728\u5730\u3092\u53d6\u5f97\u3059\u308b\" style=\"width: 100%; height: 50px; background-color: #13284B; color: white; border: none; border-radius: 4px; font-size: 16px; cursor: pointer; font-weight: 600; position: relative;\">\n      <span id=\"locshare-get-location-text\">\u73fe\u5728\u5730\u3092\u53d6\u5f97<\/span>\n      <span id=\"locshare-get-location-spinner\" class=\"locshare-spinner\" style=\"display: none; width: 20px; height: 20px; border: 3px solid rgba(255,255,255,0.3); border-top: 3px solid white; border-radius: 50%; animation: locshare-spin 1s linear infinite; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);\"><\/span>\n    <\/button>\n  <\/div>\n\n  <!-- \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8 -->\n  <div id=\"locshare-error\" role=\"alert\" style=\"display: none; padding: 12px; background-color: #fee; border-left: 4px solid #c33; margin-bottom: 16px; color: #c33; font-size: 14px; border-radius: 4px;\"><\/div>\n\n  <!-- \u7d50\u679c\u8868\u793a\u30a8\u30ea\u30a2 -->\n  <div id=\"locshare-result\" style=\"display: none;\">\n    <!-- \u5730\u56f3\u8868\u793a\u30a8\u30ea\u30a2 -->\n    <div id=\"locshare-map\" style=\"width: 100%; height: 400px; margin-bottom: 20px; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.1); position: relative;\">\n      <div id=\"locshare-map-loading\" style=\"position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; color: #666; z-index: 1000; background: white; padding: 20px; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.1);\">\n        <div class=\"locshare-spinner\" style=\"width: 30px; height: 30px; border: 3px solid #ddd; border-top: 3px solid #13284B; border-radius: 50%; animation: locshare-spin 1s linear infinite; margin: 0 auto 10px;\"><\/div>\n        <div style=\"font-size: 13px;\">\u5730\u56f3\u3092\u8868\u793a\u4e2d\u2026<\/div>\n      <\/div>\n    <\/div>\n\n    <!-- \u5171\u6709\u7528URL -->\n    <div style=\"margin-bottom: 20px;\">\n      <p style=\"margin: 0 0 8px 0; font-size: 12px; font-weight: 600; color: #999; text-transform: uppercase; letter-spacing: 0.5px;\">\u5171\u6709\u7528URL<\/p>\n      <div style=\"position: relative;\">\n        <input type=\"text\" id=\"locshare-url\" readonly aria-label=\"\u5171\u6709\u7528URL\" style=\"width: 100%; padding: 12px 85px 12px 12px; border: 2px solid #e0e0e0; border-radius: 6px; font-size: 12px; background-color: #fff; box-sizing: border-box; font-family: 'Courier New', monospace; color: #555;\">\n        <button id=\"locshare-copy-url\" aria-label=\"URL\u3092\u30b3\u30d4\u30fc\" style=\"position: absolute; right: 6px; top: 50%; transform: translateY(-50%); height: 34px; padding: 0 16px; background-color: #13284B; color: white; border: none; border-radius: 4px; font-size: 12px; cursor: pointer; font-weight: 600;\">\n          \u30b3\u30d4\u30fc\n        <\/button>\n      <\/div>\n    <\/div>\n\n    <!-- \u30a2\u30af\u30b7\u30e7\u30f3\u30dc\u30bf\u30f3 -->\n    <div style=\"margin-bottom: 16px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px;\">\n      <button id=\"locshare-line-share\" aria-label=\"LINE\u3067\u9001\u308b\" style=\"height: 48px; background-color: #00B900; color: white; border: none; border-radius: 6px; font-size: 15px; cursor: pointer; font-weight: 600;\">\n        LINE\u3067\u9001\u308b\n      <\/button>\n      <button id=\"locshare-native-share\" aria-label=\"\u305d\u306e\u4ed6\u306e\u65b9\u6cd5\u3067\u5171\u6709\" style=\"height: 48px; background-color: #13284B; color: white; border: none; border-radius: 6px; font-size: 15px; cursor: pointer; font-weight: 600;\">\n        \u305d\u306e\u4ed6\u3067\u5171\u6709\n      <\/button>\n    <\/div>\n\n    <!-- \u518d\u53d6\u5f97\u30dc\u30bf\u30f3 -->\n    <div>\n      <button id=\"locshare-refresh-location\" aria-label=\"\u4f4d\u7f6e\u60c5\u5831\u3092\u518d\u53d6\u5f97\u3059\u308b\" style=\"width: 100%; height: 42px; background-color: #fff; color: #333; border: 2px solid #e0e0e0; border-radius: 6px; font-size: 14px; cursor: pointer; font-weight: 600;\">\n        \u4f4d\u7f6e\u60c5\u5831\u3092\u518d\u53d6\u5f97\n      <\/button>\n    <\/div>\n  <\/div>\n\n  <!-- \u30c8\u30fc\u30b9\u30c8\u901a\u77e5 -->\n  <div id=\"locshare-toast\" role=\"status\" aria-live=\"polite\" style=\"display: none; position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); background-color: #333; color: white; padding: 14px 28px; border-radius: 6px; font-size: 14px; z-index: 10000; box-shadow: 0 4px 12px rgba(0,0,0,0.3); max-width: 90%; text-align: center; font-weight: 500;\">\n  <\/div>\n<\/div>\n\n<style>\n@keyframes locshare-spin {\n  0% { transform: rotate(0deg); }\n  100% { transform: rotate(360deg); }\n}\n\n#locshare-container * {\n  box-sizing: border-box;\n}\n\n#locshare-container button:not(:disabled):hover {\n  opacity: 0.9;\n  transform: translateY(-1px);\n  transition: all 0.2s ease;\n}\n\n#locshare-container button:not(:disabled):active {\n  opacity: 0.8;\n  transform: translateY(0);\n}\n\n#locshare-container button:disabled {\n  opacity: 0.6;\n  cursor: not-allowed;\n}\n\n#locshare-container input:focus,\n#locshare-container button:focus {\n  outline: 3px solid #13284B;\n  outline-offset: 2px;\n}\n\n\/* Leaflet\u5730\u56f3\u306e\u30ab\u30b9\u30bf\u30e0\u30b9\u30bf\u30a4\u30eb *\/\n#locshare-map .leaflet-control-attribution {\n  font-size: 10px;\n}\n\n@media (max-width: 600px) {\n  #locshare-map {\n    height: 300px !important;\n  }\n  \n  #locshare-container [style*=\"grid-template-columns: 1fr 1fr\"] {\n    grid-template-columns: 1fr !important;\n  }\n  \n  #locshare-container button {\n    font-size: 14px !important;\n  }\n}\n<\/style>\n\n<!-- Leaflet JS -->\n<script src=\"https:\/\/media-api.qcdgv19414.rakkoserver.net\/lib\/leaflet.js\"><\/script>\n\n<script>\n(function() {\n  'use strict';\n  \n  \/\/ ==========================================\n  \/\/ \u8a2d\u5b9a\n  \/\/ ==========================================\n  const LOCSHARE_CONFIG = {\n    BUTTON_DISABLE_DURATION: 2000,\n    HIGH_ACCURACY_TIMEOUT: 10000,\n    DEFAULT_ZOOM: 16\n  };\n  \n  \/\/ ==========================================\n  \/\/ \u30b0\u30ed\u30fc\u30d0\u30eb\u5909\u6570\n  \/\/ ==========================================\n  const locshareState = {\n    map: null,\n    marker: null,\n    currentLat: null,\n    currentLng: null,\n    isProcessing: false\n  };\n  \n  \/\/ ==========================================\n  \/\/ DOM\u8981\u7d20\u306e\u53d6\u5f97\n  \/\/ ==========================================\n  const locshareElements = {\n    mapDiv: document.getElementById('locshare-map'),\n    mapLoading: document.getElementById('locshare-map-loading'),\n    getLocationBtn: document.getElementById('locshare-get-location'),\n    getLocationText: document.getElementById('locshare-get-location-text'),\n    getLocationSpinner: document.getElementById('locshare-get-location-spinner'),\n    refreshLocationBtn: document.getElementById('locshare-refresh-location'),\n    error: document.getElementById('locshare-error'),\n    result: document.getElementById('locshare-result'),\n    url: document.getElementById('locshare-url'),\n    copyUrlBtn: document.getElementById('locshare-copy-url'),\n    lineShareBtn: document.getElementById('locshare-line-share'),\n    nativeShareBtn: document.getElementById('locshare-native-share'),\n    toast: document.getElementById('locshare-toast')\n  };\n  \n  \/\/ ==========================================\n  \/\/ \u521d\u671f\u5316\n  \/\/ ==========================================\n  if (document.readyState === 'loading') {\n    document.addEventListener('DOMContentLoaded', locshareInit);\n  } else {\n    locshareInit();\n  }\n  \n  function locshareInit() {\n    \/\/ Leaflet\u304c\u8aad\u307f\u8fbc\u307e\u308c\u308b\u306e\u3092\u5f85\u3064\n    if (typeof L === 'undefined') {\n      setTimeout(locshareInit, 100);\n      return;\n    }\n    \n    \/\/ \u30a4\u30d9\u30f3\u30c8\u30ea\u30b9\u30ca\u30fc\u306e\u8a2d\u5b9a\n    locshareElements.getLocationBtn.addEventListener('click', locshareGetCurrentLocation);\n    locshareElements.refreshLocationBtn.addEventListener('click', locshareGetCurrentLocation);\n    locshareElements.copyUrlBtn.addEventListener('click', locshareCopyUrl);\n    locshareElements.lineShareBtn.addEventListener('click', locshareLineShare);\n    locshareElements.nativeShareBtn.addEventListener('click', locshareNativeShare);\n  }\n  \n  \/\/ ==========================================\n  \/\/ \u5730\u56f3\u521d\u671f\u5316\n  \/\/ ==========================================\n  function locshareInitializeMap(lat, lng) {\n    if (locshareState.map) {\n      \/\/ \u65e2\u5b58\u306e\u5730\u56f3\u3092\u66f4\u65b0\n      locshareState.map.setView([lat, lng], LOCSHARE_CONFIG.DEFAULT_ZOOM);\n      if (locshareState.marker) {\n        locshareState.marker.setLatLng([lat, lng]);\n      } else {\n        locshareState.marker = L.marker([lat, lng], {\n          draggable: false\n        }).addTo(locshareState.map);\n      }\n    } else {\n      \/\/ \u65b0\u898f\u5730\u56f3\u4f5c\u6210\n      locshareState.map = L.map('locshare-map').setView([lat, lng], LOCSHARE_CONFIG.DEFAULT_ZOOM);\n      \n      \/\/ OpenStreetMap\u30bf\u30a4\u30eb\n      L.tileLayer('https:\/\/{s}.tile.openstreetmap.org\/{z}\/{x}\/{y}.png', {\n        attribution: '&copy; <a href=\"https:\/\/www.openstreetmap.org\/copyright\">OpenStreetMap<\/a>',\n        maxZoom: 19\n      }).addTo(locshareState.map);\n      \n      \/\/ \u30de\u30fc\u30ab\u30fc\u8ffd\u52a0\n      locshareState.marker = L.marker([lat, lng], {\n        draggable: false\n      }).addTo(locshareState.map);\n      \n      \/\/ \u30dd\u30c3\u30d7\u30a2\u30c3\u30d7\n      locshareState.marker.bindPopup('\u73fe\u5728\u5730').openPopup();\n    }\n    \n    \/\/ \u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u975e\u8868\u793a\n    locshareElements.mapLoading.style.display = 'none';\n  }\n  \n  \/\/ ==========================================\n  \/\/ \u73fe\u5728\u5730\u53d6\u5f97\n  \/\/ ==========================================\n  function locshareGetCurrentLocation() {\n    if (locshareState.isProcessing) {\n      return;\n    }\n    \n    if (!navigator.geolocation) {\n      locshareShowError('\u304a\u4f7f\u3044\u306e\u30d6\u30e9\u30a6\u30b6\u306f\u4f4d\u7f6e\u60c5\u5831\u306b\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u305b\u3093\u3002');\n      return;\n    }\n    \n    locshareState.isProcessing = true;\n    locshareElements.getLocationBtn.disabled = true;\n    locshareElements.refreshLocationBtn.disabled = true;\n    locshareElements.getLocationText.style.display = 'none';\n    locshareElements.getLocationSpinner.style.display = 'inline-block';\n    locshareHideError();\n    \n    navigator.geolocation.getCurrentPosition(\n      locshareSuccessCallback,\n      locshareErrorCallback,\n      {\n        enableHighAccuracy: true,\n        timeout: LOCSHARE_CONFIG.HIGH_ACCURACY_TIMEOUT,\n        maximumAge: 0\n      }\n    );\n  }\n  \n  function locshareSuccessCallback(position) {\n    try {\n      locshareState.currentLat = position.coords.latitude;\n      locshareState.currentLng = position.coords.longitude;\n      \n      \/\/ \u5165\u529b\u5024\u306e\u691c\u8a3c\n      if (!locshareValidateCoordinates(locshareState.currentLat, locshareState.currentLng)) {\n        locshareShowError('\u53d6\u5f97\u3057\u305f\u4f4d\u7f6e\u60c5\u5831\u304c\u7121\u52b9\u3067\u3059\u3002');\n        locshareResetButtons();\n        return;\n      }\n      \n      \/\/ \u7d50\u679c\u30a8\u30ea\u30a2\u3092\u8868\u793a\n      locshareElements.getLocationBtn.style.display = 'none';\n      locshareElements.result.style.display = 'block';\n      \n      \/\/ \u5730\u56f3\u3092\u521d\u671f\u5316\u30fb\u66f4\u65b0\n      locshareInitializeMap(locshareState.currentLat, locshareState.currentLng);\n      \n      \/\/ \u8868\u793a\u3092\u66f4\u65b0\n      locshareUpdateDisplay();\n      \n      \/\/ \u30dc\u30bf\u30f3\u306e\u518d\u6709\u52b9\u5316\n      setTimeout(function() {\n        locshareElements.refreshLocationBtn.disabled = false;\n        locshareState.isProcessing = false;\n      }, LOCSHARE_CONFIG.BUTTON_DISABLE_DURATION);\n    } catch (error) {\n      locshareShowError('\u4f4d\u7f6e\u60c5\u5831\u306e\u51e6\u7406\u4e2d\u306b\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3057\u305f\u3002');\n      locshareResetButtons();\n    }\n  }\n  \n  function locshareErrorCallback(error) {\n    let errorMessage = '\u4f4d\u7f6e\u60c5\u5831\u306e\u53d6\u5f97\u306b\u5931\u6557\u3057\u307e\u3057\u305f\u3002';\n    \n    switch(error.code) {\n      case error.PERMISSION_DENIED:\n        errorMessage = '\u4f4d\u7f6e\u60c5\u5831\u306e\u4f7f\u7528\u304c\u62d2\u5426\u3055\u308c\u307e\u3057\u305f\u3002\u30d6\u30e9\u30a6\u30b6\u306e\u8a2d\u5b9a\u3067\u4f4d\u7f6e\u60c5\u5831\u3092\u8a31\u53ef\u3057\u3066\u304f\u3060\u3055\u3044\u3002';\n        break;\n      case error.POSITION_UNAVAILABLE:\n        errorMessage = '\u4f4d\u7f6e\u60c5\u5831\u304c\u5229\u7528\u3067\u304d\u307e\u305b\u3093\u3002GPS\u304c\u30aa\u30d5\u306b\u306a\u3063\u3066\u3044\u308b\u304b\u3001\u901a\u4fe1\u74b0\u5883\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002';\n        break;\n      case error.TIMEOUT:\n        errorMessage = '\u4f4d\u7f6e\u60c5\u5831\u306e\u53d6\u5f97\u304c\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8\u3057\u307e\u3057\u305f\u3002\u3082\u3046\u4e00\u5ea6\u304a\u8a66\u3057\u304f\u3060\u3055\u3044\u3002';\n        break;\n    }\n    \n    locshareShowError(errorMessage);\n    locshareResetButtons();\n  }\n  \n  function locshareResetButtons() {\n    locshareState.isProcessing = false;\n    locshareElements.getLocationBtn.disabled = false;\n    locshareElements.refreshLocationBtn.disabled = false;\n    locshareElements.getLocationText.style.display = 'inline';\n    locshareElements.getLocationSpinner.style.display = 'none';\n  }\n  \n  \/\/ ==========================================\n  \/\/ \u8868\u793a\u66f4\u65b0\n  \/\/ ==========================================\n  function locshareUpdateDisplay() {\n    if (!locshareValidateCoordinates(locshareState.currentLat, locshareState.currentLng)) {\n      locshareShowError('\u4f4d\u7f6e\u60c5\u5831\u304c\u7121\u52b9\u3067\u3059\u3002');\n      return;\n    }\n    \n    \/\/ Google Maps URL\u306e\u751f\u6210\n    const url = `https:\/\/maps.google.com\/?q=${locshareState.currentLat},${locshareState.currentLng}`;\n    locshareElements.url.value = url;\n  }\n  \n  \/\/ ==========================================\n  \/\/ URL\u30b3\u30d4\u30fc\n  \/\/ ==========================================\n  function locshareCopyUrl() {\n    const url = locshareElements.url.value;\n    \n    if (!url) {\n      locshareShowToast('\u30b3\u30d4\u30fc\u3059\u308bURL\u304c\u3042\u308a\u307e\u305b\u3093');\n      return;\n    }\n    \n    if (navigator.clipboard && navigator.clipboard.writeText) {\n      navigator.clipboard.writeText(url).then(function() {\n        locshareShowToast('URL\u3092\u30b3\u30d4\u30fc\u3057\u307e\u3057\u305f\uff01');\n      }).catch(function() {\n        locshareFallbackCopy(url);\n      });\n    } else {\n      locshareFallbackCopy(url);\n    }\n  }\n  \n  function locshareFallbackCopy(text) {\n    try {\n      locshareElements.url.select();\n      locshareElements.url.setSelectionRange(0, 99999);\n      \n      const successful = document.execCommand('copy');\n      if (successful) {\n        locshareShowToast('URL\u3092\u30b3\u30d4\u30fc\u3057\u307e\u3057\u305f\uff01');\n      } else {\n        locshareShowToast('\u30b3\u30d4\u30fc\u306b\u5931\u6557\u3057\u307e\u3057\u305f');\n      }\n    } catch (err) {\n      locshareShowToast('\u30b3\u30d4\u30fc\u306b\u5931\u6557\u3057\u307e\u3057\u305f');\n    }\n  }\n  \n  \/\/ ==========================================\n  \/\/ LINE\u5171\u6709\n  \/\/ ==========================================\n  function locshareLineShare() {\n    const url = locshareElements.url.value;\n    \n    if (!url) {\n      locshareShowToast('\u5171\u6709\u3059\u308bURL\u304c\u3042\u308a\u307e\u305b\u3093');\n      return;\n    }\n    \n    const text = encodeURIComponent(url);\n    const lineUrl = `https:\/\/line.me\/R\/msg\/text\/?${text}`;\n    \n    try {\n      window.open(lineUrl, '_blank', 'noopener,noreferrer');\n    } catch (error) {\n      locshareShowToast('LINE\u306e\u8d77\u52d5\u306b\u5931\u6557\u3057\u307e\u3057\u305f');\n    }\n  }\n  \n  \/\/ ==========================================\n  \/\/ \u30cd\u30a4\u30c6\u30a3\u30d6\u5171\u6709\n  \/\/ ==========================================\n  function locshareNativeShare() {\n    const url = locshareElements.url.value;\n    \n    if (!url) {\n      locshareShowToast('\u5171\u6709\u3059\u308bURL\u304c\u3042\u308a\u307e\u305b\u3093');\n      return;\n    }\n    \n    if (navigator.share) {\n      navigator.share({\n        title: '\u73fe\u5728\u5730\u60c5\u5831',\n        text: url\n      }).catch(function(error) {\n        if (error.name !== 'AbortError') {\n          locshareShowToast('\u5171\u6709\u306b\u5931\u6557\u3057\u307e\u3057\u305f');\n        }\n      });\n    } else {\n      locshareShowToast('\u3053\u306e\u6a5f\u80fd\u306f\u304a\u4f7f\u3044\u306e\u30d6\u30e9\u30a6\u30b6\u3067\u306f\u5229\u7528\u3067\u304d\u307e\u305b\u3093');\n    }\n  }\n  \n  \/\/ ==========================================\n  \/\/ \u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u95a2\u6570\n  \/\/ ==========================================\n  function locshareValidateCoordinates(lat, lng) {\n    if (typeof lat !== 'number' || typeof lng !== 'number') return false;\n    if (isNaN(lat) || isNaN(lng)) return false;\n    if (lat < -90 || lat > 90) return false;\n    if (lng < -180 || lng > 180) return false;\n    return true;\n  }\n  \n  function locshareShowError(message) {\n    locshareElements.error.textContent = message;\n    locshareElements.error.style.display = 'block';\n  }\n  \n  function locshareHideError() {\n    locshareElements.error.style.display = 'none';\n  }\n  \n  function locshareShowToast(message) {\n    locshareElements.toast.textContent = message;\n    locshareElements.toast.style.display = 'block';\n    \n    setTimeout(function() {\n      locshareElements.toast.style.display = 'none';\n    }, 3000);\n  }\n})();\n<\/script>\n\n\n\n<p>\u30b9\u30de\u30db\u306eGPS\u3067\u81ea\u5206\u306e\u73fe\u5728\u5730\u3092\u53d6\u5f97\u3057\u3001Google\u30de\u30c3\u30d7\u306eURL\u3092\u5373\u5ea7\u306b\u767a\u884c\u3059\u308b\u30c4\u30fc\u30eb\u3067\u3059\u3002<br>\u30a2\u30d7\u30ea\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u4e0d\u8981\u3067\u3001LINE\u3084\u30e1\u30fc\u30eb\u3067\u3059\u3050\u306b\u4f4d\u7f6e\u60c5\u5831\u3092\u5171\u6709\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-exclamation-alt\">\u4f4d\u7f6e\u60c5\u5831\u5229\u7528\u306e\u8a31\u53ef\u304c\u6c42\u3081\u3089\u308c\u305f\u5834\u5408\u3001\u8a31\u53ef\u3092\u30af\u30ea\u30c3\u30af\u3057\u3066\u304f\u3060\u3055\u3044\u3002<br>\u306a\u304a\u3001GPS\u304c\u642d\u8f09\u3055\u308c\u3066\u3044\u306a\u3044\u7aef\u672b\u306e\u5834\u5408\u306f\u3001\u6b63\u78ba\u306a\u4f4d\u7f6e\u60c5\u5831\u304c\u53d6\u5f97\u3067\u304d\u307e\u305b\u3093\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-0\">\u3053\u306e\u30c4\u30fc\u30eb\u3067\u3067\u304d\u308b\u3053\u3068<\/h2>\n\n\n\n<p>\u3053\u306e\u30c4\u30fc\u30eb\u306f\u3001\u3042\u306a\u305f\u306e\u30b9\u30de\u30db\u3084PC\u306eGPS\u6a5f\u80fd\u3092\u5229\u7528\u3057\u3066\u3001\u4ee5\u4e0b\u306e3\u3064\u306e\u30b9\u30c6\u30c3\u30d7\u3092\u81ea\u52d5\u3067\u884c\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u73fe\u5728\u5730\u306e\u7279\u5b9a<\/strong> <br>\u300c\u73fe\u5728\u5730\u3092\u53d6\u5f97\u300d\u30dc\u30bf\u30f3\u3092\u62bc\u3059\u3060\u3051\u3067\u3001\u7def\u5ea6\u30fb\u7d4c\u5ea6\u304b\u3089\u3042\u306a\u305f\u306e\u5c45\u5834\u6240\u3092\u7279\u5b9a\u3057\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u5730\u56f3\u3067\u306e\u78ba\u8a8d<\/strong> <br>\u53d6\u5f97\u3057\u305f\u4f4d\u7f6e\u60c5\u5831\u3092\u5730\u56f3\u4e0a\u306b\u30d4\u30f3\u3067\u8868\u793a\u3057\u307e\u3059\u3002\u9001\u308b\u524d\u306b\u3001\u53d6\u5f97\u3057\u305f\u73fe\u5728\u5730\u304c\u5408\u3063\u3066\u3044\u308b\u304b\u81ea\u5206\u3067\u78ba\u8a8d\u3067\u304d\u308b\u306e\u3067\u5b89\u5fc3\u3067\u3059\u3002<\/li>\n\n\n\n<li><strong>\u5171\u6709\u7528URL\u306e\u4f5c\u6210\u3068\u9001\u4fe1<\/strong> <br>Google\u30de\u30c3\u30d7\u3067\u958b\u3051\u308b\u5171\u6709\u7528URL\u3092\u81ea\u52d5\u751f\u6210\u3057\u307e\u3059\u3002\u300cLINE\u3067\u9001\u308b\u300d\u30dc\u30bf\u30f3\u3084\u300c\u30b3\u30d4\u30fc\u300d\u30dc\u30bf\u30f3\u3092\u4f7f\u3048\u3070\u3001\u5bb6\u65cf\u3084\u53cb\u4eba\u306b\u4e00\u77ac\u3067\u73fe\u5728\u5730\u3092\u77e5\u3089\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-1\">\u3053\u306e\u30c4\u30fc\u30eb\u3067\u53d6\u5f97\u3059\u308b\u60c5\u5831\u306e\u57fa\u790e\u77e5\u8b58<\/h2>\n\n\n\n<p>\u3053\u306e\u30c4\u30fc\u30eb\u304c\u3069\u306e\u3088\u3046\u306b\u4f4d\u7f6e\u60c5\u5831\u3092\u6271\u3063\u3066\u3044\u308b\u304b\u3001\u57fa\u672c\u7684\u306a\u4ed5\u7d44\u307f\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u7def\u5ea6\u30fb\u7d4c\u5ea6\uff08GPS\u60c5\u5831\uff09<\/strong> <br>\u5730\u7403\u4e0a\u306e\u6b63\u78ba\u306a\u4f4d\u7f6e\u3092\u793a\u3059\u5ea7\u6a19\u6570\u5024\u3067\u3059\u3002\u3053\u306e\u30c4\u30fc\u30eb\u3067\u306f\u30d6\u30e9\u30a6\u30b6\u306e\u6a19\u6e96\u6a5f\u80fd\uff08Geolocation API\uff09\u3092\u4f7f\u7528\u3057\u3066\u3001\u5b89\u5168\u306b\u5ea7\u6a19\u3092\u53d6\u5f97\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u4f4d\u7f6e\u60c5\u5831\u306e\u7cbe\u5ea6<\/strong> <br>\u30b9\u30de\u30fc\u30c8\u30d5\u30a9\u30f3\u3067\u5229\u7528\u3059\u308b\u5834\u5408\u3001GPS\u885b\u661f\u306e\u96fb\u6ce2\u72b6\u6cc1\u3084Wi-Fi\u74b0\u5883\u306b\u3088\u3063\u3066\u3001\u6570\u30e1\u30fc\u30c8\u30eb\u304b\u3089\u6570\u5341\u30e1\u30fc\u30c8\u30eb\u306e\u8aa4\u5dee\u304c\u751f\u3058\u308b\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>Google\u30de\u30c3\u30d7\u3068\u306e\u9023\u643a<\/strong> <br>\u3053\u306e\u30c4\u30fc\u30eb\u304c\u8868\u793a\u3059\u308b\u5730\u56f3\u306f\u78ba\u8a8d\u7528\u306e\u7c21\u6613\u5730\u56f3\uff08OpenStreetMap\uff09\u3067\u3059\u304c\u3001\u76f8\u624b\u306b\u9001\u308bURL\u306f\u300cGoogle\u30de\u30c3\u30d7\u300d\u306e\u30ea\u30f3\u30af\u3067\u3059\u3002<br>\u53d7\u3051\u53d6\u3063\u305f\u76f8\u624b\u306f\u3001\u666e\u6bb5\u4f7f\u3044\u6163\u308c\u305fGoogle\u30de\u30c3\u30d7\u30a2\u30d7\u30ea\u3067\u3042\u306a\u305f\u306e\u5834\u6240\u3092\u958b\u304f\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-2\">\u3053\u306e\u30c4\u30fc\u30eb\u304c\u5f79\u7acb\u3064\u3068\u304d\u306f\u3069\u3093\u306a\u3068\u304d\uff1f<\/h2>\n\n\n\n<p>\u65e5\u5e38\u306e\u5f85\u3061\u5408\u308f\u305b\u304b\u3089\u7dca\u6025\u6642\u307e\u3067\u3001\u3055\u307e\u3056\u307e\u306a\u30b7\u30fc\u30f3\u3067\u6d3b\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u5f85\u3061\u5408\u308f\u305b\u3067\u76f8\u624b\u304c\u898b\u3064\u304b\u3089\u306a\u3044\u3068\u304d<\/strong> <br>\u300c\u99c5\u306e\u5317\u53e3\u306b\u3044\u308b\u300d\u3068\u4f1d\u3048\u3066\u3082\u4f1a\u3048\u306a\u3044\u6642\u3001\u3053\u306e\u30c4\u30fc\u30eb\u3067URL\u3092\u9001\u308c\u3070\u3001\u76f8\u624b\u306f\u30ca\u30d3\u6a5f\u80fd\u3092\u4f7f\u3063\u3066\u3042\u306a\u305f\u306e\u3082\u3068\u3078\u8fbf\u308a\u7740\u3051\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u81ea\u5206\u306e\u73fe\u5728\u5730\u3092\u8aac\u660e\u3067\u304d\u306a\u3044\u3068\u304d<\/strong> <br>\u521d\u3081\u3066\u8a2a\u308c\u305f\u5834\u6240\u3084\u3001\u76ee\u5370\u306e\u306a\u3044\u516c\u5712\u3001\u5c71\u9053\u306a\u3069\u3067\u8ff7\u3063\u3066\u3057\u307e\u3063\u305f\u969b\u3001\u4f4f\u6240\u304c\u308f\u304b\u3089\u306a\u304f\u3066\u3082\u6b63\u78ba\u306a\u4f4d\u7f6e\u3092\u4f1d\u3048\u3089\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u707d\u5bb3\u6642\u3084\u7dca\u6025\u6642\u306e\u5b89\u5426\u78ba\u8a8d<\/strong> <br>\u96fb\u8a71\u304c\u7e4b\u304c\u308a\u306b\u304f\u3044\u72b6\u6cc1\u3067\u3082\u3001LINE\u3084\u30e1\u30fc\u30eb\u3067\u4f4d\u7f6e\u60c5\u5831URL\u3060\u3051\u3092\u9001\u308b\u3053\u3068\u3067\u3001\u81ea\u5206\u304c\u3069\u3053\u306b\u907f\u96e3\u3057\u3066\u3044\u308b\u304b\u3092\u5bb6\u65cf\u306b\u77e5\u3089\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-3\">\u4f4d\u7f6e\u60c5\u5831\u304c\u53d6\u5f97\u3067\u304d\u306a\u3044\u5834\u5408\u306e\u5bfe\u51e6\u6cd5<\/h2>\n\n\n\n<p>\u300c\u73fe\u5728\u5730\u3092\u53d6\u5f97\u300d\u30dc\u30bf\u30f3\u3092\u62bc\u3057\u3066\u3082\u53cd\u5fdc\u3057\u306a\u3044\u3001\u307e\u305f\u306f\u30a8\u30e9\u30fc\u304c\u51fa\u308b\u5834\u5408\u306f\u3001\u4ee5\u4e0b\u306e\u8a2d\u5b9a\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30d6\u30e9\u30a6\u30b6\u306e\u4f4d\u7f6e\u60c5\u5831\u8a31\u53ef<\/strong> <br>\u521d\u56de\u30a2\u30af\u30bb\u30b9\u6642\u306b\u8868\u793a\u3055\u308c\u308b\u300c\u4f4d\u7f6e\u60c5\u5831\u306e\u5229\u7528\u3092\u8a31\u53ef\u3057\u307e\u3059\u304b\uff1f\u300d\u3068\u3044\u3046\u30dd\u30c3\u30d7\u30a2\u30c3\u30d7\u3067\u300c\u8a31\u53ef\u300d\u3092\u9078\u629e\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u62d2\u5426\u3057\u3066\u3057\u307e\u3063\u305f\u5834\u5408\u306f\u3001\u30d6\u30e9\u30a6\u30b6\u306e\u30a2\u30c9\u30ec\u30b9\u30d0\u30fc\u4ed8\u8fd1\u306b\u3042\u308b\u8a2d\u5b9a\u30a2\u30a4\u30b3\u30f3\u304b\u3089\u8a31\u53ef\u306b\u5909\u66f4\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n\n\n\n<li><strong>\u30b9\u30de\u30db\u672c\u4f53\u306eGPS\u8a2d\u5b9a<\/strong> <br>\u30b9\u30de\u30fc\u30c8\u30d5\u30a9\u30f3\u306e\u8a2d\u5b9a\u3067\u3001\u4f4d\u7f6e\u60c5\u5831\uff08GPS\uff09\u6a5f\u80fd\u304c\u30aa\u30f3\u306b\u306a\u3063\u3066\u3044\u308b\u304b\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u7701\u96fb\u529b\u30e2\u30fc\u30c9\u306b\u306a\u3063\u3066\u3044\u308b\u3068\u7cbe\u5ea6\u304c\u843d\u3061\u308b\u5834\u5408\u304c\u3042\u308a\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u96fb\u6ce2\u74b0\u5883\u306e\u78ba\u8a8d<\/strong> <br><br><\/li>\n\n\n\n<li>\u5730\u4e0b\u3084\u30c8\u30f3\u30cd\u30eb\u5185\u3001\u9ad8\u5c64\u30d3\u30eb\u306e\u9593\u306a\u3069\u3067\u306fGPS\u96fb\u6ce2\u304c\u5165\u308a\u306b\u304f\u3044\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002\u5c11\u3057\u5834\u6240\u3092\u79fb\u52d5\u3057\u3066\u300c\u4f4d\u7f6e\u60c5\u5831\u3092\u518d\u53d6\u5f97\u300d\u30dc\u30bf\u30f3\u3092\u62bc\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">\u30d7\u30e9\u30a4\u30d0\u30b7\u30fc\u3068\u5b89\u5168\u6027\u306b\u3064\u3044\u3066<\/h3>\n\n\n\n<p>\u3053\u306e\u30c4\u30fc\u30eb\u306f\u3001\u304a\u5ba2\u69d8\u306e\u30d7\u30e9\u30a4\u30d0\u30b7\u30fc\u3092\u6700\u512a\u5148\u306b\u8a2d\u8a08\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u4f4d\u7f6e\u60c5\u5831\u306f\u4fdd\u5b58\u3055\u308c\u307e\u305b\u3093<\/strong> <br>\u53d6\u5f97\u3057\u305f\u73fe\u5728\u5730\u30c7\u30fc\u30bf\u306f\u3001\u3042\u306a\u305f\u306e\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u4e00\u6642\u7684\u306b\u51e6\u7406\u3055\u308c\u308b\u3060\u3051\u3067\u3059\u3002\u30b5\u30fc\u30d0\u30fc\u306b\u5c65\u6b74\u304c\u4fdd\u5b58\u3055\u308c\u305f\u308a\u3001\u7b2c\u4e09\u8005\u306b\u52dd\u624b\u306b\u516c\u958b\u3055\u308c\u308b\u3053\u3068\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/li>\n\n\n\n<li><strong>\u5171\u6709\u306f\u624b\u52d5\u64cd\u4f5c\u306e\u307f<\/strong> <br>\u3042\u306a\u305f\u304c\u300cLINE\u3067\u9001\u308b\u300d\u3084\u300c\u30b3\u30d4\u30fc\u300d\u306a\u3069\u306e\u64cd\u4f5c\u3092\u884c\u308f\u306a\u3044\u9650\u308a\u3001\u8ab0\u304b\u306b\u4f4d\u7f6e\u60c5\u5831\u304c\u9001\u4fe1\u3055\u308c\u308b\u3053\u3068\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u3042\u306a\u305f\u306e\u73fe\u5728\u5730\u3092\u53d6\u5f97\u2192GoogleMap\u306eURL\u3092\u5171\u6709\u3067\u304d\u307e\u3059 \u73fe\u5728\u5730\u3092\u53d6\u5f97 \u5730\u56f3\u3092\u8868\u793a\u4e2d\u2026 \u5171\u6709\u7528URL \u30b3\u30d4\u30fc LINE\u3067\u9001\u308b \u305d\u306e\u4ed6\u3067\u5171\u6709 \u4f4d\u7f6e\u60c5\u5831\u3092\u518d\u53d6\u5f97 \u30b9\u30de\u30db\u306eGPS\u3067\u81ea\u5206\u306e\u73fe\u5728\u5730\u3092\u53d6\u5f97\u3057\u3001Google\u30de\u30c3\u30d7 &#8230; <\/p>\n","protected":false},"author":4,"featured_media":9192,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[13,39],"tags":[],"class_list":{"0":"post-9184","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tool","8":"category-life","9":"entry"},"_links":{"self":[{"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/posts\/9184","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/users\/4"}],"replies":[{"embeddable":true,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/comments?post=9184"}],"version-history":[{"count":7,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/posts\/9184\/revisions"}],"predecessor-version":[{"id":9191,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/posts\/9184\/revisions\/9191"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/media\/9192"}],"wp:attachment":[{"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/media?parent=9184"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/categories?post=9184"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rakkokeyword.com\/techo\/wp-json\/wp\/v2\/tags?post=9184"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}