Skip to content

Commit

Permalink
Merge pull request #141 from mamaral/issues
Browse files Browse the repository at this point in the history
Issues
  • Loading branch information
mamaral authored Jul 10, 2016
2 parents b21ed2d + 6902e09 commit 7ff095b
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 50 deletions.
4 changes: 2 additions & 2 deletions Onboard.podspec
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
Pod::Spec.new do |s|

s.name = "Onboard"
s.version = "2.2.0"
s.version = "2.2.1"
s.summary = "Create a beautiful and engaging onboarding experience with only a few lines of code."
s.homepage = "https://github.com/mamaral/Onboard"
s.license = "MIT"
s.author = { "Mike Amaral" => "[email protected]" }
s.social_media_url = "http://twitter.com/MikeAmaral"
s.platform = :ios
s.source = { :git => "https://github.com/mamaral/Onboard.git", :tag => "v2.2.0" }
s.source = { :git => "https://github.com/mamaral/Onboard.git", :tag => "v2.2.1" }
s.source_files = "Source/OnboardingViewController.{h,m}", "Source/OnboardingContentViewController.{h,m}"
s.requires_arc = true

Expand Down
4 changes: 2 additions & 2 deletions Source/OnboardingViewController.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@

#import <UIKit/UIKit.h>
#import "OnboardingContentViewController.h"
@import MediaPlayer;
@import AVKit;

@interface OnboardingViewController : UIViewController <UIPageViewControllerDataSource, UIPageViewControllerDelegate, UIScrollViewDelegate, OnboardingContentViewControllerDelegate>

Expand Down Expand Up @@ -93,7 +93,7 @@
/**
* @brief The movie player controller used to play background movies.
*/
@property (nonatomic) MPMoviePlayerController *moviePlayerController;
@property (nonatomic, strong) AVPlayerViewController *moviePlayerController;


