`
byandby
  • 浏览: 1697751 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

android 使用覆盖图

阅读更多
先提示 几点
     我们创建 项目的时候 要选择 Google APIs  不要选择 Android。

     要使用 谷歌地图 我们需要一个 api key密钥,至于怎么得到密钥 大家自己去 搜搜吧,如果下载这个例子的源码,需要把我例子里边的 密钥 替换成 自己的。

    我们要在 AdnroidManifest.xml中 引用地图库 加上这一句
  
 <uses-library android:name="com.google.android.maps"/>


再说一下MapView和MapActivity
    Android中的许多地图技术都依赖于 MapView UI控件和 android.app.Activity的扩展MapActivity。在Android中,MapView和MapActivity类负责显示和操作地图的主要工作。关于这两个类,必须记住的一点是,它们必须协同工作。具体来讲,要使用MapView,需要在MapActivity中对它进行实例化。此外,当实例化 MapView时,需要提供 map-api密钥,如果使用XML布局实例化 MapView,则需要设置 android:apiKey 属性。如果以编程的方式创建 MapView,则必须将map-api密钥传递给MapView构造器,最后由于地图的基础数据来自Google Maps,所以我们还需要点权限,具体有以下三个权限。
我们还得需要点权限 三个

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>

此权限可用于获取详细的位置数据,比如GPS 数据。

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>

此权限用于获取大概位置信息 比如 WiFi 位置信息。

<uses-permission android:name="android.permission.INTERNET"/>

访问网络的权限。
来张我AndroidManifest.xml的截图吧。



下面介绍 使用覆盖地图
      其实,就是要实现这样的功能 比如我们在Google Map 查询鸟巢 我们在鸟巢这个位置上放置 一个图钉或者气球 来标记这个位置。Google Maps 通过在地图上添加另外一层来实现此功能。Android 提供了多个类来帮助在地图上添加层。实现此类功能的一个关键类是 Overlay,也可以使用此类的扩展类 ItemizedOverlay,下面是我们自己定义的MapActivity。
package xiaohang.zhimeng;

import java.util.ArrayList;
import java.util.List;
import com.google.android.maps.GeoPoint;
import com.google.android.maps.ItemizedOverlay;
import com.google.android.maps.MapActivity;
import com.google.android.maps.MapView;
import com.google.android.maps.OverlayItem;
import android.graphics.Canvas;
import android.graphics.drawable.Drawable;
import android.os.Bundle;

public class MappingOverlayActivity extends MapActivity {
	private MapView mapView;

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		mapView = (MapView) findViewById(R.id.mapview);
		mapView.setBuiltInZoomControls(true);
		// 设置地图是否可以左右移动
		mapView.setClickable(true);
		Drawable marker = getResources().getDrawable(R.drawable.mapmarder);
		marker.setBounds(0, 0, marker.getIntrinsicWidth(),
				marker.getIntrinsicHeight());
		InterestingLocations funPlaces = new InterestingLocations(marker);
		// 获取Overlay列表
		mapView.getOverlays().add(funPlaces);
		// 默认情况下,返回第一级别的item。必须首先调用populate()。
		GeoPoint pt = funPlaces.getCenter(); // get the first-ranked point
		mapView.getController().setCenter(pt);
		// 设置显示卫星图
		mapView.setSatellite(true);
		// 设置地图的缩放级别。这个值的取值范围是[1,21],
		mapView.getController().setZoom(15);
	}

	@Override
	protected boolean isRouteDisplayed() {
		return false;
	}

	@Override
	protected boolean isLocationDisplayed() {
		return false;
	}

	class InterestingLocations extends ItemizedOverlay {
		private List<OverlayItem> locations = new ArrayList<OverlayItem>();
		private Drawable marker;

		public InterestingLocations(Drawable defaultMarker) {
			super(defaultMarker);
			this.marker = defaultMarker;
			// 经度:116.3901686668396
			// 纬度:39.99112812994946
			/*
			 * 经度、维度必须转换为微度可以乘以1000000 然后转换为int类型 (API只能处理微度)
			 */
			GeoPoint niaochao = new GeoPoint(
					(int) (39.99112812994946 * 1000000),
					(int) (116.3901686668396 * 1000000));
			locations.add(new OverlayItem(niaochao, "鸟巢",
					"production  Birdy Bird"));
			populate();
		}

		@Override
		public void draw(Canvas canvas, MapView mapView, boolean shadow) {
			super.draw(canvas, mapView, shadow);
			// 定义锚点显示在底部的中央
			boundCenterBottom(marker);
			// 定义锚点在中心位置可以调用 boundCenter()方法
		}

		@Override
		protected OverlayItem createItem(int i) {
			return locations.get(i);
		}

		@Override
		public int size() {
			return locations.size();
		}

	}
}


   布局文件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<com.google.android.maps.MapView
		android:id="@+id/mapview"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:clickable="true"
		android:apiKey="0XemFEdFemEDqY3dE3Ko9ELJX12MRLjJGKEJ01g"/>
</RelativeLayout>

     运行效果图



     为了将标记添加到地图上,必须创建 com.google.android.maps.Overlay 的扩展类并将其添加到地图上。 Overlay类本身无法实例化,所以必须扩展它或使用一个现有的扩展。在我们的示例中,实现了 InterestingLocations,它扩展了 ItemizedOverlay,而后者又扩展了Overlay。Overlay类定义了覆盖地图的契约,ItemizedOverlay 是一个很方便的实现,它简化了创建可在地图上标记的一组位置的过程。

        一般使用模式是扩展 ItemizedOverlay 类并在构造函数中添加 “项”----------感兴趣的位置。实例化兴趣点之后,调用ItemizedOverlay的populate()方法。populate()方法是一个实用程序,用于缓存OverlayItem。在内部,该类调用 size()方法来确定覆盖项的数量,然后进入循环,为每个项调用 createItem(i)。在createItem 方法中,返回数组中给定索引处已经创建的项目。

      从上面的代码中我们可以看出,我们只是创建了一些点,并调用 populate()在地图上显示标记。Overlay 负责执行剩余的工作,为了正确显示这些标记,Activity的onCreate()方法创建InterestingLocations实例,传入用于表示标记的Drawable。然后 onCreate()将 Interesting-Location 实例添加到覆盖图集合 (mapView.getOverlays().add())中。

     如果大家还有一个方法弄不太清楚,可以去看看 Google Maps for Android API 这里感谢高德软件公司给我们翻译了,呵呵。他们有自己的一套API 兼容 google的那套。都差不多,但是他们的是中文的  汗一把。猛点这里http://code.autonavi.com/android/code 建议大家去看看,还有最后关于怎么获取经纬度大家点这里http://www.williamlong.info/archives/941.html
  • 大小: 83.8 KB
  • 大小: 67.8 KB
  • 大小: 63 KB
3
1
分享到:
评论

相关推荐

    Android百度地图覆盖层

    通过阅读和学习这些代码,你可以更深入地理解和掌握Android百度地图覆盖层的使用。 总之,Android百度地图覆盖层是实现地图应用个性化和功能扩展的关键技术,它涉及到地图对象的绘制、交互以及动态更新等多个方面。...

    Android 百度地图覆盖物.zip

    总结来说,"Android 百度地图覆盖物.zip"提供的示例代码涵盖了在Android中使用百度地图API添加自定义覆盖物的关键技术,包括自定义样式、异步加载网络图片等。通过理解和学习这个例子,开发者可以更好地掌握如何在...

    android工程JaCoCo代码覆盖率Demo

    在Android开发中,JaCoCo是一个非常重要的工具,它用于计算和分析代码覆盖率,帮助开发者了解测试用例对代码的覆盖程度。JaCoCo不仅适用于Java项目,而且在Android项目中同样发挥着关键作用,尤其是在确保测试质量、...

    Android内容覆盖透明状态栏下实现全屏模式下带状态栏的效果

    在Android应用开发中,全屏模式并同时保持状态栏可见且部分内容覆盖状态栏是一种常见的设计需求,这可以为用户带来沉浸式的体验。标题所提到的"Android内容覆盖透明状态栏下实现全屏模式下带状态栏的效果"正是针对这...

    android调用百度地图的覆盖层

    本篇将详细讲解如何在Android应用中调用百度地图并实现自定义覆盖层,以便将数据可视化地展示在地图上。 首先,我们需要在Android项目中引入百度地图SDK。在`build.gradle`文件中添加依赖: ```groovy ...

    Android百度地图添加覆盖物

    当地图加载完成后,我们就可以添加覆盖物了。百度地图API提供了多种类型的覆盖物,如Marker、InfoWindow、OverlayItem等。以添加一个简单的Marker为例: ```java LatLng myLocation = new LatLng(39.913851, 116....

    Android Native C++代码覆盖率统计 Demo(基于NDK 21)

    本Demo主要介绍如何在Android环境中使用NDK 21来实现对C++代码的覆盖率统计。下面我们将深入探讨这个主题。 首先,代码覆盖率是衡量软件测试完整性的一个重要指标,它反映了测试用例执行时覆盖了多少源代码。对于...

    android版本城际通覆盖文件

    综上所述,"android版本城际通覆盖文件"的核心知识点涵盖了Android应用中的动态链接库使用、资源管理、广告集成、版本兼容性以及安全性和权限管理等方面,这些都是Android开发者在构建和优化应用时必须考虑的关键...

    Android 【覆盖/忽略/取消】对话框

    本主题将深入探讨Android中的"覆盖/忽略/取消"对话框及其使用方法。 一、覆盖对话框(AlertDialog) 覆盖对话框是Android中最基础的对话框类型,通常包含一个标题、一个消息文本以及一到三个操作按钮。创建覆盖...

    Android带图片背景的span

    "Android带图片背景的span"这个话题就是关于如何在TextView中创建具有图片背景的可操作文本片段(Span)。 Span在Android文本处理中扮演着重要角色,它允许我们对文本进行格式化,如改变颜色、大小、字体等。这里...

    安卓进度条loadingprogress相关-这是一款android进度条自定义的控件用到了混合模式进度条覆盖到文字的时候覆盖到哪里哪里变成白色.rar

    "安卓进度条loadingprogress相关-这是一款android进度条自定义的控件用到了混合模式进度条覆盖到文字的时候覆盖到哪里哪里变成白色.rar"这个压缩包文件包含了一个独特的进度条控件设计,它将混合模式运用到了进度条...

    android 界面覆盖

    实现界面覆盖,开发者通常会使用Android的ViewGroup,如FrameLayout或RelativeLayout,将覆盖层视图添加到布局的顶部,并通过调整其透明度和位置来实现所需效果。 接着,我们来看“界面引导”(Onboarding)。界面...

    Android 图片浏览全屏缩放

    综上所述,实现“Android 图片浏览全屏缩放”的功能涉及到了图片加载库的选择与使用,自定义ImageView处理手势检测,以及使用ViewPager实现图片的滑动切换。通过这些技术的组合,我们可以创建出流畅、高性能的图片...

    安卓Android源码——SurfaceView添加组件view不被组件覆盖.zip

    `Android SurfaceView添加组件view不被组件覆盖` 这个文件可能是示例代码或者详细教程,里面应该包含了如何将这些概念应用到实际项目中的具体步骤。 总的来说,处理 `SurfaceView` 与其他组件的层次关系是安卓开发...

    android图片上添加文字

    在Android开发中,将文字添加到图片上的需求十分常见,比如在地图应用中进行位置标注、制作信息图或者个性化头像等。以下是一些关于如何在Android图片上添加文字的关键知识点: 1. **画布与Bitmap**: 在Android中,...

    Android-realTimeBlurView2一个实时高斯模糊方案支持任意图形(只要你能画出来)任意覆盖色

    "Android-realTimeBlurView2"是一个专为Android平台设计的实时高斯模糊解决方案,它允许开发者实现任意图形的高斯模糊效果,并且可以自定义覆盖颜色,极大地提升了UI设计的灵活性和创意性。 一、高斯模糊原理 高斯...

    android图片处理工具

    总的来说,Android图片处理工具覆盖了从基础的Bitmap操作到复杂的计算机视觉算法,为开发者提供了丰富的选择。理解并熟练运用这些工具,能够帮助我们打造出更高效、用户体验更佳的Android应用。

    Android源码——SurfaceView添加组件view不被组件覆盖.zip

    通过结合这些图片和上述理论知识,开发者可以更好地解决SurfaceView覆盖问题,实现更丰富的用户界面设计。 总之,理解和掌握SurfaceView的工作机制以及Android的布局管理是解决此类问题的关键。通过合理利用Android...

    Android 图片叠加banner效果 仿mac QQ音乐图片轮播

    综上所述,实现"Android 图片叠加banner效果 仿mac QQ音乐图片轮播"涉及到Android的基础组件使用、自定义View的开发、图片处理技术以及动画效果的添加。通过这些技术的结合,我们可以创建出具有专业水准的图片轮播...

Global site tag (gtag.js) - Google Analytics