Fingertips is a small library (one class) meant for presentations from iOS devices that shows all touches and gestures so that the audience can see them.
This library does not do the mirroring or screen recording for you!
Just drop in our replacement UIWindow
subclass and your app will automatically determine when you are in the screen recording or an external screen is available. It will show every touch on-screen with a nice partially-transparent graphic that automatically fades out when the touch ends.
If you are using storyboards, the easiest way to integrate Fingertips is to override the window
method of your application delegate like this:
// AppDelegate.m
- (UIWindow *)window {
if (!_window) {
_window = [[MBFingerTipWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
}
return _window;
}
// AppDelegate.swift (Swift)
var window: UIWindow? = FingerTipWindow(frame: UIScreen.main.bounds)
For iOS 13+ with UISceneDelegate:
var windows: [UIWindow] = []
func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
guard let windowScene = scene as? UIWindowScene else { return }
let window = FingerTipWindow(windowScene: windowScene)
window.rootViewController = // Your root view controller
window.makeKeyAndVisible()
windows.append(window)
}
Fingertips require iOS 11.0 or greater and ARC. It uses no private API and is safe for App Store submissions.
demo.mp4
You shouldn't need to configure anything, but if you want to tweak some knobs:
touchImage
: pass aUIImage
to use for showing touchestouchAlpha
: change the visible-touch alpha transparencyfadeDuration
: change how long lifted touches fade outstrokeColor
: change defaulttouchImage
stroke color (defaults to black)fillColor
: change defaulttouchImage
fill color (defaults to white)
If you ever need to debug Fingertips, just set the DEBUG_FINGERTIP_WINDOW
environment variable to YES
in Xcode or set the runtime property alwaysShowTouches
to YES
.
Copyright (c) 2011-2023 Mapbox, Inc.
The Fingertips library should be accompanied by a LICENSE file. This file contains the license relevant to this distribution. If no license exists, please contact Mapbox.