好的,项目建好了,运行了看了效果,连cocos2dx那么经典的背景图都没了,不行,我们来修改他们。

到我们创建项目路径查看


四个文件夹加一个json文件

第二个res文件夹就是我们放资源的地方

第四个scr文件夹就是我们lua脚本的存放位置

看看这个配置json文件里面有是什么


真是我们模拟器的配置信息(你这他么不是废话么,-o-!!!)。


既然我们要显示经典的cocos2dx外星人背景图,先去cocos2dx文件夹盗一张图放到我们res文件夹下(呸,都是自家的,怎么能用盗字呢!)


现在修改脚本,达到我们要的效果。开工......

我们用sublime text打开项目文件夹(请忽略未注册信息吧-0- )


看到我们res文件夹下面有了这张图

我么进入src看看这个结构是咋样的


src/app文件夹下面就是我们要写lua脚本的存放位置

cocos文件夹放的是引擎的lua文件

framework文件夹存放的就是quick封装cocos2dx lua API的地方

在scr下面的有mian.lua和config.lua文件

打开config.lua

-- 0 - disable debug info,1 - less debug info,2 - verbose debug info --是否显示debug信息
DEBUG = 1

-- display FPS stats on screen  --是否显示fps信息
DEBUG_FPS = true

-- dump memory info every 10 seconds  --是否每10s输出debug内存信息 
DEBUG_MEM = false

-- load deprecated API     --是否导入不推荐使用的api
LOAD_DEPRECATED_API = false

-- load shortcodes API    --是否导入简码API
LOAD_SHORTCODES_API = true

-- screen orientation    --屏幕方向
CONfig_SCREEN_ORIENTATION = "portrait"

-- design resolution   --设计分辨率
CONfig_SCREEN_WIDTH  = 640
CONfig_SCREEN_HEIGHT = 960

-- auto scale mode      --自适应模式
CONfig_SCREEN_AUTOSCALE = "FIXED_WIDTH"
这里存放的就是配置信息了(我又说废话,但是不说的,上下文承接。。。。呜呜呜,让我说完。呜呜呜。。啊,别打脸。。)


这个main.lua相当于我们写c++的cocos2dx 的win32文件夹里面的main.cpp文件了,看一下

require("app.MyApp").new():run()
运行的是app下面的MyApp.lua文件

我们打开这个文件

require("config")
require("cocos.init")
require("framework.init")

local MyApp = class("MyApp",cc.mvc.AppBase)

function MyApp:ctor()
    MyApp.super.ctor(self)
end

function MyApp:run()
    cc.FileUtils:getInstance():addSearchPath("res/")
    self:enterScene("MainScene")
end

return MyApp

我们就看run函数即可,他进入的是MainScene场景

我们打开scenes文件夹下面的MainScene.lua文件

local MainScene = class("MainScene",function()
    return display.newScene("MainScene")
end)

function MainScene:ctor()
    cc.ui.UILabel.new({
            UILabelType = 2,text = "Hello,World",size = 64})
        :align(display.CENTER,display.cx,display.cy)
        :addTo(self)
end

function MainScene:onEnter()
end

function MainScene:onExit()
end

return MainScene

ok,看到Hello,world字样了吧,这边就是主要修改的地方了

修改前,我们先分析下这段简短的代码

注意:class这个函数lua是没有的,是引擎提供的,在\quick-3.3rc1\quick\framework\functions.lua里面有原型,有兴趣自己去看看

在定义自己的类的时候,用local修饰,这样才不会污染全局变量表。

我们看ctor函数,这边就是我们MainScene类的构造函数了,作用和c++ cocos2dx的init函数差不多,我们在里面初始化我们要的精灵,UI等东西


我们先分析第一个cc.ui.UILabel.new函数,其他的我们都很容易看懂,但是这个UILabelType=2中2是什么类型,我们还是看这个函数原型,文件在G:\quick-3.3rc1\quick\framework\cc\ui\UILabel.lua

local UILabel
UILabel = class("UILabel",function(options)
	if not options then
		return
	end

	if 1 == options.UILabelType then
		return UILabel.newBMFontLabel_(options)
	elseif not options.UILabelType or 2 == options.UILabelType then
		return UILabel.newTTFLabel_(options)
	else
		printInfo("UILabel unkonw UILabelType")
	end
end)

UILabel.LABEL_TYPE_BM					= 1
UILabel.LABEL_TYPE_TTF 					= 2

原来这是用TTF方式创建Label(所以看到不懂的,最好跳转到定义哪里看一下,就清楚这个魔数啥意思了,推荐sublime text装个quickxdev这个插件,能帮你转到函数定义处)

align函数就是这是设置这个label的位置,第一个参数是锚点 第二 三的参数就是x,y。在c++的cocos2dx里面这个我们要写两行,这里我们只要一行就ok了