/**
Expand Down
82 changes: 36 additions & 46 deletions Source/OnboardingViewController.m
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@

#import "OnboardingViewController.h"
#import "OnboardingContentViewController.h"
@import AVFoundation;
@import Accelerate;

static CGFloat const kPageControlHeight = 35;
Expand All @@ -26,6 +27,7 @@ @interface OnboardingViewController ()
@property (nonatomic, strong) OnboardingContentViewController *upcomingPage;

@property (nonatomic, strong) UIPageViewController *pageVC;
@property (nonatomic, strong) AVPlayer *player;
@property (nonatomic, strong) NSURL *videoURL;

@end
Expand Down Expand Up @@ -107,12 +109,6 @@ - (instancetype)initWithContents:(NSArray *)contents {
[self.skipButton setTitle:kSkipButtonText forState:UIControlStateNormal];
[self.skipButton addTarget:self action:@selector(handleSkipButtonPressed) forControlEvents:UIControlEventTouchUpInside];
self.skipButton.titleLabel.adjustsFontSizeToFitWidth = YES;

// Create the movie player controller
self.moviePlayerController = [MPMoviePlayerController new];

// Handle when the app enters the foreground.
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleAppEnteredForeground) name:UIApplicationWillEnterForegroundNotification object:nil];

return self;
}
Expand All @@ -131,26 +127,26 @@ - (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];

// if we have a video URL, start playing
if (_videoURL) {
[self.moviePlayerController play];
if (self.videoURL) {
[self.player play];
}
}

- (void)viewWillDisappear:(BOOL)animated {
[super viewWillDisappear:animated];
if (self.moviePlayerController.playbackState == MPMoviePlaybackStatePlaying && self.stopMoviePlayerWhenDisappear) {
[self.moviePlayerController stop];

if ((self.player.rate != 0.0) && (self.player.error == nil) && self.stopMoviePlayerWhenDisappear) {
[self.player pause];
}
}

- (void)generateView {
// create our page view controller
_pageVC = [[UIPageViewController alloc] initWithTransitionStyle:UIPageViewControllerTransitionStyleScroll navigationOrientation:UIPageViewControllerNavigationOrientationHorizontal options:nil];
_pageVC.view.frame = self.view.frame;
_pageVC.view.backgroundColor = [UIColor whiteColor];
_pageVC.delegate = self;
_pageVC.dataSource = self.swipingEnabled ? self : nil;
self.pageVC = [[UIPageViewController alloc] initWithTransitionStyle:UIPageViewControllerTransitionStyleScroll navigationOrientation:UIPageViewControllerNavigationOrientationHorizontal options:nil];
self.pageVC.view.frame = self.view.frame;
self.pageVC.view.backgroundColor = [UIColor whiteColor];
self.pageVC.delegate = self;
self.pageVC.dataSource = self.swipingEnabled ? self : nil;

if (self.shouldBlurBackground) {
[self blurBackground];
Expand All @@ -172,9 +168,9 @@ - (void)generateView {
// darkens it a bit for better contrast
UIView *backgroundMaskView;
if (self.shouldMaskBackground) {
backgroundMaskView = [[UIView alloc] initWithFrame:_pageVC.view.frame];
backgroundMaskView = [[UIView alloc] initWithFrame:self.pageVC.view.frame];
backgroundMaskView.backgroundColor = [UIColor colorWithWhite:0.0 alpha:kBackgroundMaskAlpha];
[_pageVC.view addSubview:backgroundMaskView];
[self.pageVC.view addSubview:backgroundMaskView];
}

// set ourself as the delegate on all of the content views, to handle fading
Expand All @@ -187,27 +183,29 @@ - (void)generateView {
_currentPage = [self.viewControllers firstObject];

// more page controller setup
[_pageVC setViewControllers:@[_currentPage] direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:nil];
_pageVC.view.backgroundColor = [UIColor clearColor];
[self addChildViewController:_pageVC];
[self.view addSubview:_pageVC.view];
[_pageVC didMoveToParentViewController:self];
[_pageVC.view sendSubviewToBack:backgroundMaskView];
[self.pageVC setViewControllers:@[self.currentPage] direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:nil];
self.pageVC.view.backgroundColor = [UIColor clearColor];
[self addChildViewController:self.pageVC];
[self.view addSubview:self.pageVC.view];
[self.pageVC didMoveToParentViewController:self];
[self.pageVC.view sendSubviewToBack:backgroundMaskView];

// send the background image view to the back if we have one
if (backgroundImageView) {
[_pageVC.view sendSubviewToBack:backgroundImageView];
[self.pageVC.view sendSubviewToBack:backgroundImageView];
}

// otherwise send the video view to the back if we have one
else if (_videoURL) {
self.moviePlayerController.contentURL = _videoURL;
self.moviePlayerController.view.frame = _pageVC.view.frame;
self.moviePlayerController.repeatMode = MPMovieRepeatModeOne;
self.moviePlayerController.controlStyle = MPMovieControlStyleNone;
else if (self.videoURL) {
self.player = [[AVPlayer alloc] initWithURL:self.videoURL];

self.moviePlayerController = [AVPlayerViewController new];
self.moviePlayerController.player = self.player;
self.moviePlayerController.view.frame = self.pageVC.view.frame;
self.moviePlayerController.showsPlaybackControls = NO;

[_pageVC.view addSubview:self.moviePlayerController.view];
[_pageVC.view sendSubviewToBack:self.moviePlayerController.view];
[self.pageVC.view addSubview:self.moviePlayerController.view];
[self.pageVC.view sendSubviewToBack:self.moviePlayerController.view];
}

// create and configure the page control
Expand All @@ -224,22 +222,14 @@ - (void)generateView {
// so we can set ourself as the delegate, this is sort of hackish but the only current
// solution I am aware of using a page view controller
if (self.shouldFadeTransitions) {
for (UIView *view in _pageVC.view.subviews) {
for (UIView *view in self.pageVC.view.subviews) {
if ([view isKindOfClass:[UIScrollView class]]) {
[(UIScrollView *)view setDelegate:self];
}
}
}
}

- (void)handleAppEnteredForeground {
// If the movie player is paused, as it does by default when backgrounded, start
// playing again.
if (self.moviePlayerController.playbackState == MPMoviePlaybackStatePaused) {
[self.moviePlayerController play];
}
}


#pragma mark - Skipping

Expand Down Expand Up @@ -407,7 +397,7 @@ - (void)moveNextPage {
NSUInteger indexOfNextPage = [self.viewControllers indexOfObject:_currentPage] + 1;

if (indexOfNextPage < self.viewControllers.count) {
[_pageVC setViewControllers:@[self.viewControllers[indexOfNextPage]] direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:nil];
[self.pageVC setViewControllers:@[self.viewControllers[indexOfNextPage]] direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:nil];
[self.pageControl setCurrentPage:indexOfNextPage];
}
}
Expand Down Expand Up @@ -450,22 +440,22 @@ - (void)scrollViewDidScroll:(UIScrollView *)scrollView {
// fade the page control to and from the last page
if (self.fadePageControlOnLastPage) {
if (transitioningToLastPage) {
_pageControl.alpha = percentCompleteInverse;
self.pageControl.alpha = percentCompleteInverse;
}

else if (transitioningFromLastPage) {
_pageControl.alpha = percentComplete;
self.pageControl.alpha = percentComplete;
}
}

// fade the skip button to and from the last page
if (self.fadeSkipButtonOnLastPage) {
if (transitioningToLastPage) {
_skipButton.alpha = percentCompleteInverse;
self.skipButton.alpha = percentCompleteInverse;
}

else if (transitioningFromLastPage) {
_skipButton.alpha = percentComplete;
self.skipButton.alpha = percentComplete;
}
}
}
Expand Down

0 comments on commit 7ff095b

Please sign in to comment.