Cocos2d-X 使用CCTableView创建滚动视图

CCTableView和CCScrollView一样用于创建滚动视图,CCTableView的功能也比较多,创建比较麻烦

实例1:使用CCTableView创建滚动视图

首先创建一个TableView类

TableView.h中的代码

#ifndef __TableView_H__
#define __TableView_H__

#include "cocos2d.h"
#include "cocos-ext.h"
USING_NS_CC;
USING_NS_CC_EXT;

class TableView : public CCLayer, public CCTableViewDataSource, public CCTableViewDelegate
{
public:
    virtual bool init();  

    static CCScene* scene();

    CREATE_FUNC(TableView);

    //创建一个数组
    CCArray* _arr;

    //返回格子的大小
    virtual CCSize tableCellSizeForIndex(CCTableView *table, unsigned int idx)
    {
        return cellSizeForTable(table);
    };

    //每个格子的大小
    virtual CCSize cellSizeForTable(CCTableView *table)
    {
        //返回窗口的大小
        return CCDirector::sharedDirector()->getWinSize();
    }

    //返回格子的编号
    virtual CCTableViewCell* tableCellAtIndex(CCTableView *table, unsigned int idx)
    {
        return (CCTableViewCell*)_arr->objectAtIndex(idx);
    }

    //返回滚动的大小(格子的个数)
    virtual unsigned int numberOfCellsInTableView(CCTableView *table)
    {
        return _arr->count();
    }

    virtual void tableCellTouched(CCTableView* table, CCTableViewCell* cell)
    {
        CCLog("clicked cell is %d", cell->getIdx());
    }

    virtual void scrollViewDidScroll(CCScrollView* view){};
    virtual void scrollViewDidZoom(CCScrollView* view){};
};

#endif // __TableView_H__

TableView.cpp中的代码

#include "TableView.h"

CCScene* TableView::scene()
{
    CCScene *scene = CCScene::create();

    TableView *layer = TableView::create();

    scene->addChild(layer);

    return scene;
}

bool TableView::init()
{
    CCLayer::init();

    CCSize winSize = CCDirector::sharedDirector()->getWinSize();
    CCPoint center = ccp(winSize.width / 2, winSize.height / 2);

    //先创建好CCTableViewCell

    //创建一个数组
    _arr = CCArray::create();

    _arr->retain();

    for(int i = 0; i < 5; i++)
    {
        CCTableViewCell* cell = new CCTableViewCell();
        cell->autorelease();
        _arr->addObject(cell);

        CCSprite* sprite = CCSprite::create("HelloWorld.png");
        cell->addChild(sprite);
        sprite->setPosition(center);
    }

    //创建TableView
    CCTableView* tableView =  CCTableView::create(this, winSize);
    addChild(tableView);

    //设置TableView的滚动方向
    //kCCScrollViewDirectionHorizonta表示在水平方向上滚动
    tableView->setDirection(kCCScrollViewDirectionHorizontal);

    //加载数据
    tableView->reloadData();

    tableView->setDelegate(this);

    return true;
}

执行结果:

实例2:使用CCTableView创建一个小窗口的滚动视图(该功能常用于游戏中的选择道具)

首先创建一个TableViewSmall类

TableViewSmall.h中的代码

#ifndef __TableViewSmall_H__
#define __TableViewSmall_H__

#include "cocos2d.h"
#include "cocos-ext.h"
USING_NS_CC;
USING_NS_CC_EXT;

class TableViewSmall : public CCLayer, public CCTableViewDataSource, public CCTableViewDelegate
{
public:
    virtual bool init();  

    static CCScene* scene();

    CREATE_FUNC(TableViewSmall);

    //创建一个数组
    CCArray* _arr;

    //返回格子的大小
    virtual CCSize tableCellSizeForIndex(CCTableView *table, unsigned int idx)
    {
        if(1 == idx)
        {
            return CCSizeMake(60, 40);
        }

        return cellSizeForTable(table);
    };

    //每个格子的大小
    virtual CCSize cellSizeForTable(CCTableView *table)
    {
        //每个格子的大小
        return CCSizeMake(40, 40);
    }

    //返回格子的编号
    virtual CCTableViewCell* tableCellAtIndex(CCTableView *table, unsigned int idx)
    {
        return (CCTableViewCell*)_arr->objectAtIndex(idx);
    }

    //返回滚动的大小(格子的个数)
    virtual unsigned int numberOfCellsInTableView(CCTableView *table)
    {
        return _arr->count();
    }

    virtual void tableCellTouched(CCTableView* table, CCTableViewCell* cell)
    {
        CCLog("clicked cell is %d", cell->getIdx());
    }

    virtual void scrollViewDidScroll(CCScrollView* view){};
    virtual void scrollViewDidZoom(CCScrollView* view){};
};

#endif // __TableViewSmall_H__

TableViewSmall.cpp中的代码

#include "TableViewSmall.h"

CCScene* TableViewSmall::scene()
{
    CCScene *scene = CCScene::create();

    TableViewSmall *layer = TableViewSmall::create();

    scene->addChild(layer);

    return scene;
}

