【IOS】仿捕鱼达人的金币滚动显示

2024-03-14 10:30

本文主要是介绍【IOS】仿捕鱼达人的金币滚动显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【原创作品, 欢迎转载,转载请在明显处注明! 谢谢。

原文地址:http://blog.csdn.net/toss156/article/details/7439769

今天给大家带来一个模仿捕鱼达人中,金币的滚动显示。(部分代码参考了cocoachina上一个C++版的)


//
//  UiNumRoll.h
//  WheelScore
//
//  Created by 周海锋 on 12-4-8.
//  Copyright 2012年 CJLU. All rights reserved.
//#import <Foundation/Foundation.h>
#import "cocos2d.h"#define NUM_HEIGHT 20
#define NUM_WIDTH  20typedef enum{NumStyleNormal,NumStyleSameTime,
}NumStyle;@interface UINumber : CCSprite {NumStyle m_style;       //滚动样式int m_num;              //显示的数字int m_nPosCur;          //当前的位置int m_nPosEnd;          //结束的位置int m_nMoveLen;         //每次移动的位置CCTexture2D *m_texture; //数字的texture
}@property(nonatomic,retain) CCTexture2D *m_texture;
-(id) initWithStyle:(NumStyle) style;
-(void) setNumber:(int) num;
-(void) onRollDown:(ccTime) dt;
-(void) onRollUP:(ccTime) dt;
-(void) setup;
@end

//
//  UiNumRoll.m
//  WheelScore
//
//  Created by 周海锋 on 12-4-8.
//  Copyright 2012年 CJLU. All rights reserved.
//#import "UINumber.h"
@implementation UINumber
@synthesize m_texture;/** init 初始化*/
-(id) init
{if( (self=[super init])) {m_texture = NULL;m_style = NumStyleNormal;m_num = 0;m_nPosCur = 0;m_nPosEnd = 0;   [self setup];}return self;
}/** initWithStyle 初始化*/
-(id) initWithStyle:(NumStyle) style
{if( (self=[super init])) {m_texture = NULL;m_style = style;m_num = 0;m_nPosCur = 0;m_nPosEnd = 0;[self setup];}return self;
}/** setup 设置texture*/
-(void)setup
{UIImage *image = [UIImage imageNamed:@"number.png"];m_texture = [[CCTexture2D alloc]initWithImage:image];CCSpriteFrame *frame = [CCSpriteFrame frameWithTexture:m_texture rect:CGRectMake(0, 0, NUM_WIDTH, NUM_HEIGHT)];[self setDisplayFrame:frame];
}/** setNumber 设置显示的数字*/
-(void) setNumber:(int) num
{m_nPosCur = NUM_HEIGHT * m_num;m_nPosEnd = NUM_HEIGHT * num;if (NumStyleNormal == m_style) {m_nMoveLen = 4;}else if (NumStyleSameTime == m_style) {m_nMoveLen = (m_nPosEnd-m_nPosCur)/20;}if (m_num > num) {[self schedule:@selector(onRollUP:) interval:0.03];}else {[self schedule:@selector(onRollDown:) interval:0.03];}m_num = num;
}/** onRollDown 向下滚动*/
-(void) onRollDown:(ccTime) dt
{m_nPosCur += m_nMoveLen;if (m_nPosCur >= m_nPosEnd) {m_nPosCur = m_nPosEnd;[self unschedule:@selector(onRollDown:)];}CCSpriteFrame *frame = [CCSpriteFrame frameWithTexture:m_texture rect:CGRectMake(0, m_nPosCur, NUM_WIDTH, NUM_HEIGHT)];[self setDisplayFrame:frame];
}/** onRollUP 向上滚动*/
-(void) onRollUP:(ccTime) dt
{m_nPosCur -= 4;if (m_nPosCur <= m_nPosEnd) {m_nPosCur = m_nPosEnd;[self unschedule:@selector(onRollUP:)];}CCSpriteFrame *frame = [CCSpriteFrame frameWithTexture:m_texture rect:CGRectMake(0, m_nPosCur, NUM_WIDTH, NUM_HEIGHT)];[self setDisplayFrame:frame];
}-(void)dealloc
{[self unscheduleAllSelectors];[m_texture release];[super dealloc];
}
@end

