【Cocos2d游戏开发之十六】添加本地通知(UILocalNotification)以及添加系统组件滚动视图(UIScrollView)!

简介:

首先申明下:希望大家转载的时候不要忘记给原文连接,看到不少论坛转载完全变成他们论坛自己原创了~ 请大家配合哈~谢谢~娃哈哈;

         本篇Himi为童鞋们介绍两个常用的知识点:一个是在Cocos2d中添加UILocalNotification本地化通知,另外一个就是添加UIScrollViewiOS系统组件实现滚动字幕效果;

          对于UILocalNotification这个本地化通知功能实现比较简单,用途很广,最大的用途就是阶段性的让用户回归我们的应用中;那么下面就直接上代码:

          因为是添加到cocos2d引擎中,另一方面一般我们需要用户进入我们应用后就开启通知功能的;所以我们将代码放在 AppDelegate.m 类中的applicationDidFinishLaunching中,代码如下:

 


  
  
  1. - (void) applicationDidFinishLaunching:(UIApplication*)application   
  2. {   
  3.     ...   
  4.     application.applicationIconBadgeNumber = 0;//应用程序右上角的数字=0(消失)   
  5.     [[UIApplication sharedApplication] cancelAllLocalNotifications];//取消所有的通知   
  6.     //------通知;   
  7.     UILocalNotification *notification=[[UILocalNotification alloc] init];    
  8.     if (notification!=nil) {//判断系统是否支持本地通知   
  9.         notification.fireDate=[NSDate dateWithTimeIntervalSinceNow:kCFCalendarUnitDay];//本次开启立即执行的周期   
  10.         notification.repeatInterval=kCFCalendarUnitDay;//循环通知的周期   
  11.         notification.timeZone=[NSTimeZone defaultTimeZone];   
  12.         notification.alertBody=@"哇,我的女神,你怎了?";//弹出的提示信息   
  13.         notification.applicationIconBadgeNumber=1; //应用程序的右上角小数字   
  14.         notification.soundName= UILocalNotificationDefaultSoundName;//本地化通知的声音   
  15.         notification.alertAction = NSLocalizedString(@"营救女神!", nil);  //弹出的提示框按钮   
  16.         [[UIApplication sharedApplication]   scheduleLocalNotification:notification];   
  17.     }    
  18.  ...   
  19. }   

 

这里Himi首先是将之前的所有通知都取消掉,防止开启多个循环本地化通知,并且让应用右上角的数字设置为0,这里设置为0就相当与取消数字的显示了;

           然后需要说明的是循环通知的周期,iOS提供如下一些周期:

 


  
  
  1. enum {   
  2.     kCFCalendarUnitEra = (1UL << 1),   
  3.     kCFCalendarUnitYear = (1UL << 2),   
  4.     kCFCalendarUnitMonth = (1UL << 3),   
  5.     kCFCalendarUnitDay = (1UL << 4),   
  6.     kCFCalendarUnitHour = (1UL << 5),   
  7.     kCFCalendarUnitMinute = (1UL << 6),   
  8.     kCFCalendarUnitSecond = (1UL << 7),   
  9.     kCFCalendarUnitWeek = (1UL << 8) /* CF_DEPRECATED(10_4, 10_7, 2_0, 5_0) */,   
  10.     kCFCalendarUnitWeekday = (1UL << 9),   
  11.     kCFCalendarUnitWeekdayOrdinal = (1UL << 10),   
  12. #if MAC_OS_X_VERSION_10_6 <= MAC_OS_X_VERSION_MAX_ALLOWED || __IPHONE_4_0 <= __IPHONE_OS_VERSION_MAX_ALLOWED   
  13.     kCFCalendarUnitQuarter = (1UL << 11),   
  14. #endif   
  15. #if MAC_OS_X_VERSION_10_7 <= MAC_OS_X_VERSION_MAX_ALLOWED || __IPHONE_5_0 <= __IPHONE_OS_VERSION_MAX_ALLOWED   
  16.     kCFCalendarUnitWeekOfMonth = (1UL << 12),   
  17.     kCFCalendarUnitWeekOfYear = (1UL << 13),   
  18.     kCFCalendarUnitYearForWeekOfYear = (1UL << 14),   
  19. #endif   
  20. };   

 

