【iOS-Cocos2d游戏开发之二十】精灵的基础知识点总汇(位图操作/贴图更换/重排z轴等)及制作简单遮盖层!

简介:

最近写了不少Cocos2d的博文了,那么由于Himi介绍的一般都是比较容易出错的问题或者比较受到关注的知识点,所以不少童鞋要求写个基础篇,那么这里Himi就举例最常用的精灵CCSprite来详细的介绍一些吧; 考虑到网上对于Cocos2d-iphone的中文教程已有很多,所以这里Himi会拿出一些教程没有提到的基础知识点来分享;

     首先我们来创建一个精灵: 


  
  
  1. CCSprite* sprite =[CCSprite spriteWithFile:@"Icon.png"];//初始化   
  2. [self addChild:sprite]; //添加入层中   

    代码很简单,传入一张贴图名即可,然后添加层中,那么这里Himi说几点:

 

 1. 精灵除了这个创建函数外,还有很多方法,最重要的另一个就是利用打包工具打包出来的帧缓存中加载贴图并创建;关于打包工具Himi使用的是TP,还有其他一些这里不介绍了,Himi之前的博文也有对应的介绍;

 2.精灵默认添加进layer中默认是layer的(0,0)点,即屏幕的左下角;而且精灵的贴图绘制是以精灵的贴图中心点进行渲染的,简单说如果精灵贴图大小看成单位一,精灵的锚点(anchor)是(0.5,0.5);这个是精灵默认锚点,当然也可以设置锚点,这个锚点的范围是[0,1];

3.大家如果刚接触一门新语言、引擎、框架等就要慢慢找到它们的规律,比如在cocos2d中一般创建都是类似的创建方式,而初始化的函数基本都是以类名后的一个单词作为开头;比如咱们这个CCSprite类,它的构造函数就是sprite开头的;

    OK,知道如何创建一个精灵了,下面我们来写一点精灵的常用方法和基本位图操作吧:


  
  
  1. CCSprite* sprite =[CCSprite spriteWithFile:@"Icon.png"];//初始化   
  2. [self addChild:sprite]; //添加入层中   
  3. sprite.scale=2;//放大2倍   
  4. sprite.rotation=90;//旋转90度   
  5. sprite.opacity=255;//设置透明度为完全不透明(范围0~255)   
  6. sprite.position=ccp(100,100);//设置精灵中心点坐标是x=100,y=100   
  7. [sprite setFlipX:YES];//X轴镜像反转   
  8. [sprite setFlipY:YES];//Y轴镜像反转   
  9. [sprite setColor:ccc3(255, 0, 0)];//设置颜色为红色  

   关于精灵的动作这些N多文章都写过了,这里我就不写了,没意义,我这里给大家再讲解下童鞋们经常纠结的两个问题:

 

1.如何重新设置精灵的z轴(覆盖层)?

       对于这个问题,很多童鞋无法找到方法的原因主要是因为大家首先想到的是更改精灵的Z轴值的大小(Z轴值越大离屏幕越近),那么就会错误的使用下面这段代码:


  
  
  1. sprite.zOrder=2;  

这句话是不允许使用的错误代码,因为精灵的zOrder属性只能可读不可修改;那么Himi提供大家一个解决方法,那就是利用布局去重新设置你想设置的精灵的z轴值,例如以下代码:(111.png是我从博客随便截出来的图,反正比Icon.png大就可以,这样童鞋们就能看得清楚了)

  
  
  1. //--z值1的精灵   
  2. CCSprite* sprite =[CCSprite spriteWithFile:@"Icon.png"];   
  3. [self addChild:sprite z:1]; //添加入层中   
  4. sprite.position=ccp(300,200);//设置精灵中心点坐标是x=100,y=100   
  5. //--z值2的精灵   
  6. CCSprite* sprite2 =[CCSprite spriteWithFile:@"111.png"];   
  7. [self addChild:sprite2 z:2];    
  8. sprite2.position=ccp(220,120);   

 

从代码中可以很清晰看到第二个精灵sprite2的z轴大于第一个精灵sprite的z轴值,那么sprite2肯定是覆盖sprite上的,运行效果图如下:

 

下面我们来利用layer对第一个精灵进行z轴重新设定,代码如下:


  
  
  1. [self reorderChild:sprite z:10];  

self:  CCLayer   sprite:  想要重新设置z轴(覆盖层)的精灵   z: 想要重新设置z轴(覆盖层)的精灵的z轴值

  OK,那么我们重新设置了第一个精灵的z轴值为10,这时候精灵1比精灵2的z轴大了,1会覆盖2精灵,运行效果如下图:

 

 

2.如何更换已创建的精灵贴图?

    在上面我介绍了精灵的创建一般有两种:一种是利用帧缓存,另一种是直接索引贴图ID进行创建;所以呢更换精灵贴图也一般分为两种方法;

首先介绍第一种直接利用新建贴图进行更换:

 实例代码如下:


  
  
  1. //-----没有换贴图前   
  2. CCSprite*sprite =[CCSprite spriteWithFile:@"Icon.png"];   
  3. sprite.position=ccp(150,150);   
  4. [self addChild:sprite];   
  5. //-----换贴图后   
  6. CCSprite*sprite2 =[CCSprite spriteWithFile:@"Icon.png"];   
  7. sprite2.position=ccp(350,150);   
  8. [self addChild:sprite2];   
  9. //更换贴图   
  10. CCTexture2D * texture =[[CCTextureCache sharedTextureCache] addImage: @"Default.png"];//新建贴图   
  11. [sprite2 setTexture:texture];   