bool TableViewSmall::init()
{
    CCLayer::init();

    CCSize winSize = CCDirector::sharedDirector()->getWinSize();
    CCPoint center = ccp(winSize.width / 2, winSize.height / 2);

    //先创建好CCTableViewCell

    //创建一个数组
    _arr = CCArray::create();

    _arr->retain();

    for(int i = 0; i < 5; i++)
    {
        CCTableViewCell* cell = new CCTableViewCell();
        cell->autorelease();
        _arr->addObject(cell);

        CCSprite* sprite = CCSprite::create("CloseNormal.png");
        cell->addChild(sprite);
        sprite->setPosition(ccp(20, 20));
    }

    //创建TableView
    CCTableView* tableView =  CCTableView::create(this, CCSizeMake(40 * 3, 40));
    addChild(tableView);

    //设置TableView的滚动方向
    //kCCScrollViewDirectionHorizonta表示在水平方向上滚动
    tableView->setDirection(kCCScrollViewDirectionHorizontal);

    //加载数据
    tableView->reloadData();

    tableView->setDelegate(this);

    tableView->setPosition(center);

    return true;
}

执行结果:



时间: 2024-10-12 23:26:21

Cocos2d-X 使用CCTableView创建滚动视图的相关文章

Cocos2d-X使用CCScrollView创建滚动视图

CCScrollView可以使游戏有滚动视图的效果,并且可以通过滚动视图切换游戏场景,滚动视图常用于游戏中选择关卡 实例1:使用CCScrollView创建一个简单的滚动视图 首先创建一个ScrollView类 然后在ScrollView.h中添加下面的代码 #ifndef __ScrollView_H__ #define __ScrollView_H__ #include "cocos2d.h" #include "cocos-ext.h" USING_NS_CC

Cocos2d-X采用CCScrollView创建滚动视图

CCScrollView滚动视图可以让游戏有效果,并能够通过滚动视图切换游戏场景,滚动视图通常用来选择在游戏中的级别 实例1:使用CCScrollView创建一个简单的滚动视图 首先创建一个ScrollView类 然后在ScrollView.h中加入以下的代码 #ifndef __ScrollView_H__ #define __ScrollView_H__ #include "cocos2d.h" #include "cocos-ext.h" USING_NS_C

MFC小程序003------MFC使用WebBrowser组件,在对话框中创建滚动视图,动态创建一个静态文本控件并设置鼠标单击的消息响应

MFC小程序截图: 一.在MFC中简单使用WebBrowser的ActiveX插件的方法: 见博文:  http://blog.csdn.net/supermanking/article/details/5866213 二.在对话框中创建视图(我这里创建的是一个滚动视图): 见博文: http://blog.csdn.net/clever101/article/details/4873994 http://blog.csdn.net/clever101/article/details/37790

【转载】cocos2dx基础篇(16)——滚动视图CCScrollView

[唠叨] 本节要讲讲滚动视图CCScrollView,相信玩过手游的同学们应该对它不会陌生吧. 例如:愤怒的小鸟的游戏场景里大大的地图,手机的屏幕肯定无法完全显示的,所以需要通过触摸滚动才能显示大地图的其他区域:排行榜中上下滑动来查看其他玩家的排名:以及手机上主界面左右滑动来切换界面等等. 如下图为屏幕滚动,切换手机的界面. [致谢] http://blog.csdn.net/paea_gulang/article/details/10283601 [Demo下载] https://github

cocos2dx基础篇(16)——滚动视图CCScrollView

[唠叨] 本节要讲讲滚动视图CCScrollView,相信玩过手游的同学们应该对它不会陌生吧. 例如:愤怒的小鸟的游戏场景里大大的地图,手机的屏幕肯定无法完全显示的,所以需要通过触摸滚动才能显示大地图的其他区域:排行榜中上下滑动来查看其他玩家的排名:以及手机上主界面左右滑动来切换界面等等. 如下图为屏幕滚动,切换手机的界面. [致谢] http://blog.csdn.net/paea_gulang/article/details/10283601 http://bbs.firedragonpz

滚动视图和页面控制UIScollView,UIpageControlDemo

////  ViewController.m//  UIScollView////  Created by hehe on 15/9/25.//  Copyright (c) 2015年 wang.hehe. All rights reserved.// #import "ViewController.h"#define width_screen self.view.bounds.size.width#define height_screen self.view.bounds.size

制作滚动视图(ScrollView)

怎样判断是否应当使用滚动视图 所谓的滚动视图,是指一个可以滑动的视窗,视窗大小和位置固定不变,视窗内的内容用户可以通过手指滑动或者拖动滚动天来进行滚动浏览. 滚动视图的目的是为了解决同类内容过多,一个UI版面显示不下的情况.如果同类内容过多,一般可以采取设置多个页面,然后通过翻页浏览的方式来浏览,但是很明显,滚动视图会比翻页更方便,因为在移动上可以很方便地花瓶进行滚动,在PC上可以通过鼠标的滚动进行滚动. 当需要判断是否应该使用滚动视图制作UI时,可以遵循以下规律: (1)有很多同类内容一个版面

ios &ndash; 滚动视图(UIScrollView)详解

移动的设备的屏幕大小有限,当一个视图要显示的内容大于屏幕尺寸的时候就要用到滚动视图,比如一个网页的内容通常比屏幕尺寸大,那么浏览器就使用了滚动视图.   UIScrollView有一个contentSize属性,声明如下: @property(nonatomic) CGSize contentSize; 这个属性表示滚动视图的内容有多大. 创建滚动视图实例: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup

Cocos2d-x学习笔记(14)(更新函数scheduleUpdate、进度计时器CCProgressTo、滚动视图CCScrollView)

一.scheduleUpdate 1.scheduleUpdate:此函数是CCNode的函数,每一个CCNode仅仅要调用scheduleUpdate更新函数,那么这个CCNode就会响应当前类的update(float dt)函数. 首先在头文件里定义update函数:void update(float dt): 接下来在cpp文件里的初始化函数调用scheduleUpdate()函数: 实现update更新函数. 2.schedule:其作用于scheduleUpdate()函数同样,可是