cocos2dx tableview基础:实现多图片的滑动显示
来源:互联网 发布:政府层级结构优化导向 编辑:程序博客网 时间:2024/05/17 16:03
通过tableview实现滑动显示26个字母图片,点击图片执行相应的动作。
tableview 需要继承TableViewDataSource(数据源),TableViewDelegate(触屏事件处理),同时实现其虚函数。
代码如下:
头文件TableViewTest.h如下:
#ifndef __macstudycocos2dx__TableViewTest__
#define __macstudycocos2dx__TableViewTest__
#include <stdio.h>
#include "cocos2d.h"
#include "extensions/cocos-ext.h"
USING_NS_CC;
USING_NS_CC_EXT;
//void runTableViewTest();
class TableViewTest:publiccocos2d::Layer,publiccocos2d::extension::TableViewDataSource,publiccocos2d::extension::TableViewDelegate
{
public:
static cocos2d::Scene* createScene();
virtual bool init();
void toExtensionMainLayer(cocos2d::Ref *sender);
CREATE_FUNC(TableViewTest);
virtual void scrollViewDidScroll(cocos2d::extension::ScrollView* view){};
//重写滑动事件
virtual void scrollViewDidZoom(cocos2d::extension::ScrollView* view){};
//重写缩放事件
//以下重写TableViewDataSource的虚函数
virtualvoid tableCellTouched(cocos2d::extension::TableView* table,cocos2d::extension::TableViewCell* cell);
//定义单元触碰事件
virtual Size tableCellSizeForIndex(TableView *table,ssize_t idx);
//定义单元的大小
virtual TableViewCell* tableCellAtIndex(cocos2d::extension::TableView* table,ssize_t idx);
//定义单元格
virtual ssize_t numberOfCellsInTableView(cocos2d::extension::TableView* table);
//定义单元格数量
};
#endif /* defined(__macstudycocos2dx__TableViewTest__) */
TableViewTest.cpp如下:
#include "TableViewTest.h"
Scene* TableViewTest::createScene()
{
// 'scene' is an autorelease object
auto scene = Scene::create();
// 'layer' is an autorelease object
auto layer = TableViewTest::create();
// add layer as a child to scene
scene->addChild(layer);
// return the scene
return scene;
}
bool TableViewTest::init(){
if (!Layer::init()) {
return false;
}
Size winSize=Director::getInstance()->getWinSize();
TableView* tableView=TableView::create(this,Size(800,300));
tableView->setDirection(ScrollView::Direction::HORIZONTAL);
tableView->setPosition(Vec2(20,winSize.height/2-30));
tableView->setDelegate(this);
this->addChild(tableView);
tableView->reloadData();
return true;
}
void TableViewTest::tableCellTouched(cocos2d::extension::TableView* table,TableViewCell* cell){
log("cell touched at index:%ld",cell->getIdx());
}
SizeTableViewTest::tableCellSizeForIndex(cocos2d::extension::TableView* table,ssize_t idx){
return Size(300,150);
}
TableViewCell* TableViewTest::tableCellAtIndex(cocos2d::extension::TableView* table,ssize_t idx){
auto letindex=idx+1;
auto string=String::createWithFormat("let%ld.png",letindex);
TableViewCell *cell=table->cellAtIndex(idx);
if (!cell) {
cell=newTableViewCell();
cell->autorelease();
auto sprite=Sprite::create(string->getCString());
sprite->setAnchorPoint(Vec2::ZERO);
sprite->setPosition(Vec2(0,0));
cell->addChild(sprite);
auto label=Label::createWithSystemFont(string->getCString(),"arial", 30);
label->setPosition(Vec2::ZERO);
label->setAnchorPoint(Vec2::ZERO);
label->setTag(123);
cell->addChild(label);
}
else{
auto label=(Label*)cell->getChildByTag(123);
label->setString(string->getCString());
}
return cell;
}
ssize_tTableViewTest::numberOfCellsInTableView(cocos2d::extension::TableView *table){
return 26;
}
最好实现的效果如下:
- cocos2dx tableview基础:实现多图片的滑动显示
- cocos2dx tableview基础:实现多图片的滑动显示
- 多tableView的滑动显示
- 滑动tableView表单时cell图片的视差效果实现分析
- COCOS2DX - TableView的使用
- Cell特效之图片随着TableView的滑动上下移动
- cocos2dx滑动条实现
- tableView的滑动删除
- tableview的滑动删除
- ios8 tableView设置滑动删除时显示多个按钮
- ios8 tableView设置滑动删除时显示多个按钮
- 1.IOS TableView滑动显示多个按钮
- ios8 tableView设置滑动删除时显示多个按钮
- cocos2dx tableview的实际应用
- tableView实现添加多个图片
- 菜单和图片的滑动显示效果!
- 对话框显示加载的滑动图片
- iOS tableView滑动隐藏/显示tabbar
- ndk串口驱动与Java输入输出流
- 【Oracle】windows平台 Oracle12c 的安装教程
- List之Union(),Intersect(),Except() 即并集,交集,差集运算。
- linux常用命令行
- web.xml配置文件详解
- cocos2dx tableview基础:实现多图片的滑动显示
- TCP/IP相关介绍(二)
- CSS学习—颜色值+小技巧
- python 编写杨辉三角
- C++语言类和对象有什么区别
- Linux_博客-调研tcp定时器
- udp socket
- 地球上最厉害的字体:Helvetica
- int android.view.View.getImportantForAccessibility()