运行效果如下:

 

第二种利用帧替换:


  
  
  1. //加载帧缓存,这个testpngs.plist保存了Icon和111两张图,-hd表示高清版本iphone4   
  2. [[CCSpriteFrameCache sharedSpriteFrameCache] addSpriteFramesWithFile:@"testpngs-hd.plist"];   
  3. //-----没有换贴图前    
  4. CCSprite*sprite =[CCSprite spriteWithSpriteFrameName:@"Icon.png"];   
  5. sprite.position=ccp(150,150);   
  6. [self addChild:sprite];   
  7. //-----换贴图后   
  8. CCSprite*sprite2 =[CCSprite spriteWithSpriteFrameName:@"Icon.png"];   
  9. sprite2.position=ccp(350,150);   
  10. [self addChild:sprite2];   
  11. //更换帧贴图   
  12. //从帧缓存中取出111.png   
  13. CCSpriteFrame* frame2 = [[CCSpriteFrameCache sharedSpriteFrameCache] spriteFrameByName:@"111.png"];   
  14. [sprite2 setDisplayFrame:frame2];   

运行效果如下:

 

 

-------------下面来介绍如何来利用CCSprite精灵或者CCLayerColor简单实现一个简单的覆盖层(遮挡)效果

      首先利用CCSprite来实现,代码如下:


  
  
  1. CCSprite *sprLeft = [CCSprite spriteWithFile:@"Icon.png"];   
  2. sprLeft.position=ccp(100,180);   
  3. [self addChild:sprLeft];   
  4. //----创建一个简单的覆盖层   
  5. //获取当前屏幕宽高   
  6. CGSize size =[[CCDirector sharedDirector]winSize];   
  7. //创建一个精灵(无贴图)   
  8. CCSprite*sprite =[CCSprite node];   
  9. //设置精灵贴图大小(全屏幕宽高)   
  10. sprite.textureRect=CGRectMake(0, 0, size.width, size.height);   
  11. sprite.position=ccp(size.width*0.5,size.height*0.5);   
  12. sprite.opacity=127;//半透明[0~255]   
  13. sprite.color=ccc3(0, 0, 0);//设置黑色   
  14. [self addChild:sprite];   
  15. //----   
  16. CCSprite* sprRight = [CCSprite spriteWithFile:@"Icon.png"];   
  17. sprRight.position=ccp(300,180);   
  18. [self addChild:sprRight];   

      这里我创建了两个精灵一个被覆盖 一个不被覆盖 这样只要让童鞋们看得更清楚~

     下面利用第二种方式实现:


  
  
  1. //----   
  2. CCSprite *sprLeft = [CCSprite spriteWithFile:@"Icon.png"];   
  3. sprLeft.position=ccp(100,180);   
  4. [self addChild:sprLeft];   
  5. //----创建一个简单的覆盖层   
  6. //创建一个精灵(无贴图)   
  7. CCLayerColor *layer =[CCLayerColor layerWithColor:ccc4(0, 0, 0, 127)];   
  8. [self addChild:layer];   
  9. //----   
  10. CCSprite* sprRight = [CCSprite spriteWithFile:@"Icon.png"];   
  11. sprRight.position=ccp(300,180);   
  12. [self addChild:sprRight];  

 

      第二种方法大家可以看到就两句话实现,原因这里解释下:

                第一种设置了贴图大小,layer不需要!因为layer默认全屏;

                第一种设置了坐标,layer不需要!因为layer默认屏幕中心点;

            第一种设置了透明度和颜色,layer也设置了~在layer创建的时候创建的,在layer创建时传入的四个数:

                四个参数分别表示RGBA!注意是RGBA!!!!不是ARGB!(因为Himi做过me、Android所以看到设置颜色第一概念就是ARGB。。所以刚接触这里各种郁闷,总是效果不是如自己想的。。。)

               这里补充下:RGBA 颜色的三原色,红色、绿色、蓝色、透明度!

 两种实现方式效果都如下图所示:

 

 

希望童鞋们在初学的时候尽可能的遇到问题按照如下顺序去做:首先自己多次尝试->去看源码->百度google->最后请教他人

      OK,就写到这里!下篇见~继续忙了;           










本文转自 xiaominghimi 51CTO博客,原文链接:http://blog.51cto.com/xiaominghimi/710944,如需转载请自行联系原作者
目录
相关文章
|
监控 API iOS开发
iOS触动精灵模拟触控类外挂原理分析
一、外挂功能: 类似于模拟按键,该类型外挂主要用于通过图像识别,利用luac脚本对图像进行识别。而后再通过私有api实现触屏操作的功能。     二、外挂特征 外挂安装后,会有下面三个主要程序,touchsprite,tsevent,tsdeamon. 其中,touchsprite 为gui的界面程序,其主要功能为提供交互界面由用户选择加载的脚本。(脚本保存在/Us
4225 0
|
1天前
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
26天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
118 66
|
12天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