Streaming Measurement in iOS
This chapter describes the basic use of the sensor for the measurement of streaming content.
Properties of the Library
Property | Default | Description |
---|---|---|
tracking | true | If this property is set to |
offlineMode | false | If this property is set to |
debug | false | If the value is set to true , the debug messages are issued by the library |
timeout | 10 | Timeout Setting for the HTTP-Request |
...
Lifecycle of the Measurement
...
Note |
---|
The site name and application name is specified by the operator of the measurement system. |
...
From this point on, the method getInstance
must be used .
Code Block | ||||
---|---|---|---|---|
| ||||
KMA_SpringStreams *spring = [KMA_SpringStreams getInstance]; |
...
Implementation of the Adapter
...
Code Block | ||||
---|---|---|---|---|
| ||||
@protocol@interface KMA_Player_Meta <NSObject> @required -(NSString*) getPlayerName; -(NSString*) getPlayerVersion; -(int) getScreenWidth; -(int) getScreenHeight; @end @interface StreamAdapter : NSObject { } - (id) init:(NSObject *)stream; -(NSObject<Meta>: NSObject<NSCoding, NSCopying> { } @property (retain,readwrite) NSString *playername; @property (retain,readwrite) NSString *playerversion; @property (assign,readwrite) int screenwidth; @property (assign,readwrite) int screenheight; @end @protocol KMA_StreamAdapter @required -(KMA_Player_Meta*) getMeta; -(int) getPosition; -(int) getDuration; -(int) getWidth; -(int) getHeight; @end |
...
|
Beginning of the Measurement
This chapter explains step by step how a streaming content is transferred to the library for the measurement.
Info |
---|
In the library an adapter for class AVPlayerViewController from the AVKit ramework is settled. The source code for this implementation can be found in Appendix Anhang A and in the library. |
...
The following code block shows an example for the use of the library.
...
Then an NSDictionary is generated in order to formulate more detailed information about the stream. Therefore the attribute stream must always be specified
Info |
---|
The attribute |
...
Info |
---|
A stream is measured as long as the application is in the foreground. When the application goes into the background, the current status is transmitted to the measurement system and the measurement stops. If the stream should be measured again, when the application will come back to the foreground, the method |
...
End of the Measurement
After the measurement of a stream has been started, this stream is measured by the sensor. The measurement can be stopped by calling the method stop
on the stream object. All measurements will be automatically stopped by the library, when the application goes into the background.
...
Info |
---|
If the stream should be measured again, when the application comes to the foreground or after the method |
Foreground- and Background Actions
...
Info |
---|
Once the application is in the background all measurements in the library are stopped, i.e. when the application goes to the foreground, the measurement on a stream must be restarted. |
...
Code Block | ||||
---|---|---|---|---|
| ||||
... [[KMA_SpringStreams getInstance] unload]; |
Appendix A
Anchor | ||||
---|---|---|---|---|
|
In the following example, the adapter has been implemented for the media player
from the standard API.
Code Block |
---|
// // KMA_MediaPlayerAdapter.m // KMA_SpringStreams // // Created by Frank Kammann on 26.08.11. // Copyright 2011 spring GmbH & Co. KG. All rights reserved. // #import <MediaPlayer/MediaPlayer.h> #import <UIKit/UIKit.h> #import "KMA_SpringStreams.h" /** @class MediaPlayerMeta;* Implementation of @implementation MediaPlayerAdaptera KMA_StreamAdapter. MPMoviePlayerController* *controller; NSObject<Meta> *meta; @see - (id)adapter:(MPMoviePlayerController *)player { self = [super init:player]; if (self) { meta = [[MediaPlayerMeta alloc] meta:player]; } return self; } - (NSObject<Meta>*) getMeta { return meta; } - (int) getPosition { int position = (int)round([controller currentPlaybackTime]); // in initialize phase in controller this value is set to -2^31 if(position < 0) position = 0; return position; } - (int) getDuration { return (int)round([controller duration]); } - (int) getWidth { return controller.view.bounds.size.width; } - (int) getHeight { return controller.view.bounds.size.height; } - (void)dealloc { [meta release]; [super dealloc]; } @end @implementation MediaPlayerMeta MPMoviePlayerController *controller; - (id) meta:(MPMoviePlayerController *)player { self = [super init]; if (self) { if(player == nil)KMA_StreamAdapter */ @implementation KMA_MediaPlayerAdapter AVPlayerViewController *controller; KMA_Player_Meta *meta; /** * Initialize the adapter with the MPMoviePlayerController * * @see http://developer.apple.com/library/ios/#documentation/mediaplayer/reference/MPMoviePlayerController_Class/Reference/Reference.html * */ - (KMA_MediaPlayerAdapter*)adapter:(AVPlayerViewController *)player { //if (self) { meta = [[KMA_Player_Meta alloc] init]; meta.playername = @"AVPlayerViewController"; controller = player; //} return [super init]; } /** * Returns the meta object. * * @see MediaPlayerMeta */ - (KMA_Player_Meta*) getMeta { return meta; } /** * Returns the current position on the KMA_Stream in seconds by calling * the method MPMediaPlayback.currentPlaybackTime * * @see http://developer.apple.com/library/ios/#documentation/mediaplayer/reference/MPMediaPlayback_protocol/Reference/Reference.html#//apple_ref/occ/intf/MPMediaPlayback# */ - (int) getPosition { int position = CMTimeGetSeconds(controller.player.currentItem.currentTime); // in initialize phase in controller this value is set to -2^31 if(position < 0) position = 0; return position; } /** * Returns the duration of the KMA_Stream in seconds by calling * the method MPMediaPlayback.duration. * */ - (int) getDuration { return CMTimeGetSeconds(controller.player.currentItem.duration); } /** * Returns the width by the controller view. * * @return contoller.view.bound.size.width */ - (int) getWidth { return controller.view.bounds.size.width; } /** * Returns the height by the controller view. * * @return contoller.view.bound.size.height */ - (int) getHeight { return controller.view.bounds.size.height; } @end @implementation KMA_Player_Meta /** * Returns the player name * * @return the string "MediaPlayer" */ @synthesize playername; /** * Returns the player version. * The itselfs has no version so the system version is delivered. * * @see http://developer.apple.com/library/ios/#documentation/uikit/reference/UIDevice_Class/Reference/UIDevice.html * * @return The version my calling [UIDevice currentDevice].systemVersion */ @synthesize playerversion; /** * Returns the screen width my calling the method * [[UIScreen mainScreen] bounds].screenRect.size.width * * @see http://developer.apple.com/library/ios/#documentation/uikit/reference/UIScreen_Class/Reference/UIScreen.html * * @return the width */ @synthesize screenwidth; /** * Returns the screen width my calling the method * [[UIScreen mainScreen] bounds].screenRect.size.height * * @see http://developer.apple.com/library/ios/#documentation/uikit/reference/UIScreen_Class/Reference/UIScreen.html * * @return the height */ @synthesize screenheight; - (id) init { self = [super init]; if (self) { self.playername = @"iOS Player"; self.playerversion = [UIDevice currentDevice].systemVersion; CGRect screenRect = [[UIScreen mainScreen] bounds]; self.screenwidth = screenRect.size.width; self.screenheight = screenRect.size.height; } return self; } - (id) copyWithZone:(NSZone *)zone { id copy = [[[self class] alloc] init]; if (copy) { // Copy NSObject subclasses [copy setPlayername:[self.playername copyWithZone:zone]]; [copy setPlayerversion:[self.playerversion copyWithZone:zone]]; // Set primitives @throw [NSException exceptionWithName:@"IllegalArgumentException" [copy setScreenwidth:self.screenwidth]; [copy setScreenheight:self.screenheight]; } return copy; } - (NSString *)description { return reason[NSString stringWithFormat:@"playerMeta may not be null"pl=%@ plv=%@ sx=%ld sy=%ld", self.playername, self.playerversion, (long)self.screenwidth, userInfo:nil]; (long)self.screenheight]; } controller = player; - (void)encodeWithCoder:(NSCoder *)encoder { } [encoder return self; } - (NSString*) getPlayerName {encodeObject:self.playername forKey:@"playername"]; [encoder encodeObject:self.playerversion forKey:@"playerversion"]; return [encoder encodeInt:self.screenwidth forKey:@"MediaPlayerscreenwidth"]; } - (NSString*) getPlayerVersion { return [UIDevice currentDevice].systemVersion [encoder encodeInt:self.screenheight forKey:@"screenheight"]; } - (intid) getScreenWidthinitWithCoder:(NSCoder *)decoder { CGRect screenRectself.playername = [[UIScreen mainScreen] bounds];decoder decodeObjectForKey:@"playername"]; self.playerversion = return screenRect.size.width; } - (int) getScreenHeight { [decoder decodeObjectForKey:@"playerversion"]; self.screenwidth = [decoder decodeIntForKey:@"screenwidth"]; CGRect screenRectself.screenheight = [[UIScreen mainScreen] bounds]decoder decodeIntForKey:@"screenheight"]; return screenRect.size.heightself; } @end |
Implementation of the URL Scheme in iOS
...
you can edit it in any editor, if you do so, please insert the following code:
Code Block <key>CFBundleURLTypes</key> <array> <dict> <key>CFBundleURLName</key> <string>***</string> //please change *** to your URL name, not so important <key>CFBundleURLSchemes</key> <array> <string>***</string> //very important, please replace </array> </dict> </array>
Or you can edit this in xcode, add an item into
Info.plist
, named "URL types", expand "Item 0" under "URL types", and add two items: "URL identifier", "URL Schemes".For "URL identifier", assign your identifier, and for "URL Schemes", add a new item within it named "Item0", REGISTER A UNIQUE URL SCHEME FOR YOUR APP, VERY IMPORTANT!
It should be like the following:
How to use the different Files in the Library Package
File | Description |
---|---|
spring-appsensor-device.a | This is the version that has been compiled with ARM support and which is intended for execution on iOS devices |
spring-appsensor-simulator.a | This is the version that has been compiled with x86 support and which is intended for execution on iOS simulator |
spring-appsensor-fat.a | This is a combined version of the two libraries above, which can be executed on both, iOS devices and iOS simulator because it contains code for ARM and x86 execution. This file is called "fat" as it is roughly double the size (because it combines both versions). |
Note |
---|
If size does not matter for the app, the "fat" version is the carefree option to be used for execution on simulator and real devices. |
Include Page | ||||
---|---|---|---|---|
|