下面是真机截图:

 

 

以上是在我真机iOS5系统上的测试效果,主界面中的展示效果以及通知栏内的通知效果,在iOS5之前都会出现类似弹出一个框,框中有你设置的按钮名称和提示文字~

         OK,这个知识点就不多说了,比较easy;下面介绍如何在cocos2d中添加UIScrollView;

        对于UIScrollView视图,比较常用,Android也有此视图,那么它用途比较广,最常用也是最容易想到的就是利用此功能实现游戏中公司介绍、字幕滚动效果,那么Himi就简单的实现在cocos2d中利用UIScrollView添加一个无线循环滚动的小例子加以讲解;

        注意:对于还不知道如何在cocos2d中添加系统组建的童鞋请移步到《【Cocos2d游戏开发之七】在cocos2d中添加/删除系统组件,并解决View设置透明会影响View中的其他组件的问题!》此贴学习先,下面开始添加:

         首先我们新建一个cocos2d项目,然后添加显示一个自定义的MyView(UIViewController)的视图,并且在MyView.xib中添加了一些label和ScrollView组件中;

          如下图:

 

然后修改MyView.h,和MyView.m类,在MyView.h中如下代码:

 


  
  
  1. @interface MyView : UIViewController<UIScrollViewDelegate>{   
  2.     IBOutlet UIScrollView *scrollView;   
  3. }   
  4. @property(nonatomic,retain)IBOutlet UIScrollView *scrollView;   
  5. @end  

 .h类中添加了一个UIScrollView并使用UIScrollViewDelegate协议,并IBOutlet出去,接着让xib文件中的UIScrollView组件连接此scrollView;

 

 

  之后在MyView.m中添加如下代码:

         1.添加一行如下代码:

 


  
  
  1. @synthesize scrollView;   

 

 2.在- (void)viewDidLoad{}中添加如下代码:

 


  
  
  1. - (void)viewDidLoad   
  2. {   
  3.     [super viewDidLoad];   
  4.     //滚动view    
  5.     scrollView.delegate = self;   
  6.     scrollView.scrollEnabled = YES;    
  7.     scrollView.contentSize = CGSizeMake(100, 249);//设置滚动的可视区域   
  8.     // Do any additional setup after loading the view from its nib.   
  9. }   

 整个MyView.m代码如下:

 


  
  
  1. //   
  2. //  MyView.m   
  3. //  ScrollViewByHimi   
  4. //   
  5. //  Created by 华明 李 on 11-10-22.   
  6. //  Copyright (c) 2011年 __MyCompanyName__. All rights reserved.   
  7. //   
  8.    
  9. #import "MyView.h"   
  10.    
  11. @implementation MyView   
  12. @synthesize scrollView;   
  13. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil   
  14. {   
  15.     self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];   
  16.     if (self) {   
  17.         // Custom initialization   
  18.     }   
  19.     return self;   
  20. }   
  21.    
  22. - (void)didReceiveMemoryWarning   
  23. {   
  24.     // Releases the view if it doesn't have a superview.   
  25.     [super didReceiveMemoryWarning];   
  26.        
  27.     // Release any cached data, images, etc that aren't in use.   
  28. }   
  29.    
  30. #pragma mark - View lifecycle   
  31.    
  32. - (void)viewDidLoad   
  33. {   
  34.     [super viewDidLoad];   
  35.     //滚动view    
  36.     scrollView.delegate = self;   
  37.     scrollView.scrollEnabled = YES;    
  38.     scrollView.contentSize = CGSizeMake(100, 249);//设置滚动的可视区域   
  39.     // Do any additional setup after loading the view from its nib.   
  40. }   
  41.    
  42. - (void)viewDidUnload   
  43. {   
  44.     [super viewDidUnload];   
  45.     // Release any retained subviews of the main view.   
  46.     // e.g. self.myOutlet = nil;   
  47. }   
  48.    
  49. - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation   
  50. {   
  51.     // Return YES for supported orientations   
  52.     return (interfaceOrientation == UIInterfaceOrientationPortrait);   
  53. }   
  54.    
  55. @end  

