zoukankan      html  css  js  c++  java
  • cocos2d_x_03_经常使用类的使用_事件_画图

    一、TextFieldTTF输入框的使用


    #pragma mark - 自己定义方法
    // 自己定义方法,加入一个  TextField
    void TextFieldScene::addOneTextField(float x,float y)
    {
        TextFieldTTF *field = TextFieldTTF::textFieldWithPlaceHolder("请输入:","宋体",50);
        field->setPosition(x,y);
        // 加入精灵到当前 Layer
        this->addChild(field);
        
        // 2、实例化一个触摸监听器 对象
        auto listener = EventListenerTouchOneByOne::create();
        // 当触摸開始时,绑定一个闭包函数;
        // 【】表示 要传入的外界对象,此处是field
        // ()表示參数
        listener->onTouchBegan = [field](Touch *t,Event *e){
            // getLocation 返回一个OpenGL坐标
            // 假设点击的点,在textField上,才同意输入
        if (field->getBoundingBox().containsPoint(t->getLocation())) {
                field->attachWithIME();
            }else{
                field->detachWithIME();
            }
            return false;
        };
        // 3、获取事件分发器,加入一个事件监听器,到this身上;即监听的是field对象【文本输入框】
        Director::getInstance()->getEventDispatcher()->addEventListenerWithSceneGraphPriority(listener, field);
        
    }
    


    二、自己定义类Ball,继承自Sprite
    Ball.h

    CREATE_FUNC(type)宏

    Ball.cpp
    init方法的实现

    在主场景中使用自己定义类,创建实例对象
    能够是在onEnter()方法,也能够在init()方法


    三、Cocos2d-x的内存管理
    引用计数 reference count
    推荐:使用时,先retain,使用完release
    不建议:delete
    简化操作:创建完成后。使用autorelease();
    四、菜单的使用

    第1种方式:设置 回调函数 为 闭包函数,它属于c++11最新特性
    菜单项的 回调函数类型 定义例如以下:


    第2种方式:设置 菜单项 的回调方法,通过宏

    CC_CALLBACK_1宏

    .h文件里的回调方法声明

    .cpp文件里回调方法的实现

    五、TableView的使用

    导入cocos2d-x扩展头文件,里面有CCTableView.h

    场景继承自datasouce和delegate

    以下是数据源的方法声明

    以下是tableView代理的声明

    实例化一个tableView

    整个场景的完整的头文件

    整个场景的方法实现.cpp文件
    //
    //  TableViewScene.cpp
    //  01_cocos2d-x
    //
    //  Created by beyond on 14-10-4.
    #include "TableViewScene.h"
    
    Scene* TableViewScene::createScene()
    {
        // 'scene' 自己主动释放
        // 创建一个scene
        auto scene = Scene::create();
        
        // 'layer' 自己主动释放
        auto layer = TableViewScene::create();
        // 将图层 加入到场景中
        scene->addChild(layer);
        // 返回 填充好图层的 场景
        return scene;
    }
    
    // 在 "init" 方法中,实例化自己要用的精灵对象
    bool TableViewScene::init()
    {
        // 1. 调用父类的init , cpp 没有super,直接写父类名
        if ( !Layer::init() ) return false;
        // 屏幕尺寸
        winSize = Director::getInstance()->getVisibleSize();
        
        // 加入一个tableview
        Size size = Size(300, 300);
        TableView *tv = TableView::create(this, size);
        // 设置锚点
        tv->setAnchorPoint(Point(0, 0));
        // 设置位置
        tv->setPosition(winSize.width/2, winSize.height/2);
        // 设置代理
        tv->setDelegate(this);
        // 加入到this
        addChild(tv);
        
        
        return true;
    }
    
    #pragma mark - 数据源方法
    // 以下全是数据源方法
    // 共同拥有多少行
    ssize_t TableViewScene::numberOfCellsInTableView(TableView *table)
    {
        return 7;
    }
    // 每一行的尺寸
    Size TableViewScene::tableCellSizeForIndex(TableView *table, ssize_t idx)
    {
        return Size(300, 60);
    }
    // 每一行的cell
    TableViewCell* TableViewScene::tableCellAtIndex(TableView *table, ssize_t idx)
    {
        // 重用机制,先从缓存池中取,取不到再创建
        TableViewCell *cell = table->dequeueCell();
        
        LabelTTF *label;
        if (cell==NULL) {
            // 创建一个cell
            cell = TableViewCell::create();
            // 创建一个新的label
            label = LabelTTF::create();
            // 绑定标记
            label->setTag(5267);
            // 设置字体大小
            label->setFontSize(30);
            // 设置锚点
            label->setAnchorPoint(Point(0, 0));
            // 加入到cell
            cell->addChild(label);
        }else{
            // 直接取出cell里面的 label,又一次赋值
            label = (LabelTTF*)cell->getChildByTag(5267);
        }
        std::string arr[] = {"宝玉","黛玉","宝钗","湘云","探春","妙玉","晴雯"};
        // 设置label内容
        label->setString(StringUtils::format("Label %ld,%s",idx,arr[idx].c_str()));
        // 返回独一无二的cell
        return cell;
        
    }
    #pragma mark - 代理 方法
    //以下全是代理方法
    // 点击时调用
    void TableViewScene::tableCellTouched(TableView* table, TableViewCell* cell)
    {
        LabelTTF *label = (LabelTTF*)cell->getChildByTag(5267);
        std::string content = StringUtils::format("点击了第n行,内容是:%s",label->getString().c_str());
        MessageBox(content.c_str(), "标题");
    }


    重点是
    StringUtils::format();<span style="color: rgb(57, 57, 57); font-family: 'Courier New'; font-size: 24px;  line-height: 32px; background-color: rgb(245, 245, 245);"><strong>方法</strong></span>
    <span style="color: rgb(57, 57, 57); font-family: 'Courier New'; font-size: 24px;  line-height: 32px; background-color: rgb(245, 245, 245);"><strong>返回的是std::string对象,能够通过c_str()</strong></span><span style="font-family: 'Courier New'; background-color: rgb(245, 245, 245);">方法转成c字符串</span>

    重点是:重用机制

    tableCellTouched 相当于iOS中的didSlectedRowAtIndexPath

    六、场景切换

    效果图:

    场景.h头文件

    场景.cpp类实现
    加入一个LabelTTF,内容是空白字符串,监听点击事件,进行场景切换


    七、动作Action


    // 创建一个监听器对象
    auto listener = EventListenerTouchOneByOne::create();
    // 监听方法 用闭包函数实现
    listener->onTouchBegan = [label](Touch *t,Event *e){
        // 仅仅有点击的位置在label身上,才响应监听事件
        if (label->getBoundingBox().containsPoint(t->getLocation())) {
            // 绝对, 相对
            label->runAction(MoveTo::create(1, Point(100, 100)));
            label->runAction(MoveBy::create(1, Point(-50, -50))->reverse());
            // 同一时候并发运行 Spawn
            label->runAction(Spawn::create(MoveBy::create(1, Point(100, 100)), RotateBy::create(1, 360),NULL));
            
            label->runAction(Sequence::create(MoveBy::create(1, Point(100, 100)),RotateBy::create(1, 360), NULL));
            
            // 顺序运行 Sequence
            label->runAction(Sequence::create(
                                              MoveBy::create(1, Point(100, 100)),
                                              RotateBy::create(1, 360),
                                              // 闭包函数,实现 动作的侦听
                                              CallFunc::create([](){
                // 动作完毕时,弹出 对话框
                MessageBox("Action complete", "title");
            }),NULL));
        }
        
        return false;
    };
    // 向事件分发器 注冊一个事件侦听器,侦听发生在label身上的事件
    Director::getInstance()->getEventDispatcher()->addEventListenerWithSceneGraphPriority(listener, label);


    八、逐帧动画

    首先。下载Flash_Professional_13_LS20.dmg,约1G左右
    按以下方法,执行补丁

    打开Flash,打开【库Library】,点击左下角的新建button
    新建一个Symbol,类型选择【影片剪辑Movie Clip】;
    在第1帧先画一个正方形,按F6在第20帧创建一个关键帧;
    并在第20帧 删除原来的正方形,画一个圆形;
    在上面两个关键帧之间的随意一帧,右击,创建一个【形变补间动画shape tween】
    最后,重点,导出为cocos2d用的大纹理+Plist文件
    点击库,右击刚才创建的影片剪辑【movie clip】,选择【Generate Sprite Sheet】,data format选择【cocos2D v3】,选择【Export导出】
    这时,生成了plist文件+一个大纹理图片,例如以下所看到的

    plist文件

    精灵帧缓存、纹理缓存、SpriteBatchNode三者的关系


    //
    //  FrameAnimateScene.cpp
    //  01_cocos2d-x
    //
    //  Created by beyond on 14-10-4.
    //
    //
    
    #include "FrameAnimateScene.h"
    USING_NS_CC;
    Scene* FrameAnimateScene::createScene()
    {
        // 'scene' 自己主动释放
        // 创建一个scene
        auto scene = Scene::create();
        
        // 'layer' 自己主动释放
        auto layer = FrameAnimateScene::create();
        // 将图层 加入到场景中
        scene->addChild(layer);
        // 返回 填充好图层的 场景
        return scene;
    }
    
    // 在 "init" 方法中,实例化自己要用的精灵对象
    bool FrameAnimateScene::init()
    {
        // 1. 调用父类的init , cpp 没有super,直接写父类名
        if ( !Layer::init() ) return false;
        // 屏幕尺寸
        winSize = Director::getInstance()->getVisibleSize();
        
        // 2.加入一个精灵,播放帧动画
        this->addSpriteFrameAniamtion();
        return true;
    }
    
    #pragma mark - 自己定义方法
    // 2.加入一个精灵,播放帧动画
    void FrameAnimateScene::addSpriteFrameAniamtion(){
        // 精灵帧缓存 单例
        auto cache = SpriteFrameCache::getInstance();
        // 【精灵帧缓存】会依据plist中的key,到大纹理相冊中,分割并载入 小的精灵帧,放入帧缓存中,以后仅仅需 依据 小图片名,从【精灵帧缓存】中取出小精灵帧就可以
        cache->addSpriteFramesWithFile("anim.plist");
        
        // 容器,数组,里面存放的是精灵帧
        Vector<SpriteFrame*> vec;
        // 用来生成小精灵帧的图片名
        char name[15];
        // 用0清空内存
        memset(name, 0, 15);
        // 从帧缓存中取出全部的小精灵帧,放入Vector
        for (int i=0; i<20; i++) {
            // 格式化name,%04d,表示 不足四位 用填充
            sprintf(name, "anim%04d",i);
            // 将小精灵帧  加入容器
            vec.pushBack(cache->getSpriteFrameByName(name));
        }
        // 创建 Animation
        Animation *animation = Animation::createWithSpriteFrames(vec,0.1f);
        // 创建 Animate
        Animate *animate = Animate::create(animation);
        // 创建精灵
        auto sprite = Sprite::create();
        // 加入到 this
        addChild(sprite);
        // 设置位置
        sprite->setPosition(200, 200);
        // 运行序列帧动画
        Sequence *seq = Sequence::create(animate,animate->reverse(), NULL);
        sprite->runAction(RepeatForever::create(seq));
    }
    
    
    
    
    
    
    


    九、事件的传递
    listener->onTouchBegan方法中,返回的bool值 决定了onTouchMove方法是否可以被触发
    onTouchBegan方法,返回值是bool,參数:Touch *t,Event *e
    当中,參数Event *e中,e->getCurrentTarget()得到的是被点击的对象,即 向事件分发器中注冊listener时,绑定的Node对象
    此外,仅仅要是Node都能够监听事件


    多点触摸

    OneByOne是单点触摸】【AllAtOnce是多点触摸】


    加速计事件

    1、必须先 同意加速计事件

    2、事件类型是【EventListenerAcceleration

    关于加速计的方向x y z

    当手机竖着,x方向的加速值,约等于0

    当手机向右倾斜,x方向的加速值,添加

    当手机全然向右倾斜,x方向的加速值,约等于+1.0

    当手机向左倾斜,x方向的加速值,减小

    当手机全然向左倾斜,x方向的加速值,约等于-1.0


    侦听 Android菜单键返回键

    事件类型是【EventListenerKeyboard

    闭包函数的參数1:键盘码,当中,菜单键是【4199,返回键是【8】    


    十、画图API
    效果图:

    Node类有一个虚方法draw(),仅仅要覆写,就能够绘制自己的Node

    自己定义类,继承自Node



    draw()方法中,主要使用到的类是【DrawPrimitives

    DrawPrimitives类绘制图形,但已经过期~


    在draw()方法中绘制 矩形

    在draw()方法中绘制 填充矩形SolidRect

    在draw()方法中绘制 圆形

     圆心 半径 角度360  segment50 true表示要连接一根线到圆心

     注意 4个參数 segment 3 ,事实上是画一个三角形;当为50段时,就比較接近圆了

     计算机 事实上 无法直接画圆,就是当分段数目segment趋近无穷大时,就接近于圆了



    在draw()方法中绘制 填充圆形 Solid


    在draw()方法中绘制 多边形 顶点数组


    在draw()方法中绘制 填充多边形

    在draw()方法中绘制 画直线

    在draw()方法中绘制 画点


























  • 相关阅读:
    洛谷 P1032 字串变换
    map && multimap
    【转载】Pycharm调试高效,还是pdb调试高效? (在服务端)
    弱国无外交 弱国一定无外交吗
    [转发]Linux性能测试工具之Lmbench特性、安装及使用
    fedora21 桌面用户自动登录lightdm.conf -20190520 方法
    获取显卡硬件信息lspci -vnn | grep VGA -A 12
    mate桌面用户 root 自动登录lightdm.conf -20190520 方法【fedora 21】mate
    在线文本差异对比
    【科目三】机考 教练不出话 态度要好
  • 原文地址:https://www.cnblogs.com/gavanwanggw/p/6917234.html
Copyright © 2011-2022 走看看