aboutsummaryrefslogtreecommitdiffstats
path: root/iBean/iBean
diff options
context:
space:
mode:
authorEddie Ehlin <eddiex@eddiex.se>2013-01-22 22:08:20 +0100
committerEddie Ehlin <eddiex@eddiex.se>2013-01-22 22:08:20 +0100
commitc0120a7416208d34d8303b985bcdc78a5ffa16a1 (patch)
treef2ad64a5ca68655ee7862978725cc05ff7434fb0 /iBean/iBean
parentb36ffa25882b548c800ee609965196ef3332e9c4 (diff)
downloadiBean-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.h7
-rw-r--r--iBean/iBean/BeanCollectionExtractionViewController.m50
-rw-r--r--iBean/iBean/InstantExtractionViewController.h1
-rw-r--r--iBean/iBean/InstantExtractionViewController.m13
-rw-r--r--iBean/iBean/iPhoneStoryboard.storyboard6
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"/>