addTo函数作用就是把当前结点作为一个子结点加到target中

你可以改成

function MainScene:ctor()
	local label =  cc.ui.UILabel.new({UILabelType = 2,size = 64})
    label:align(display.CENTER,display.cy)
    self:addChild(label)
end
换到模拟器,F5一下模拟器,我们看到,效果是一样的


扯了半天,还没有做我们正事,显示背景图,并且将文字修改成其他的

下面是修改的ctor函数

function MainScene:ctor()
	local label =  cc.ui.UILabel.new({UILabelType = 2,text = "Hi,yiye3376",display.height-100)
    self:addChild(label)

    display.newSprite("Hello.png",display.cy)
    	:addTo(self)
end

写完,保存

display是什么?display 模块封装了绝大部分与显示有关的功能,并负责根据 config.lua 中定义的分辨率设定计算屏幕的设计分辨率。

更多函数使用方法查看这个文件就行了

框架初始化后,display 模块提供下列属性:

-   display.sizeInPixels.width,-   display.sizeInPixels.height 屏幕的像素分辨率
-   display.widthInPixels,-   display.heightInPixels 屏幕的像素分辨率
-   display.contentScaleFactor 内容缩放因子
-   display.size.width,-   display.size.height 屏幕的设计分辨率
-   display.width,-   display.height 屏幕的设计分辨率
-   display.cx,-   display.cy 屏幕中央的 x 坐标和 y 坐标
-   display.left,-   display.top,-   display.right,-   display.bottom 屏幕四边的坐标
-   display.c_left,-   display.c_top,-   display.c_right,-   display.c_bottom 当父对象在屏幕中央时,屏幕四边的坐标


f5查看效果图



好,看到效果了,很好

Quick cocos2dx-LuaV3.3R1学习笔记(2)----不要老是显示Hello World,我们显示点别的的更多相关文章

  1. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

  2. ios – 将UIViewController视图属性设置为不带有storyboard / nib的自定义UIView类

    或者上面的代码片段是推荐的吗?

  3. 在iOS App中使用CoreAnimation / QuartzCore动画UILabel

    我实际上在我的iOS应用程序中设置了动画UILabel的问题.在网上搜索代码片段2天后,仍然没有结果.我找到的每个样本都是关于如何为UIImage制作动画,将它作为子视图添加到UIView中.有没有关于动画UILabel的好例子?我通过设置alpha属性为闪烁动画找到了一个很好的解决方案,如下所示:我的功能:在UILabel上调用我的函数:但是pulse或缩放动画呢?另一个注意事项–可以在here找到CALayer动画属性的完整列表.快乐的补间!

  4. uitableview – UILabel和UILabel在iOS 7中的省略号颜色变化

    提前谢谢你的帮助!

  5. ios – UILabel在垂直生长和断线时添加了不必要的顶部和底部填充

    )之间切换也不能解决问题.我能够在Xcode6和Xcode7beta,InterfaceBuilder以及运行应用程序时重现此行为.解决方法看起来修复无意填充的唯一方法是将Lines设置为常量(例如3).UILabel仍将动态增长,并且不会添加任何填充.

  6. ios – 如何根据文本计算TextView高度

    我使用下面的代码计算文本的高度,然后为UILabel和UITextView设置此高度这对于UILabel来说是完美的,但对于UITextView来说,它计算错误.我认为问题的发生是因为UITextView的填充(左,右)比UILabel大.那么如何计算正确的文本大小以便在UITextView中显示.任何帮助或建议将非常感谢.如下面的描述图片具有相同的大小(300),相同的字体,相同的文字,但UIT

  7. ios – UILabel有两种不同颜色的文字

    我怎么能有一个UILabel有两种不同颜色的字体?

  8. ios – 默认的自动布局内容拥抱和内容压缩阻抗优先级值是什么?

    我正在尝试调试自动布局问题,并且知道内容拥抱和内容压缩阻力优先级的默认值将有所帮助.这些是什么?它们是否特定于特定组件?我可以使用常量来引用它们吗?

  9. ios – 突出显示UILabel中的文本

    我正在尝试设置背景颜色/突出显示在UILabel内的文本.问题在于,还会突出显示添加到UILabel中以保持文本居中的换行符和空格.注意UILabel最后一行之前的间距突出显示.此外,任何新行的开始和结束也突出显示.我使用以下代码创建上面的示例:我想实现的输出是只突出显示文本和单词之间的空格,如果只有一个空格.文本的长度和UILabel的大小会不断变化,所以硬编码解决方案不是一个选择.解决方法在我

  10. ios – 更改UIBarButtonItem标题时,转换是抖动/闪烁

    解决方法而不是再次设置标题,您可以再次使用标题设置按钮,然后将其动画化:

