CCScrollView滚动视图可以让游戏有效果,并能够通过滚动视图切换游戏场景,滚动视图通常用来选择在游戏中的级别

实例1:使用CCScrollView创建一个简单的滚动视图

首先创建一个ScrollView类

然后在ScrollView.h中加入以下的代码

#ifndef __ScrollView_H__
#define __ScrollView_H__ #include "cocos2d.h"
#include "cocos-ext.h"
USING_NS_CC;
USING_NS_CC_EXT; class ScrollView : public CCLayer
{
public:
virtual bool init(); static CCScene* scene(); CREATE_FUNC(ScrollView); //响应触摸事件
bool ccTouchBegan(CCTouch* touch, CCEvent*);
void ccTouchEnded(CCTouch* touch, CCEvent*); CCNode* _contaner;
}; #endif // __ScrollView_H__

在ScrollView.cpp中加入以下的代码

#include "ScrollView.h"

CCScene* ScrollView::scene()
{
CCScene *scene = CCScene::create(); ScrollView *layer = ScrollView::create(); scene->addChild(layer); return scene;
} bool ScrollView::init()
{
CCLayer::init(); CCSize winSize = CCDirector::sharedDirector()->getWinSize(); CCPoint center = ccp(winSize.width / 2, winSize.height / 2); //创建一个结点
CCNode* c = CCNode::create(); //创建5个紧挨着的精灵
for(int i = 0; i < 5; i++)
{
CCSprite* sprite = CCSprite::create("HelloWorld.png");
c->addChild(sprite); //设置图片的位置,每两张图片相差一张图片的宽度
sprite->setPosition(ccpAdd(center, ccp(i*winSize.width, 0)));
} //滚动视图
//第一个參数:显示的视图大小
//第二个參数:视图的实际大小
CCScrollView* view = CCScrollView::create(winSize, c);
addChild(view); //设置视图运动的方向为水平运动
view->setDirection( kCCScrollViewDirectionHorizontal); //设置视图的宽度和高度
view->setContentSize(CCSize(winSize.width * 5, winSize.height * 5)); return true;
}

运行结果

实例2:CCScrollView的高级应用

不会出现两张图片的相交位置在窗体中(当切换完毕图片后总会在窗体上显示一张完整的图片)

在ScrollView.cpp中加入以下的代码

#include "ScrollView.h"

CCScene* ScrollView::scene()
{
CCScene *scene = CCScene::create(); ScrollView *layer = ScrollView::create(); scene->addChild(layer); return scene;
} bool ScrollView::init()
{
CCLayer::init(); CCSize winSize = CCDirector::sharedDirector()->getWinSize(); CCPoint center = ccp(winSize.width / 2, winSize.height / 2); //创建一个结点
CCNode* c = CCNode::create(); _contaner = c; //创建5个紧挨着的精灵
for(int i = 0; i < 5; i++)
{
CCSprite* sprite = CCSprite::create("HelloWorld.png");
c->addChild(sprite); //设置图片的位置。每两张图片相差一个屏幕的宽度
sprite->setPosition(ccpAdd(center, ccp(i*winSize.width, 0))); //给视图编号
char buf[10];
sprintf(buf, "%d", i);
CCLabelTTF* label = CCLabelTTF::create(buf, "Arial", 36);
sprite->addChild(label);
label->setPosition(center);
} //滚动视图
//第一个參数:在窗体显示的视图大小
//第二个參数:结点CCNode
CCScrollView* view = CCScrollView::create(winSize, c);
addChild(view); //设置视图运动的方向为水平运动
view->setDirection( kCCScrollViewDirectionHorizontal); //设置视图的宽度和高度
view->setContentSize(CCSize(winSize.width * 5, winSize.height * 5)); //取消ScrollView的弹性
view->setBounceable(false); //注冊触摸事件
setTouchEnabled(true);
setTouchMode(kCCTouchesOneByOne); return true;
} //鼠标点下的时候
bool ScrollView::ccTouchBegan(CCTouch* touch, CCEvent* ev)
{
return true;
} //鼠标起来的时候
void ScrollView::ccTouchEnded(CCTouch* touch, CCEvent*)
{
//得到鼠标点下去的时候的位置
CCPoint ptDown = touch->getStartLocation(); //得到鼠标松开时的位置
CCPoint ptUp = touch->getLocation(); //当两个位置的距离的平方小于25时(觉得是点击,否则是滑动)
if(ptUp.getDistanceSq(ptDown) <= 25)
{
//检查点击的是哪一个图片
//将世界坐标转换成结点坐标
CCPoint ptInContainer = _contaner->convertToNodeSpace(ptUp); //定义一个数组保存5个精灵
CCArray* arr = _contaner->getChildren(); for(int i = 0; i < 5; ++i)
{
//获取精灵的索引(获取点击的是哪个精灵)
CCSprite* sprite = (CCSprite*)arr->objectAtIndex(i); //boundingBox()获取精灵的边框(推断触摸点是否在边框内,当在的时候。打印精灵的编号)
if(sprite->boundingBox().containsPoint(ptInContainer))
{
CCLog("click i is %d", i);
break;
}
}
}
else
{
//滑动
int x = _contaner->getPositionX(); if (x >= -1920 && x <= 0)
{
// adjust
// 0, -480, -960, -1440, -1920
int idx = (-x +240)/ 480;
x = -idx * 480; CCMoveTo* moveTo = CCMoveTo::create(0.5f, ccp(x, this->_contaner->getPositionY())); this->_contaner->runAction(moveTo);
}
}
}

