jjzjj

iphone - 在 Iphone 中从 Seconds ViewController 调用方法时显示第一个 ViewController

coder 2023-09-26 原文

实际上我正在制作一个闹钟应用程序。在那里,当我设置时间时,UILocalNotification 事件发生在那个时候,它调用 AppDelegate 类的方法,即 didReceiveNotifications 方法。在这个方法中,我编写了一个代码来调用 SetViewController 的方法(showReminder 方法),现在在这个方法中,我希望它应该显示一个 NewViewController,即 TimeViewController,因为我必须在调用警报时显示动画。

我需要这个,因为当警报调用时,我已经设置了一个要显示的 Action 表,但我也想显示动画。 Action 表出现在所有 View 中但是动画只能在特定 View 中显示,这就是为什么我需要显示 A不同的 ViewController。

这是我正在尝试的代码:- 我已经尝试了所有这些也像 PresentModalViewController、dismissModalViewController、AddSubview、删除 superView...但结果是否定的:(我应该怎么做..?

几乎完整的代码:--

AppDelegate 类:-

- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {
    if (notification){
        NSLog(@"In did Notification");
        NSString *reminderText = [notification.userInfo objectForKey:kRemindMeNotificationDataKey];
        [viewController showReminder:reminderText];
        application.applicationIconBadgeNumber = 0;
    }
}

setViewController.h :-

@interface SetAlarmViewController : UIViewController <UITableViewDataSource,UITableViewDelegate,UITextFieldDelegate,UIActionSheetDelegate>{

    IBOutlet UITableView *tableview;
    IBOutlet UIDatePicker *datePicker;
    IBOutlet UITextField *eventText;
    TPKeyboardAvoidingScrollView *scrollView;

    IBOutlet UINavigationBar *titleBar;
    IBOutlet UIButton *setAlarmButton;
    AVAudioPlayer *player;
    int index;
    The420DudeAppDelegate *appDelegate;
    TimeViewController *viewController;

   IBOutlet UIImageView *animatedImages;

    NSMutableArray *imageArray;
    AVPlayerItem *player1,*player3;
    AVPlayerItem *player2,*player4;
    AVQueuePlayer *queuePlayer;
}
@property (nonatomic, retain) IBOutlet UIImageView *animatedImages;

@property (nonatomic, retain) IBOutlet UITableView *tableview;
@property (nonatomic, retain) IBOutlet UIDatePicker *datePicker;
@property (nonatomic, retain) IBOutlet UITextField *eventText;
@property (nonatomic, retain) TPKeyboardAvoidingScrollView *scrollView;

@property(nonatomic, retain) IBOutlet UINavigationBar *titleBar;
@property(nonatomic, retain) IBOutlet UIButton *setAlarmButton;
@property(nonatomic) UIReturnKeyType returnKeyType;  

@property(nonatomic, retain) IBOutlet TimeViewController *viewController;

- (IBAction) scheduleAlarm:(id)sender;
- (void)showReminder:(NSString *)text;
-(IBAction)onTapHome;

-(IBAction)onTapChange:(id)sender;

@end

SetViewController.m :-

@synthesize datePicker,tableview, eventText,titleBar,setAlarmButton,returnKeyType,scrollView,animatedImages,viewController;


// Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
- (void)viewDidLoad {

    [super viewDidLoad];

    appDelegate = (The420DudeAppDelegate *)[[UIApplication sharedApplication] delegate];
    eventText.returnKeyType = UIReturnKeyDone;

    viewController = [[TimeViewController alloc] initWithNibName:@"TimeViewController" bundle:nil];

    NSDate *now = [NSDate date];
    [datePicker setDate:now animated:YES];
    eventText.delegate = self;
    index = 0;

    NSString *path1 = [[NSBundle mainBundle] pathForResource:@"inhale" ofType:@"mp3"];
    NSURL *url1 = [NSURL fileURLWithPath:path1];
    player1 = [[AVPlayerItem alloc]initWithURL:url1];

    NSString *path3 = [[NSBundle mainBundle] pathForResource:@"sound1" ofType:@"wav"];
    NSURL *url3 = [NSURL fileURLWithPath:path3];
    player3 = [[AVPlayerItem alloc]initWithURL:url3];

    NSString *path2 = [[NSBundle mainBundle] pathForResource:@"exhale" ofType:@"mp3"];
    NSURL *url2 = [NSURL fileURLWithPath:path2];
    player2 = [[AVPlayerItem alloc]initWithURL:url2];

    NSString *path4 = [[NSBundle mainBundle] pathForResource:@"Dude" ofType:@"mp3"];
    NSURL *url4 = [NSURL fileURLWithPath:path4];
    player4 = [[AVPlayerItem alloc]initWithURL:url4];


    NSArray *items = [[NSArray alloc]initWithObjects:player1,player3,player2,player4,nil];
    queuePlayer = [[AVQueuePlayer alloc] initWithItems:items];    

    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(playEnded) name:AVPlayerItemDidPlayToEndTimeNotification object:player4];



}

