• Stars
    star
    1,197
  • Rank 39,089 (Top 0.8 %)
  • Language
    Objective-C
  • License
    Apache License 2.0
  • Created over 12 years ago
  • Updated over 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A lightweight callout view class for iOS mimicking UICalloutView.

Example Screenshot

Overview

SMCalloutView aims to be an exact replica of the private UICalloutView system control.

We all love those "bubbles" you get when clicking pins in MKMapView. But sadly, it's impossible to present this bubble-style "Callout" UI anywhere outside MKMapView. Phooey! So this class painstakingly recreates this handy control for your pleasure.

Usage

To use SMCalloutView in your own projects, simply copy the files SMCalloutView.h and SMCalloutView.m.

SMCalloutView, by default, will render in the new style introduced with iOS 7. If you need the old style, simply include SMClassicCalloutView.h and SMClassicCalloutView.m in your project as well. There is a special class constructor, +[SMCalloutView platformCalloutView] which will automatically select the appropriate callout class for the current platform.

The comments in SMCalloutView.h do a lot of explaining on how to use the class, but the main function you'll need is presentCalloutFromRect:. You'll specify the view you'd like to add the callout to, as well as the rect defining the "target" that the popup should point at. The target rect should be in the coordinate system of the target view (just like the similarly- named UIPopover method). Most likely this will be target.frame if you're adding the callout view as a sibling of the target view, or it would be target.bounds if you're adding the callout view to the target itself.

You can study the included project's UIViewController subclasses for a working example.

Questions

How do I change the height of the callout?

If you use only the title/titleView/subtitle/subtitleView properties, the callout will always be the "system standard" height. If you assign the contentView property however, then the callout will size to fit the contentView and the other properties are ignored.

Can I customize the background graphics?

Yes, the callout background is an instance of SMCalloutBackgroundView. You can set your own custom View subclass to be the background, or you can use one of the built-in subclasses:

  • SMCalloutMaskedBackgroundView renders an iOS-7 style background.

  • SMCalloutImageBackgroundView lets you specify each of the image "fragments" that make up a horizontally-stretchable background.

  • SMCalloutDrawnBackgroundView draws the background at any size using CoreGraphics methods. You can copy the -drawRect method and change the parameters to suit your needs.

Can I use the callout with the Google Maps iOS SDK?

Check out ryanmaxwell's demo project for an example of one way to do this. (More discussion on this topic)

Have you recreated more of MapKit?

Nope, but other intrepid coders have!

  • For an awesome replacement of the pulsing blue "Current Location" dot, check out Sam Vermette's SVPulsingAnnotationView.

  • And for the outdoor map data and tiles themselves, check out Mapbox's iOS SDK, a complete open-source solution for custom maps. They even use SMCalloutView out of the box!

More Info

You can read more info if you wish in the blog post.

More Repositories

1

feeds

Keep tabs on your favorite website and RSS feeds from your Mac's menubar.
Objective-C
323
star
2

xmldocument

A lightweight XML Document class for iOS.
Objective-C
276
star
3

xmldoc

A lightweight XML Document class for JavaScript.
JavaScript
269
star
4

homebridge-dummy

Dummy switches for Homebridge: https://github.com/nfarina/homebridge
JavaScript
264
star
5

homebridge-tesla

Tesla plugin for homebridge: https://github.com/nfarina/homebridge
TypeScript
155
star
6

homebridge-sonos

Sonos plugin for homebridge: https://github.com/nfarina/homebridge
JavaScript
155
star
7

webrequest

A lightweight class for iOS for making asynchronous web requests.
Objective-C
102
star
8

modelobject

ObjC Model Object class using new language features.
Objective-C
69
star
9

dropdav

WebDAV frontend for Dropbox.
Python
66
star
10

homebridge-legacy-plugins

Legacy plugins for Homebridge: https://github.com/nfarina/homebridge
JavaScript
35
star
11

simpledav

Simple WebDAV Server for Google App Engine
Python
31
star
12

homebridge-liftmaster

LiftMaster support for Homebridge: https://github.com/nfarina/homebridge
JavaScript
23
star
13

homebridge-kevo

Kevo support for Homebridge: https://github.com/nfarina/homebridge
HTML
21
star
14

homebridge-eightsleep

Eight Sleep plugin for homebridge: https://github.com/nfarina/homebridge
TypeScript
11
star
15

homebridge-lockitron

Lockitron support for Homebridge: https://github.com/nfarina/homebridge
JavaScript
8
star
16

homebridge-icontrol

iControl (Xfinity Home) for Homebridge: https://github.com/nfarina/homebridge
JavaScript
7
star
17

homebridge-philipshue

PhilipsHue plugin for homebridge: https://github.com/nfarina/homebridge
JavaScript
3
star
18

pooljs

Manage parallel workers with optional rate limits
TypeScript
1
star
19

run

Executes scripts in your package.json much faster than NPM or Yarn, especially for projects using Yarn Workspaces. And with less typing.
TypeScript
1
star
20

homebridge-stack

Stack Lighting plugin for homebridge: https://github.com/nfarina/homebridge
1
star