From e43acfca695c3b964ec8f2421fb436382d5cbb32 Mon Sep 17 00:00:00 2001 From: Darius Sabaliauskas Date: Wed, 21 May 2014 14:41:28 +0300 Subject: [PATCH] Switch to simple mode without fancy animation added --- RESideMenu/RESideMenu.h | 2 ++ RESideMenu/RESideMenu.m | 61 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 63 insertions(+) diff --git a/RESideMenu/RESideMenu.h b/RESideMenu/RESideMenu.h index 7e358035..46c1d312 100644 --- a/RESideMenu/RESideMenu.h +++ b/RESideMenu/RESideMenu.h @@ -45,6 +45,8 @@ @property (strong, readwrite, nonatomic) UIViewController *rightMenuViewController; @property (weak, readwrite, nonatomic) id delegate; +@property (assign, readwrite, nonatomic) BOOL simpleMode; + @property (assign, readwrite, nonatomic) NSTimeInterval animationDuration; @property (strong, readwrite, nonatomic) UIImage *backgroundImage; @property (assign, readwrite, nonatomic) BOOL panGestureEnabled; diff --git a/RESideMenu/RESideMenu.m b/RESideMenu/RESideMenu.m index fca46701..f47abe1d 100644 --- a/RESideMenu/RESideMenu.m +++ b/RESideMenu/RESideMenu.m @@ -116,6 +116,41 @@ - (void)commonInit _contentViewScaleValue = 0.7f; } +#pragma mark - +#pragma mark Getters (Simple mode) + +- (BOOL)scaleContentView +{ + if (self.simpleMode) { + return NO; + } + return _scaleContentView; +} + +- (BOOL)scaleMenuView +{ + if (self.simpleMode) { + return NO; + } + return _scaleMenuView; +} + +- (BOOL)scaleBackgroundImageView +{ + if (self.simpleMode) { + return NO; + } + return _scaleBackgroundImageView; +} + +- (BOOL)parallaxEnabled +{ + if (self.simpleMode) { + return NO; + } + return _parallaxEnabled; +} + #pragma mark - #pragma mark Public methods @@ -566,9 +601,14 @@ - (void)panGestureRecognized:(UIPanGestureRecognizer *)recognizer } if (recognizer.state == UIGestureRecognizerStateChanged) { + CGFloat contentOffset = UIInterfaceOrientationIsLandscape([[UIApplication sharedApplication] statusBarOrientation]) ? self.contentViewInLandscapeOffsetCenterX : self.contentViewInPortraitOffsetCenterX; + CGFloat maxPanWidth = self.contentViewContainer.bounds.size.width/2 + contentOffset; + CGFloat delta = 0; if (self.visible) { delta = self.originalPoint.x != 0 ? (point.x + self.originalPoint.x) / self.originalPoint.x : 0; + } else if (self.simpleMode) { + delta = point.x / maxPanWidth; } else { delta = point.x / self.view.frame.size.width; } @@ -616,6 +656,27 @@ - (void)panGestureRecognized:(UIPanGestureRecognizer *)recognizer } else { point.x = MIN(point.x, [UIScreen mainScreen].bounds.size.height); } + if (self.simpleMode) { + if (self.leftMenuVisible && self.rightMenuVisible) { + NSAssert(FALSE, @"WARNING: both left and right menu visible"); + } else if (self.leftMenuVisible) { + if (point.x > 0) { + point.x = 0; + } else if (point.x < -maxPanWidth) { + point.x = -maxPanWidth; + } + } else if (self.rightMenuVisible) { + if (point.x < 0) { + point.x = 0; + } else if (point.x > maxPanWidth) { + point.x = maxPanWidth; + } + } else if (point.x < -maxPanWidth){ + point.x = -maxPanWidth; + } else if (point.x > maxPanWidth) { + point.x = maxPanWidth; + } + } [recognizer setTranslation:point inView:self.view]; if (!self.didNotifyDelegate) {