-(void)onAlarmInvoke
{
    animatedImages = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, 320, 100)];
    animatedImages.userInteractionEnabled = YES;
    [animatedImages setContentMode:UIViewContentModeScaleToFill];
    [self.view addSubview : animatedImages];

    [queuePlayer play];    

    // Array to hold jpg images
    imageArray = [[NSMutableArray alloc] initWithCapacity:IMAGE_COUNT];

    // Build array of images, cycling through image names
    for (int i = 1; i <= IMAGE_COUNT; i++)
        [imageArray addObject:[UIImage imageNamed:[NSString stringWithFormat:@"animation(%d).jpg", i]]];

    animatedImages.animationImages = [NSArray arrayWithArray:imageArray];

    // One cycle through all the images takes 1.0 seconds
    animatedImages.animationDuration = 12.0;

    // Repeat foreverlight electro / 4 sec.
    animatedImages.animationRepeatCount = -1;

    // Add subview and make window visible
    //  [self.view addSubview:animatedImages];

    animatedImages.image = [imageArray objectAtIndex:imageArray.count - 1];

    // Start it up
    [animatedImages startAnimating];



    // Wait 5 seconds, then stop animation
    [self performSelector:@selector(stopAnimation) withObject:nil afterDelay:15000];

}

-(void)playEnded
{   
    [self performSelector:@selector(playNextItem) withObject:nil afterDelay:5.0];
}

-(void)playNextItem
{
    [queuePlayer play];
}
-(void)textFieldDidBeginEditing:(UITextField *)textField
{
    [scrollView adjustOffsetToIdealIfNeeded];
}

-(void)viewDidAppear:(BOOL)animated
{
    [super viewDidAppear:YES];
    [self.tableview reloadData];
}

- (IBAction) scheduleAlarm:(id)sender {
    [eventText resignFirstResponder];

    // Get the current date
    NSDate *pickerDate = [self.datePicker date];

    //   NSDate *selectedDate = [datePicker date]; // you don't need to alloc-init the variable first
    NSCalendar *cal = [NSCalendar currentCalendar];  
    NSDateComponents *dc = [cal components: (NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit | NSHourCalendarUnit | NSMinuteCalendarUnit) fromDate:pickerDate];
    pickerDate = [cal dateFromComponents:dc]; 

    NSLog(@"%@ is the date in picker date",pickerDate);

    UILocalNotification *localNotif = [[UILocalNotification alloc] init];
    if (localNotif == nil)
        return;
    localNotif.fireDate = pickerDate;
    //  NSLog(@"%@",localNotif.fireDate);
    localNotif.timeZone = [NSTimeZone defaultTimeZone];
    //  NSLog(@"%@",localNotif.timeZone);

    // Notification details
    localNotif.alertBody = [eventText text];

    // Set the action button
    localNotif.alertAction = @"Show me";
    localNotif.repeatInterval = NSDayCalendarUnit;
    localNotif.soundName = @"jet.wav";
    // Specify custom data for the notification
    NSDictionary *userDict = [NSDictionary dictionaryWithObject:eventText.text
                                                         forKey:kRemindMeNotificationDataKey];
    localNotif.userInfo = userDict;

    // Schedule the notification
    [[UIApplication sharedApplication] scheduleLocalNotification:localNotif];
    [localNotif release];

    [self.tableview reloadData];
    eventText.text = @"";

    viewController = [[TimeViewController alloc] initWithNibName:@"TimeViewController" bundle:nil];
    [self presentModalViewController:viewController animated:YES];
}


- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    index = indexPath.row;
    UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Warning!!!" 
                                                        message:@"Are you sure you want to Delete???" delegate:self
                                              cancelButtonTitle:@"Cancel"
                                              otherButtonTitles:@"Ok",nil];
    [alertView show];
    [alertView release];

}
- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
    NSArray *notificationArray = [[UIApplication sharedApplication] scheduledLocalNotifications];
    UILocalNotification *notify = [notificationArray objectAtIndex:index];

    if(buttonIndex == 0)
    {
        // Do Nothing on Tapping Cancel...
    }
    if(buttonIndex ==1)
    {
        if(notify)
            [[UIApplication sharedApplication] cancelLocalNotification:notify];
    }
    [self.tableview reloadData];
}

// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier] autorelease];
    }
    // Configure the cell...

    NSArray *notificationArray = [[UIApplication sharedApplication] scheduledLocalNotifications];
    UILocalNotification *notif = [notificationArray objectAtIndex:indexPath.row];

    [cell.textLabel setText:notif.alertBody];
    [cell.detailTextLabel setText:[notif.fireDate description]];    
    return cell;
}

- (void)viewDidUnload {
    datePicker = nil;
    tableview = nil;
    eventText = nil;
    [self setScrollView:nil];
    [super viewDidUnload];

}

- (void)showReminder:(NSString *)text {

    [self onAlarmInvoke];

    [self.view addSubview:viewController.view];

    UIActionSheet *actionSheet = [[UIActionSheet alloc]initWithTitle:nil delegate:self cancelButtonTitle:nil destructiveButtonTitle:@"Cancel" otherButtonTitles:nil];
    [actionSheet setActionSheetStyle:UIActionSheetStyleBlackTranslucent];
    CGRect rect = self.view.frame;
   // if(rect.origin.y <= 480)
  //      rect.origin.y +=20;

    self.view.frame = rect;
    [actionSheet showInView:self.view];
    [actionSheet release];


}
- (void)actionSheet:(UIActionSheet *)actionSheet clickedButtonAtIndex:(NSInteger)buttonIndex
{

    if(buttonIndex == 0)
    {
        [player stop];
        NSLog(@"OK Tapped");
    }
    if(buttonIndex ==  1)
    {
        [player stop];
        NSLog(@"Cancel Tapped");
    }

}

-(IBAction)onTapHome{
    viewController = [[TimeViewController alloc] initWithNibName:@"TimeViewController" bundle:nil];
    [self presentModalViewController:viewController animated:YES];
}

- (void)dealloc {
    [super dealloc];
    [datePicker release];
    [tableview release];
    [eventText release];
    [scrollView release];
}
-(IBAction)onTapChange:(id)sender{

    SetTimeViewController *viewC = [[SetTimeViewController alloc]initWithNibName:@"SetTimeViewController" bundle:nil];
    [self presentModalViewController:viewC animated:YES];
}
@end

最佳答案

您的 viewController 可能正在显示 View ,但如果屏幕上没有 SetViewController 的 View ,您将看不到它。您必须先转到 SetViewController,然后显示您的 TimeViewController。是这样吗,您想显示 SetViewController 但立即调用 showReminder: 方法?但仅来自 didReceiveLocalNotification:.

如果是这种情况,请在您的 SetViewControllers.h 中设置一个标志和一个文本属性,

BOOL isFromNotification;
NSString *notifText; 

并呈现 SetViewController,并设置标志

SetViewController *setViewController = [SetViewController alloc]........
setViewController.isFromNotification = YES;
setViewController.notifText = reminderText;
[self presentModalViewController animated:YES}

然后在 ViewDidAppear: 的 SetViewController 中

if(isFromNotification = YES){
  [self showReminders:notifText];
}

关于iphone - 在 Iphone 中从 Seconds ViewController 调用方法时显示第一个 ViewController,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8738057/

有关iphone - 在 Iphone 中从 Seconds ViewController 调用方法时显示第一个 ViewController的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  6. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  7. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  8. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  9. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  10. ruby - Highline 询问方法不会使用同一行 - 2

    设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案

随机推荐