//
//  UIRollNum.h
//  WheelScore
//
//  Created by 周海锋 on 12-4-8.
//  Copyright 2012年 CJLU. All rights reserved.
//#import <Foundation/Foundation.h>
#import "cocos2d.h"
#import "UINumber.h"@interface UIRollNum : CCSprite {int m_nNumber;              //显示的数字int m_maxCol;               //最大显示位数NSMutableArray *numArray;   //存放每个数字的数组CGPoint m_point;            //坐标bool  zeroFill;             //是否开启0填充NumStyle style;             //滚动样式
}@property (nonatomic,retain) NSMutableArray *numArray;
@property (nonatomic) CGPoint m_point;
@property (nonatomic) NumStyle style;  -(void) rebuildEffect;
-(void) clearEffect;
-(int) getNumber;
-(void) setNumber:(int)num;
@end

//
//  UIRollNum.m
//  WheelScore
//
//  Created by 周海锋 on 12-4-8.
//  Copyright 2012年 CJLU. All rights reserved.
//#import "UIRollNum.h"
@implementation UIRollNum
@synthesize numArray,m_point,style;/** init 初始化*/
-(id) init
{if (self = [super init]) {m_nNumber = 0;m_maxCol = 6;numArray =[[NSMutableArray alloc] init];zeroFill = YES;style = NumStyleNormal;}   return self;
}/** getNumber 获取显示的数字*/
-(int) getNumber
{return m_nNumber;
}/** setNumber 设置显示的数字* num int 设置的数字*/
-(void) setNumber:(int)num
{if (m_nNumber != num) {m_nNumber = num;[self rebuildEffect];}
}/** rebuildEffect 重新设置每位数字*/
-(void) rebuildEffect
{[self clearEffect];int i=0;int num = m_nNumber;while (1) {if (num<=0) {if(m_maxCol<=i && zeroFill)break;}int showNum = num%10;UINumber* pNumber = [[UINumber alloc]initWithStyle:style];[numArray addObject:pNumber];[pNumber setNumber:showNum];[pNumber setPosition:CGPointMake(m_point.x - i*NUM_WIDTH, m_point.y)];[pNumber setAnchorPoint:CGPointMake(1, 0.5)];[self addChild:pNumber z:100];i++;num = num/10;}
}/** rebuildEffect 清楚每位数字*/
-(void) clearEffect
{for(int i=0;i<[numArray count];i++) {UINumber* pNumber = (UINumber *)[numArray objectAtIndex:i];[self removeChild:pNumber cleanup:YES];}[numArray removeAllObjects];
}-(void)dealloc
{[numArray release];[super dealloc];
}@end

demo的下载地址:http://download.csdn.net/detail/toss156/4209940

这篇关于【IOS】仿捕鱼达人的金币滚动显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/808134

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

小程序button控件上下边框的显示和隐藏

问题 想使用button自带的loading图标功能,但又不需要button显示边框线 button控件有一条淡灰色的边框,在控件上了样式 border:none; 无法让button边框隐藏 代码如下: <button class="btn">.btn{border:none; /*一般使用这个就是可以去掉边框了*/} 解决方案 发现button控件有一个伪元素(::after

MFC中Spin Control控件使用,同时数据在Edit Control中显示

实现mfc spin control 上下滚动,只需捕捉spin control 的 UDN_DELTAPOD 消息,如下:  OnDeltaposSpin1(NMHDR *pNMHDR, LRESULT *pResult) {  LPNMUPDOWN pNMUpDown = reinterpret_cast(pNMHDR);  // TODO: 在此添加控件通知处理程序代码    if

微信小程序uniappvue3版本-控制tabbar某一个的显示与隐藏

1. 首先在pages.json中配置tabbar信息 2. 在代码根目录下添加 tabBar 代码文件 直接把微信小程序文档里面的四个文件复制到自己项目中就可以了   3. 根据自己的需求更改index.js文件 首先我这里需要判断什么时候隐藏某一个元素,需要引入接口 然后在切换tabbar时,改变tabbar当前点击的元素 import getList from '../

gazebo 已加载模型但无法显示

目录 写在前面的话问题一:robot_state_publisher 发布机器人信息失败报错一 Error: Error document empty.报错二 .xcaro 文件中有多行注释成功启动 问题二:通过 ros2 启动 gazebo 失败成功启动 问题三:gazebo 崩溃和无法显示模型问题四: 缺少 robot_description 等话题正确的输出 写在前面的话