diff options
author | Eddie Ehlin <eddiex@eddiex.se> | 2013-01-22 22:08:20 +0100 |
---|---|---|
committer | Eddie Ehlin <eddiex@eddiex.se> | 2013-01-22 22:08:20 +0100 |
commit | c0120a7416208d34d8303b985bcdc78a5ffa16a1 (patch) | |
tree | f2ad64a5ca68655ee7862978725cc05ff7434fb0 /iBean/iBean | |
parent | b36ffa25882b548c800ee609965196ef3332e9c4 (diff) | |
download | iBean-c0120a7416208d34d8303b985bcdc78a5ffa16a1.tar.gz iBean-c0120a7416208d34d8303b985bcdc78a5ffa16a1.zip |
Added timer handling (using core timer) to BeanCollectionExtractionViewController.
Diffstat (limited to 'iBean/iBean')
-rw-r--r-- | iBean/iBean/BeanCollectionExtractionViewController.h | 7 | ||||
-rw-r--r-- | iBean/iBean/BeanCollectionExtractionViewController.m | 50 | ||||
-rw-r--r-- | iBean/iBean/InstantExtractionViewController.h | 1 | ||||
-rw-r--r-- | iBean/iBean/InstantExtractionViewController.m | 13 | ||||
-rw-r--r-- | iBean/iBean/iPhoneStoryboard.storyboard | 6 |
5 files changed, 69 insertions, 8 deletions
diff --git a/iBean/iBean/BeanCollectionExtractionViewController.h b/iBean/iBean/BeanCollectionExtractionViewController.h index 1cb0f67..449642a 100644 --- a/iBean/iBean/BeanCollectionExtractionViewController.h +++ b/iBean/iBean/BeanCollectionExtractionViewController.h @@ -12,10 +12,15 @@ @interface BeanCollectionExtractionViewController : UIViewController <UITableViewDelegate, UITableViewDataSource> @property (nonatomic, strong) BeanCollection *beanCollection; +@property (nonatomic, assign) double extractionProgress; +@property (nonatomic, assign) BOOL extractionInProgress; /* Utility methods */ - (void) initViewController; - (void) initWithBeanCollection:(BeanCollection*) bc; +- (void) updateExtractionProgress; +- (void) haltExtractionTimer; +- (void) timerInterrupted; /* UI Outlets */ @property (weak, nonatomic) IBOutlet UITableView *beanTableView; @@ -24,6 +29,6 @@ @property (weak, nonatomic) IBOutlet UIButton *extractionButton; /* UI Actions */ - +- (IBAction) startExtraction:(id)sender; @end diff --git a/iBean/iBean/BeanCollectionExtractionViewController.m b/iBean/iBean/BeanCollectionExtractionViewController.m index 4c26ab6..785c981 100644 --- a/iBean/iBean/BeanCollectionExtractionViewController.m +++ b/iBean/iBean/BeanCollectionExtractionViewController.m @@ -11,6 +11,7 @@ #import "BeanCollection+Interface.h" #import "BeanCell.h" #import "Bean+Interface.h" +#import "AppDelegate+Storage.h" @interface BeanCollectionExtractionViewController () @@ -87,7 +88,39 @@ - (void) initWithBeanCollection:(BeanCollection *)bc { self.beanCollection = bc; +} + +- (void) updateExtractionProgress +{ + self.extractionProgress -= 0.1f; + self.extractionProgressLabel.text = [NSString stringWithFormat:@"%1.1f", self.extractionProgress]; + if (self.extractionProgress <= 0.0f) + { + NSLog(@"Timer reached its limit!"); + [self haltExtractionTimer]; + } +} + +- (void) haltExtractionTimer +{ + if ([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] != nil) + { + [(AppDelegate*) [[UIApplication sharedApplication] delegate] haltTimer:YES]; + + //Return UI to "Start extraction" state. + [self timerInterrupted]; + } +} + +- (void) timerInterrupted +{ + NSLog(@"BeanCollectionExtractionViewController - timerInterrupted"); + + //Return UI to "Start extraction" state. + [self.extractionButton setTitle:@"Start extraction" forState:UIControlStateNormal]; + self.extractionProgressLabel.text = [self.beanCollection.extractionTime stringValue]; + self.extractionInProgress = NO; } /***************************************************** @@ -95,6 +128,23 @@ *****************************************************/ #pragma mark - UI action methods +- (void) startExtraction:(id)sender +{ + //Extraction in progress? + if ([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] == nil || self.extractionInProgress == NO) + { + self.extractionProgress = [self.beanCollection.extractionTime doubleValue]; + [self.extractionButton setTitle:@"Stop extraction" forState:UIControlStateNormal]; + self.extractionInProgress = YES; + + [(AppDelegate*) [[UIApplication sharedApplication] delegate] createTimer:self :@selector(updateExtractionProgress) :nil :YES]; + } + else if ([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] != nil) + { + [self haltExtractionTimer]; + } +} + /***************************************************** Delegates *****************************************************/ diff --git a/iBean/iBean/InstantExtractionViewController.h b/iBean/iBean/InstantExtractionViewController.h index 4fded92..92b265e 100644 --- a/iBean/iBean/InstantExtractionViewController.h +++ b/iBean/iBean/InstantExtractionViewController.h @@ -12,6 +12,7 @@ @interface InstantExtractionViewController : UIViewController @property (nonatomic, assign) double extractionProgress; +@property (nonatomic, assign) BOOL extractionInProgress; @property (nonatomic, strong) Configuration *configuration; /* Utility methods */ diff --git a/iBean/iBean/InstantExtractionViewController.m b/iBean/iBean/InstantExtractionViewController.m index 3c53faa..d0205c8 100644 --- a/iBean/iBean/InstantExtractionViewController.m +++ b/iBean/iBean/InstantExtractionViewController.m @@ -87,10 +87,10 @@ { if ([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] != nil) { - [(AppDelegate*) [[UIApplication sharedApplication] delegate] haltTimer:NO]; + [(AppDelegate*) [[UIApplication sharedApplication] delegate] haltTimer:YES]; //Return UI to "Start extraction" state. - [self timerInterrupted]; + //[self timerInterrupted]; } } @@ -101,6 +101,7 @@ //Return UI to "Start extraction" state. [self.extractionButton setTitle:@"Start extraction" forState:UIControlStateNormal]; [self.extractionSettingStepper setEnabled:YES]; + self.extractionInProgress = NO; } /***************************************************** @@ -108,17 +109,17 @@ *****************************************************/ #pragma mark - IBActions - (IBAction)startExtraction:(id)sender { - - //Extraction in progress? - if ([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] == nil) + + if (([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] == nil) || self.extractionInProgress == NO) { self.extractionProgress = 0.0f; [self.extractionButton setTitle:@"Stop extraction" forState:UIControlStateNormal]; [self.extractionSettingStepper setEnabled:NO]; + self.extractionInProgress = YES; [(AppDelegate*) [[UIApplication sharedApplication] delegate] createTimer:self :@selector(updateExtractionProgressLabel) :nil :YES]; } - else + else if (([(AppDelegate*) [[UIApplication sharedApplication] delegate] getTimer] != nil)) { [self haltExtractionTimer]; } diff --git a/iBean/iBean/iPhoneStoryboard.storyboard b/iBean/iBean/iPhoneStoryboard.storyboard index df40f8a..2cb8195 100644 --- a/iBean/iBean/iPhoneStoryboard.storyboard +++ b/iBean/iBean/iPhoneStoryboard.storyboard @@ -743,10 +743,13 @@ </scrollView> <button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="YJ7-1f-6ZW"> <fontDescription key="fontDescription" name="Helvetica-Bold" family="Helvetica" pointSize="15"/> - <state key="normal" title="Button"> + <state key="normal" title="Start extraction"> <color key="titleColor" red="0.19607843459999999" green="0.30980393290000002" blue="0.52156865600000002" alpha="1" colorSpace="calibratedRGB"/> <color key="titleShadowColor" white="0.5" alpha="1" colorSpace="calibratedWhite"/> </state> + <connections> + <action selector="startExtraction:" destination="aA5-tc-vwr" eventType="touchUpInside" id="VkN-OE-9wh"/> + </connections> </button> <label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" text="Extraction counter" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="OLN-e5-oOe"> <fontDescription key="fontDescription" type="system" pointSize="17"/> @@ -826,6 +829,7 @@ <class className="BeanCollectionExtractionViewController" superclassName="UIViewController"> <source key="sourceIdentifier" type="project" relativePath="./Classes/BeanCollectionExtractionViewController.h"/> <relationships> + <relationship kind="action" name="startExtraction:"/> <relationship kind="outlet" name="beanCollectionNoteTextView" candidateClass="UITextView"/> <relationship kind="outlet" name="beanTableView" candidateClass="UITableView"/> <relationship kind="outlet" name="extractionButton" candidateClass="UIButton"/> |