OK,运行代码即可,运行效果如下: 

 

可以拖动ScrollView中的数据了,ScrollView默认显示滚动条的,可以代码设置隐藏也可以xib中对ScrollView属性调整都可以;

 

             下面介绍如何让ScrollView中的数据无限循环运动:

       首先在HelloWorldLayer.m种的init添加我们自定义view的下面设置一个选择器:

 

 


  
  
  1. [self schedule:@selector(viewAddPointY) interval:0.03];//每0.03秒执行一次viewAddPointY方法   

 然后viewAddPointY方法是Himi自定义的函数,代码如下:

 


  
  
  1. -(void)viewAddPointY{   
  2.     view.scrollView.contentOffset=ccpAdd(view.scrollView.contentOffset, ccp(0,0.5));//让UIScrollView显示内容每次慢慢向上移动0.5像素   
  3.     //view.scrollView.contentSize.height :得到UIScrollView的高度   
  4.     if(view.scrollView.contentOffset.y>=view.scrollView.contentSize.height){   
  5.         view.scrollView.contentOffset=ccp(0,-view.scrollView.frame.size.height);   
  6.     }   
  7. }   

运行效果如下:

 

 

备注:我的Xcode是4.2用的模拟器是iOS5的模拟器,可能童鞋们按照我的这个教程运行后发现虽然UIScrollView中的数据滚动了但是没有循环播放,这个是因为模拟器的问题,Himi真机测试无问题的~

 

      好了,最后我把 HelloWorldLayer.h 和HelloWorldLayer.m也完整放上来,省得有的童鞋不知道添加代码的地方也方便童鞋们拷贝代码; 

HelloWorldLayer.h

 


  
  
  1. //   
  2. //  HelloWorldLayer.h   
  3. //  ScrollViewByHimi   
  4. //   
  5. //  Created by 华明 李 on 11-10-22.   
  6. //  Copyright __MyCompanyName__ 2011年. All rights reserved.   
  7. //   
  8.    
  9.    
  10. // When you import this file, you import all the cocos2d classes   
  11. #import "cocos2d.h"   
  12. #import "MyView.h"   
  13. // HelloWorldLayer   
  14. @interface HelloWorldLayer : CCLayer   
  15. {   
  16.     MyView *view;   
  17. }   
  18.    
  19. // returns a CCScene that contains the HelloWorldLayer as the only child   
  20. +(CCScene *) scene;   
  21.    
  22. @end   

 

HelloWorldLayer.m

 


  
  
  1. //   
  2. //  HelloWorldLayer.m   
  3. //  ScrollViewByHimi   
  4. //   
  5. //  Created by 华明 李 on 11-10-22.   
  6. //  Copyright __MyCompanyName__ 2011年. All rights reserved.   
  7. //   
  8.    
  9.    
  10. // Import the interfaces   
  11. #import "HelloWorldLayer.h"   
  12. #import "MyView.h"   
  13. // HelloWorldLayer implementation   
  14. @implementation HelloWorldLayer   
  15.    
  16. +(CCScene *) scene   
  17. {    
  18.     CCScene *scene = [CCScene node];    
  19.     HelloWorldLayer *layer = [HelloWorldLayer node];    
  20.     [scene addChild: layer];    
  21.     return scene;   
  22. }   
  23.     
  24. -(id) init   
  25. {    
  26.     if( (self=[super init])) {   
  27.            
  28.         view= [[MyView alloc] initWithNibName:@"MyView" bundle:nil];     
  29.         [[[CCDirector sharedDirector] openGLView] addSubview:view.view];     
  30.         [self schedule:@selector(viewAddPointY) interval:0.03];//每0.03秒执行一次viewAddPointY方法   
  31.     }   
  32.     return self;   
  33. }   
  34. -(void)viewAddPointY{   
  35.     view.scrollView.contentOffset=ccpAdd(view.scrollView.contentOffset, ccp(0,0.5));//让UIScrollView显示内容每次慢慢向上移动0.5像素   
  36.     //view.scrollView.contentSize.height :得到UIScrollView的高度   
  37.     if(view.scrollView.contentOffset.y>=view.scrollView.contentSize.height){   
  38.         view.scrollView.contentOffset=ccp(0,-view.scrollView.frame.size.height);   
  39.     }   
  40. }   
  41.     
  42. - (void) dealloc   
  43. {     
  44.     [super dealloc];   
  45. }   
  46. @end   

 OK,本篇结束;再次提醒下,希望大家转载的时候不要忘记给原文连接,看到不少论坛转载完全变成他们论坛自己原创了~ 请大家配合下哈~谢谢~

 