运行结果:

当在图片中点击后会打印点击的图片的编号

改进后不会出现的情形





版权声明:本文博主原创文章,博客,未经同意不得转载。

Cocos2d-X采用CCScrollView创建滚动视图的更多相关文章

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

    CCTableView和CCScrollView如创建滚动视图,CCTableView该函数将是更,制造更多麻烦 实例1:使用CCTableView创建滚动视图 首先创建一个TableView类 Ta ...

  2. swift:创建滚动视图的图片轮播器

    用swift创建图片轮播器和用OC创建的方式是一样的,都主要用到UIScrollView和UIImageview这两个控件,有几张图片,就将滚动视图的内容区域大小设置为每一张图片的大小乘以张数即可.然 ...

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

    MFC小程序截图: 一.在MFC中简单使用WebBrowser的ActiveX插件的方法: 见博文:  http://blog.csdn.net/supermanking/article/detail ...

  4. cocos2dx基础篇(14) 滚动视图CCScrollView

    [3.x]     (1)去掉 "CC"     (2)滚动方向         > CCScrollViewDirection 改为强枚举 ScrollView::Dire ...

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

    ////  ViewController.m//  UIScollView////  Created by hehe on 15/9/25.//  Copyright (c) 2015年 wang.h ...

  6. 制作滚动视图(ScrollView)

    怎样判断是否应当使用滚动视图 所谓的滚动视图,是指一个可以滑动的视窗,视窗大小和位置固定不变,视窗内的内容用户可以通过手指滑动或者拖动滚动天来进行滚动浏览. 滚动视图的目的是为了解决同类内容过多,一个 ...

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

    一.scheduleUpdate 1.scheduleUpdate:此函数是CCNode的函数,每一个CCNode仅仅要调用scheduleUpdate更新函数,那么这个CCNode就会响应当前类的u ...

  8. iOS 滚动视图的复用问题解决方案

    LazyScroll是什么 LazyScrollView 继承自ScrollView,目标是解决异构(与TableView的同构对比)滚动视图的复用回收问题.它可以支持跨View层的复用,用易用方式来 ...

  9. 【Android】10.5 滚动视图(RecyclerView)

    分类:C#.Android.VS2015: 创建日期:2016-02-19 一.简介 滚动视图(RecyclerView)的用法与布局控件的用法类似,唯一不同的是,所有布局控件中都可以包含多个组件,而 ...

随机推荐

  1. CodeForces 10C. Digital Root

    乞讨A.B.C ∈[1.N] && A*B != C,d(A*B) == d(C)组的数量. 首先要知道d(x) = (x%9 == 0 ? 9 : x%9); 那么则会有A*B == ...

  2. iOS8数字键盘加左下角完成button

    iOS8数字键盘加左下角完成button的核心代码如下面: - (void)addDoneButtonToNumPadKeyboard { UIButton *doneButton = [UIButt ...

  3. Gradle入门系列(转)

    Gradle是一种构建工具,它抛弃了基于XML的构建脚本,取而代之的是采用一种基于Groovy的内部领域特定语言.近期,Gradle获得了极大的关注,这也是我决定去研究Gradle的原因. 这篇文章是 ...

  4. Telnet,SSH1,SSH2,Telnet/SSL,Rlogin,Serial,TAPI,RAW

    一.Telnet 采用Telnet用来訪问远程计算机的TCP/IP协议以控制你的网络设备,相当于在离开某个建筑时大喊你的username和口令.非常快会有人进行监听, 并且他们会利用你安全意识的缺乏. ...

  5. 【C语言探索之旅】 第三课:你的第一个程序

    内容简介 1.课程大纲 2.第一部分第三课:你的第一个程序 3.第一部分第四课预告:变量的世界 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写三个 ...

  6. .NET 并行(多核)编程系列之五 Task执行和异常处理

    原文:.NET 并行(多核)编程系列之五 Task执行和异常处理 .NET 并行(多核)编程系列之五 Task执行和异常处理 前言:本篇主要讲述等待task执行完成. 本篇的议题如下: 1. 等待Ta ...

  7. HDU 1864最大报销额(一维背包)

    题目地址:HDU 1864 刚上来看着挺麻烦的..细致看了看原来好简单好简单...仅仅要去掉一些不符合要求的发票,剩下的就是最简单的背包问题了..对于小数问题,仅仅要*100就变成整数了. 代码例如以 ...

  8. C#设计及其UML(反向工程)

    OOP之C#设计及其UML(反向工程)   现在总结一下C#类关键字(virtual.abstract.override.new.sealed)的使用(以C#代码体现),并再次熟悉一下OOP思想,使用 ...

  9. Python学习笔记12:标准库之对象序列化(pickle包,cPickle包)

    计算机的内存中存储的是二进制的序列. 我们能够直接将某个对象所相应位置的数据抓取下来,转换成文本流 (这个过程叫做serialize),然后将文本流存入到文件里. 因为Python在创建对象时,要參考 ...

  10. 持久化redis

    redis持久化 Redis持久化原理: Redis支持两种持久化:RDB和AOF模式 一.名词解释: RDB:持久化可以在指定的时间间隔内生成数据集的时间点快照(point-in-time snap ...