照片提取GPS 转成百度地图坐标
感谢: 小慧only http://www.cnblogs.com/zhaohuionly/p/3142623.html GPS转化坐标方法
大胡子青松 http://www.cnblogs.com/xianyin05/archive/2013/05/10/3071224.html 获取照片中Exif信息里GPS经纬度数
需求:上传个图片 解释出拍摄地的 GPS 信息,以地图的形式展现出来。GPS 信息的验证,可下载 MagicEXIF 元数据编辑器 查看
不多说,一下为代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm2.aspx.cs" Inherits="Code.Test.WebForm2" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<input type="file" id="file_img" runat="server"/>
<asp:Button runat="server" Text="提取" ID="btn_zh" OnClick="btn_zh_Click"/>
<asp:Image runat="server" ID="Map" />
</div>
</form>
</body>
</html>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Text;
using System.Data;
using System.IO;
using System.Drawing.Imaging;
using System.Net;
using Newtonsoft.Json; namespace Code.Test
{
public partial class WebForm2 : System.Web.UI.Page
{
Code.SysManage.Commen.CommonTool commonTool = new SysManage.Commen.CommonTool();
public class MapConvert
{
public string error { get; set; }
public string x { get; set; }
public string y { get; set; }
}
protected void Page_Load(object sender, EventArgs e)
{ } #region 读取图片中GPS点 /// <summary>
/// 获取图片中的GPS坐标点
/// </summary>
/// <param name="p_图片路径">图片路径</param>
/// <returns>返回坐标【纬度+经度】用"+"分割 取数组中第0和1个位置的值</returns>
public String fnGPS坐标(String p_图片路径)
{
String s_GPS坐标 = "";
//载入图片
System.Drawing.Image objImage = System.Drawing.Image.FromFile(p_图片路径);
//取得所有的属性(以PropertyId做排序)
var propertyItems = objImage.PropertyItems.OrderBy(x => x.Id);
//暂定纬度N(北纬)
char chrGPSLatitudeRef = 'N';
//暂定经度为E(东经)
char chrGPSLongitudeRef = 'E';
foreach (PropertyItem objItem in propertyItems)
{
//只取Id范围为0x0000到0x001e
if (objItem.Id >= 0x0000 && objItem.Id <= 0x001e)
{
switch (objItem.Id)
{
case 0x0000:
var query = from tmpb in objItem.Value select tmpb.ToString();
string sreVersion = string.Join(".", query.ToArray());
break;
case 0x0001://北纬 N chrGPSLatitudeRef
chrGPSLatitudeRef = BitConverter.ToChar(objItem.Value, );
break;
case 0x0002://维度 strLatitude
if (objItem.Value.Length == )
{
//degrees(将byte[0]~byte[3]转成uint, 除以byte[4]~byte[7]转成的uint)
double d = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//minutes(將byte[8]~byte[11]转成uint, 除以byte[12]~byte[15]转成的uint)
double m = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//seconds(將byte[16]~byte[19]转成uint, 除以byte[20]~byte[23]转成的uint)
double s = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//计算经纬度数值, 如果是南纬, 要乘上(-1)
double dblGPSLatitude = (((s / + m) / ) + d) * (chrGPSLatitudeRef.Equals('N') ? : -);
string strLatitude = string.Format("{0:#}°{1:#}'{2:#.00}\"{3}", d
, m, s, chrGPSLatitudeRef);
//纬度
//s_GPS坐标 += "维度:" + dblGPSLatitude + "," + strLatitude + "|";
s_GPS坐标 += (dblGPSLatitude + "|");
}
break;
case 0x0003: //东经 chrGPSLongitudeRef
//透过BitConverter, 将Value转成Char('E' / 'W')
//此值在后续的Longitude计算上会用到
chrGPSLongitudeRef = BitConverter.ToChar(objItem.Value, );
break;
case 0x0004: //经度
if (objItem.Value.Length == )
{
//degrees(将byte[0]~byte[3]转成uint, 除以byte[4]~byte[7]转成的uint)
double d = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//minutes(将byte[8]~byte[11]转成uint, 除以byte[12]~byte[15]转成的uint)
double m = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//seconds(将byte[16]~byte[19]转成uint, 除以byte[20]~byte[23]转成的uint)
double s = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, );
//计算精度的数值, 如果是西经, 要乘上(-1)
double dblGPSLongitude = (((s / + m) / ) + d) * (chrGPSLongitudeRef.Equals('E') ? : -);
string strLongitude = string.Format("{0:#}°{1:#}'{2:#.00}\"{3}", d
, m, s, chrGPSLongitudeRef); //s_GPS坐标 += "经度:" + dblGPSLongitude + "," + strLongitude + "|";
s_GPS坐标 += (dblGPSLongitude + "|");
}
break;
case 0x0005://海平面
string strAltitude = BitConverter.ToBoolean(objItem.Value, ) ? "" : "";
s_GPS坐标 += "海平面:" + strAltitude + "|";
break;
case 0x0006://高度
if (objItem.Value.Length == )
{
//将byte[0]~byte[3]转成uint, 除以byte[4]~byte[7]转成的uint
double dblAltitude = BitConverter.ToUInt32(objItem.Value, ) * 1.0d / BitConverter.ToUInt32(objItem.Value, ); s_GPS坐标 += "水平高度:" + dblAltitude + "|";
}
break;
}
}
}
return s_GPS坐标;
} #endregion protected void btn_zh_Click(object sender, EventArgs e)
{ string picpath = commonTool.SaveImg(file_img, "News"); /*上传图片的方法,可自己重写*/
picpath = HttpContext.Current.Request.MapPath(picpath);
string Gpslocation = fnGPS坐标(picpath);/*获得GPS 信心,详细信息参考方法*/
Response.Write(Gpslocation);
//获取当前纬度
string Latitude = Gpslocation.Split('|')[];/*上传图片的方法,可自己重写*/ //获取当前经度
string Longitude = Gpslocation.Split('|')[]; //百度坐标转换API
string path = "http://api.map.baidu.com/ag/coord/convert?from=0&to=4&x=" + Longitude + "&y=" + Latitude + "";/*坐标纠正,生成百度地图的坐标*/ //WebClient请求
WebClient wc = new WebClient();
Stream stream = wc.OpenRead(path);
StreamReader sr = new StreamReader(stream);
MapConvert mapConvert = new MapConvert();
string strResult = sr.ReadToEnd();
Response.Write(strResult);
mapConvert = JsonConvert.DeserializeObject<MapConvert>(strResult);
string lon = mapConvert.x;
string lat = mapConvert.y;
//进行Base64解码
byte[] xBuffer = Convert.FromBase64String(lon);
string strX = Encoding.UTF8.GetString(xBuffer, , xBuffer.Length);
byte[] yBuffer = Convert.FromBase64String(lat);
string strY = Encoding.UTF8.GetString(yBuffer, , xBuffer.Length);
Response.Write(strX + ",");
Response.Write(strY);
//生成静态图片
string imgSrc = string.Format("http://api.map.baidu.com/staticimage?center={0},{1}&width=600&height=600&zoom=19&markers={2},{3}&markerStyles=l,A", strX, strY, strX, strY);/*此处生成静态地图,以显示是否正确,可自行修改*/ //显示图片
Map.ImageUrl = imgSrc;
}
} }
照片提取GPS 转成百度地图坐标的更多相关文章
- gps数据转百度地图坐标
昨天大叔问我一个关于gps的问题,一开始我是懵逼的,因为之前我从来没有接触过这玩意儿.稍微查了一下,gps协议包含了$开头和<>结尾,但这并不是重点.大叔告诉我说他们采集了一些位置的经纬度 ...
- GPS坐标转百度地图坐标
百度地图提供了相关API:BMap.Convertor.translate, 但是使用上存在部分限制:1.次数限制:2.异步回调 可以用如下方法: /** * 地图位置计算工具(将GPS坐标转换成百度 ...
- 百度和谷歌的逆地址解析及GPS、谷歌地图和百度地图坐标之间的转换(python版)
#!/usr/bin/env python # coding:utf-8 # @author: KaiVen """ GPS坐标转换: WGS-84:是国际标准,GPS坐 ...
- GPS定位为什么要转换处理?高德地图和百度地图坐标处理有什么不一样?
GPS定位为什么要转换处理?高德地图和百度地图坐标处理有什么不一样? 先了解一下 高德地图 采用: GCJ-02 (不可逆) 百度百科: http://baike.baidu.com/link?url ...
- GPS坐标转换为百度地图坐标
/** * GPS坐标转换为百度地图坐标 * 需要引入javabase64.jar 和json的一些包 * */ public class Gps2BaiDu { public static void ...
- 微信JS-SDK坐标位置转换为百度地图坐标
微信JS-SDK开发过程中,使用getLocation获取坐标位置,如何将微信获取的坐标直接应用到百度地图中,显示以下效果: 说明:红色图标是从微信转换过来的位置,蓝色图标是周边位置.首先从微信开发流 ...
- 百度地图坐标纠偏和转换工具和DLL
百度一直以来都是个即想装出一副拥抱互联网开放的样子,又为了短期商业利益封闭自己的公司,模仿谷歌地图,开放了自己的百度地图 API,为了防止别人盗用其数据和用户自由迁移,地图相比于火星坐标,又更加封闭, ...
- 手机端GPS定位结合百度地图实现定位
html页面: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Typ ...
- 获取ip ,百度地图坐标点 和 在 后台调用 url()
protected void getip() { string ips = HttpContext.Current.Request.UserHostA ...
随机推荐
- CG之基本光照模型计算公式
在一个基本模型里,一个物体表面的颜色是由放射(emissive).环境反射(ambient).漫反射(diffuse)和镜面反射(specular)等光照作用的总和.每种光照作用取决于表面材质的性质( ...
- HDU 1068 Girls and Boys 二分图最大独立集(最大二分匹配)
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- html-div-css
用CSS实现拉动滚动条时固定网页背景不动 body{ background-image: url(./inc/bgbk.jpg); background-attachm ...
- Android之事件分发
网上总结的很详细了,有时间总结下做个笔记
- JVM线程安全
一.线程的调度方式 线程调度分为两种方式: 协同式调度和抢占式调度.协同式调度:线程的执行时间由线程本身控制,线程将工作执行完之后,通知操作系统切换到其他线程上.缺点:时间不可控,就算出问题,也不会通 ...
- isKindOfClass,isMemberOfClass使用备忘
isMemberOfClass 判断是否是属于这类的实例isKindOfClass 判断是否是这个类或者这个类的子类的实例 if ([teacher isKindOfClass:[Teacher cl ...
- CSS排序工具csscomb
一. css写久了以后感觉需要按照某种规则或者说顺序来,便于开发和维护.O(∩_∩)O哈哈~ 找到一个 http://csscomb.com/ CSS排序总结: 1. 对css样式排序; 2. 按样式 ...
- jQuery简单实现图片预加载
我们在做网站的时候经常会遇到这样的问题:一个页面有大量的图片导致页面加载速度缓慢,经常会出现一个白页用户体验很不好.那么如何解决这个问题呢?下面我来介绍一种在实际应用中经常会使用到的js预加载的方法. ...
- iPhone Info.plist属性说明
1.) <key>BadgeStyle</key> 设置这个属性就是修改通知标记 出现在未接电话短信邮件的那个小数字 可以改变字体 颜色 位置等 2.) <key> ...
- 功率W与dBm的对照表及关系(转)
源:功率W与dBm的对照表及关系 功率W与dBm的对照表 dBm Watts dBm Watts 0 ...