本文转自 xiaominghimi 51CTO博客,原文链接:http://blog.51cto.com/xiaominghimi/695313,如需转载请自行联系原作者
目录
相关文章
|
8月前
|
编解码 前端开发 人机交互
【Unity 3D】UI系统中UGUI各个组件的详细讲解(附源码 超详细)
【Unity 3D】UI系统中UGUI各个组件的详细讲解(附源码 超详细)
365 0
|
移动开发 Dart
【新年快乐第二弹】在 Flutter 中使用交错网格视图创建瀑布流布局
马上过新年了,想好如何过年了吗?,今天我带大家在瀑布流布局中写新年快乐。 在 Web 和移动开发世界中,当我们想要显示大小不相同的项目网格时,瀑布流布局很有用。一个轴使用严格的网格布局,通常是列。在另一个轴上,项目具有不同的高度,但可以灵活排列以填满可用空间。使用瀑布流布局的一个著名例子是 Pinterest。他们为他们的网站和移动应用程序实现了这种布局,以显示不同大小的图像。
322 0
|
vr&ar 图形学
【Unity3D 灵巧小知识点】☀️ | Unity UGUI组件Scroll View禁止 左右 或 上下 滑动
Unity 小科普 老规矩,先介绍一下 Unity 的科普小知识: Unity是 实时3D互动内容创作和运营平台 。 包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者,借助 Unity 将创意变成现实。 Unity 平台提供一整套完善的软件解决方案,可用于创作、运营和变现任何实时互动的2D和3D内容,支持平台包括手机、平板电脑、PC、游戏主机、增强现实和虚拟现实设备。 也可以简单把 Unity 理解为一个游戏引擎,可以用来专业制作游戏!
【Unity3D 灵巧小知识点】☀️ | Unity UGUI组件Scroll View禁止 左右 或 上下 滑动
|
vr&ar 图形学
【Unity3D 灵巧小知识点】☀️ | Unity 中如何让 Toggle组件 实现多选一的效果
Unity 小科普 老规矩,先介绍一下 Unity 的科普小知识: Unity是 实时3D互动内容创作和运营平台 。 包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者,借助 Unity 将创意变成现实。
【Unity3D 灵巧小知识点】☀️ | Unity 中如何让 Toggle组件 实现多选一的效果
|
C# 数据可视化 容器
WPF触屏Touch事件在嵌套控件中的响应问题
原文:WPF触屏Touch事件在嵌套控件中的响应问题 前几天遇到个touch事件的坑,记录下来以增强理解。 具体是 想把一个listview嵌套到另一个listview,这时候如果list view(子listview)的内容过多超过容器高度,它是不会出现滚动条压缩内容区域的,反而会将滚动区域转移到外面的list view(父listview),这个无可争议,但这个问题开始没留意,为待会的坑埋下伏笔。
1038 0
|
iOS开发
iOS开发实战 - 完美解决UIScrollView嵌套滑动手势冲突
我们应该都有用过这个功能,你的朋友微信给你分享了一个淘宝里面的商品链接,然后当你复制这个链接打开淘宝APP的时候,就会弹出一个弹窗,像这样: example.PNG 这个功能想必大家都挺熟悉,受这个启发我们产品也想在我们APP上添加这样一个功能,与这个不一样的是,当我们复制一段网址的时候打开我们的APP会弹出框填一些信息后上传到我们的“资源库”。
4320 0
|
前端开发 图形学 算法