随机推荐

  1. 【cocos2d-x 3.x 学习笔记】对象内存管理

    Cocos2d-x的内存管理cocos2d-x中使用的是上面的引用计数来管理内存,但是又增加了一些自己的特色。cocos2d-x中通过Ref类来实现引用计数,所有需要实现内存自动回收的类都应该继承自Ref类。下面是Ref类的定义:在cocos2d-x中创建对象通常有两种方式:这两中方式的差异可以参见我另一篇博文“对象创建方式讨论”。在cocos2d-x中提倡使用第二种方式,为了避免误用第一种方式,一般将构造函数设为protected或private。参考资料:[1]cocos2d-x高级开发教程2.3节[

  2. 利用cocos2dx 3.2开发消灭星星六如何在cocos2dx中显示中文

    由于编码的不同,在cocos2dx中的Label控件中如果放入中文字,往往会出现乱码。为了方便使用,我把这个从文档中获取中文字的方法放在一个头文件里面Chinese.h这里的tex_vec是cocos2dx提供的一个保存文档内容的一个容器。这里给出ChineseWords,xml的格式再看看ChineseWord的实现Chinese.cpp就这样,以后在需要用到中文字的地方,就先include这个头文件然后调用ChineseWord函数,获取一串中文字符串。

  3. 利用cocos2dx 3.2开发消灭星星七关于星星的算法

    在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix,如果还不知道怎么创建星星矩阵请回去看看而且我们也讲了整个游戏的触摸事件的派发了。

  4. cocos2dx3.x 新手打包APK注意事项!

    这个在编译的时候就可以发现了比较好弄这只是我遇到的,其他的以后遇到再补充吧。。。以前被这两个问题坑了好久

  5. 利用cocos2dx 3.2开发消灭星星八游戏的结束判断与数据控制

    如果你看完之前的,那么你基本已经拥有一个消灭星星游戏的雏形。开始把剩下的两两互不相连的星星消去。那么如何判断是GameOver还是进入下一关呢。。其实游戏数据贯穿整个游戏,包括星星消除的时候要加到获得分数上,消去剩下两两不相连的星星的时候的加分政策等,因此如果前面没有做这一块的,最好回去搞一搞。

  6. 利用cocos2dx 3.2开发消灭星星九为游戏添加一些特效

    needClear是一个flag,当游戏判断不能再继续后,这个flag变为true,开始消除剩下的星星clearSumTime是一个累加器ONE_CLEAR_TIME就是每颗星星消除的时间2.连击加分信息一般消除一次星星都会有连击信息和加多少分的信息。其实这些combo标签就是一张图片,也是通过控制其属性或者runAction来实现。源码ComboEffect.hComboEffect.cpp4.消除星星粒子效果消除星星时,为了实现星星爆裂散落的效果,使用了cocos2d提供的粒子特效引擎对于粒子特效不了

  7. 02 Cocos2D-x引擎win7环境搭建及创建项目

    官网有搭建的文章,直接转载记录。环境搭建:本文介绍如何搭建Cocos2d-x3.2版本的开发环境。项目创建:一、通过命令创建项目前面搭建好环境后,怎样创建自己的Cocos2d-x项目呢?先来看看Cocos2d-x3.2的目录吧这就是Cocos2d-x3.2的目录。输入cocosnew项目名–p包名–lcpp–d路径回车就创建成功了例如:成功后,找到这个项目打开proj.win32目录下的Hello.slnF5成功了。

  8. 利用cocos2dx 3.2开发消灭星星十为游戏添加音效项目源码分享

    一个游戏,声音也是非常的重要,其实cocos2dx里面的简单音效引擎的使用是非常简单的。我这里只不过是用一个类对所有的音效进行管理罢了。Audio.hAudio.cpp好了,本系列教程到此结束,第一次写教程如有不对请见谅或指教,谢谢大家。最后附上整个项目的源代码点击打开链接

  9. 03 Helloworld

    程序都有一个入口点,在C++就是main函数了,打开main.cpp,代码如下:123456789101112131415161718#include"main.h"#include"AppDelegate.h"#include"cocos2d.h"USING_NS_CC;intAPIENTRY_tWinMain{UNREFERENCED_ParaMETER;UNREFERENCED_ParaMETER;//createtheapplicationinstanceAppDelegateapp;return

  10. MenuItemImage*图标菜单创建注意事项

    学习cocos2dx,看的是cocos2d-x3.x手游开发实例详解,这本书错误一大把,本着探索求知勇于发现错误改正错误的精神,我跟着书上的例子一起调试,当学习到场景切换这个小节的时候,出了个错误,卡了我好几个小时。

返回
顶部