Git Product home page Git Product logo

android-mapviewballoons's Introduction

Android MapView Balloons

DEPRECATED

Please use Google Maps Android API v2: https://developers.google.com/maps/documentation/android/

This project provides an easy way to annotate map overlay items with a simple information balloon when using the Android Maps external library (com.google.android.maps). It consists of BalloonOverlayView, a view representing the balloon that is displayed over your MapView and BalloonItemizedOverlay, an abstract extension of ItemizedOverlay.

Balloon  Balloon Pressed  Balloon2

Basic Usage

Create a subclass of BalloonItemizedOverlay in the same way you would do for the base ItemizedOverlay class. Rather than overriding onTap() (which is already implemented and final in the subclass to invoke the balloon view display for each item tap), you override onBalloonTap() to handle a screen tap event on the balloon itself.

The data displayed in each balloon is mapped to the title and snippet arguments you provide to the constructor of each OverlayItem.

The repository contains a working sample application project which fully demonstrates its usage.

Custom Layouts

custom

You can create your own balloon look & feel and custom data mapping by creating a subclass of BalloonOverlayView with a generic type that extends OverlayItem. Override the setupView(Context context, final ViewGroup parent) method and inflate your own XML layout using parent as the root of its view hierarchy.

One caveat with custom layouts is that you MUST include a layout container that represents the clickable action area of your balloon whose id property is android:id="@id/balloon_inner_layout".

An example custom layout and data mapping which downloads an image from the internet and displays it in an ImageView is included in the sample application project.

TapControlledMapView

This library also includes TapControlledMapView - an optional custom MapView implementation which can be used to more closely mimic behaviour of Google Maps for Android and the iOS MapKit component, such as double-tap to zoom and single-tap to dismiss a balloon.

Refer to the example Activity included in the sample application project.

Amazon Maps API & Kindle Fire

kindle

This library supports the alternative Amazon Maps API found on devices such as the 2nd generation Kindle Fire and Kindle Fire HD.

To enable Amazon Maps API support you should follow the Google Maps API migration instructions found at developer.amazon.com. Switch to the amazon-maps-api-support branch in this repository for an example. The library must be modified to use the com.amazon.geo.maps imports. You can use the mapimports.sh script to toggle between Google and Amazon APIs. This project does not currently provide a way to support both APIs in a single build.

Implementation

This project is implemented as an Android Library project. Refer to Referencing a library project in this document for instructions on how to include it in your own Android project. Ensure you have the latest Android SDK, tools and Eclipse plugin installed.

To install the library and sample project in Eclipse:

  • Select File, Import, Existing projects into workspace...
  • Select the root folder where you cloned/downloaded the repository to import both projects.
  • Use Project - Clean if there are any errors.

Credits

Author: Jeff Gilfelt

The code in this project is licensed under the Apache Software License 2.0.
Copyright © 2012 readyState Software Ltd.

android-mapviewballoons's People

Contributors

adamcohenrose avatar jgilfelt avatar laalto avatar stefanbossbaly avatar wellsie1116 avatar westonplatter avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.