游戏中非常多须要用到ScrollView的情况,也就是须要滚动一片区域。

这里有两种实现方法,一种是使用cocos studio的方式,另外一种是手写代码。先看第一种

第一种记得在设置滚动区域时选取裁剪项。

        var size = cc.winSize;

        //读取json文件
var root = ccs.uiReader.widgetFromJsonFile(res.listJson);
this.addChild(root);
//获取在cocos studio里面设定好的scrollView
var missionlist = ccui.helper.seekWidgetByName(root, "MissionList");
//设定垂直朝向滚动
missionlist.setDirection(ccui.ScrollView.DIR_VERTICAL);
missionlist.setTouchEnabled(true);
missionlist.setBounceEnabled(true);
missionlist.setVisible(true);
//设置大小
missionlist.setSize(cc.size(960, 400));
//设置能够滚动区域
var len = 9;
missionlist.setInnerContainerSize(cc.size(960, 80* len));
missionlist.y = size.height/2;
missionlist.x = size.width/2;
missionlist.setAnchorPoint(cc.p(0.5,0.5));
//设置滚动的项目
for(var i = 0; i < len; i++){
var sprite = new cc.Sprite(res.item_png);
missionlist.addChild(sprite);
sprite.x = missionlist.width/2;
sprite.y = missionlist.getInnerContainerSize().height + 40 - (i+1)*80;
sprite.setAnchorPoint(cc.p(0.5,0.5));
}
missionlist.jumpToTop();
另外一种。手写代码
        var listView = ccui.ScrollView.create();
listView.setDirection(ccui.ScrollView.DIR_VERTICAL);
listView.setTouchEnabled(true);
listView.setBounceEnabled(true);
listView.setSize(cc.size(960, 400));
listView.x = size.width/2;
listView.y = size.height/2;
listView.setAnchorPoint(cc.p(0.5,0.5));
this.addChild(listView);
listView.setInnerContainerSize(cc.size(960, 80*9));
for(var i =0; i < 9; i++){
var sprite = new cc.Sprite(res.item_png);
listView.addChild(sprite);
sprite.x= listView.width/2;
sprite.y= listView.getInnerContainerSize().height + 40 - (i+1)*80;
sprite.setAnchorPoint(cc.p(0.5,0.5));
} listView.jumpToTop();

以下是左右滑动的代码演示样例


var HelloWorldLayer = cc.Layer.extend({
    sprite:null,
    ctor:function () {         this._super();         var size = cc.winSize;
        
        var listView = new ccui.ScrollView();
        listView.setDirection(ccui.ScrollView.DIR_HORIZONTAL); 
        listView.setTouchEnabled(true);  
        listView.setBounceEnabled(true); 
        listView.setSize(cc.size(512, 200));  
        listView.x = size.width/2;  
        listView.y = size.height/2;
        listView.setAnchorPoint(cc.p(0.5,0.5));  
        this.addChild(listView);
        listView.setInnerContainerSize(cc.size(128*6, 200));
        for(var i =0; i < 6; i++){  
        <span style="white-space:pre"> </span>var sprite = new cc.Sprite(res.item_png);  
        <span style="white-space:pre"> </span>listView.addChild(sprite);
        <span style="white-space:pre"> </span>
        <span style="white-space:pre"> </span>sprite.x= i*130 + 40;
        <span style="white-space:pre"> </span>sprite.y= listView.getInnerContainerSize().height/2;  
        <span style="white-space:pre"> </span>sprite.setAnchorPoint(cc.p(0.5,0.5));
        }           listView.jumpToLeft();  
        cc.log("ben guo...");
        return true;
    }
}); var HelloWorldScene = cc.Scene.extend({
    onEnter:function () {
        this._super();
        var layer = new HelloWorldLayer();
        this.addChild(layer);
    }
});


cocos2d js ScrollView的使用方法的更多相关文章

  1. cocos2d js jsb XMLHttpRequest 中文乱码

    1.首先讲下怎样使用XMLHttpRequest 下面所说的是在cocos2d-x 2.2.2 或者 2.3 版本号中. 首先要明确cocos2d js事实上分两个版本号,一个是html5的版本号,另 ...

  2. 由js apply与call方法想到的js数据类型(原始类型和引用类型)

    原文地址:由js apply与call方法想到的js数据类型(原始类型和引用类型) js的call方法与apply方法的区别在于第二个参数的不同,他们都有2个参数,第一个为对象(即需要用对象a继承b, ...

  3. iOS之在webView中引入本地html,image,js,css文件的方法 - sky//////////////////////////////////////ZZZZZZZZZZZZZZZ

    iOS之在webView中引入本地html,image,js,css文件的方法   2014-12-08 20:00:16CSDN-sky_2016-点击数:10292     项目需求 最近开发的项 ...

  4. 原生js获取鼠标坐标方法全面讲解-zmq

    原生js获取鼠标坐标方法全面讲解:clientX/Y,pageX/Y,offsetX/Y,layerX/Y,screenX/Y 一.关于js鼠标事件综合各大浏览器能获取到坐标的属性总共以下五种:eve ...

  5. js巧用apply方法实现数组最值以及合并

    尽管js的apply方法在平常的使用中并不多见,但是在某些地方使用的还是很有帮助性的,这里就和大家说两个比较实用的例子:1.数组最大最小值 求数组中的最大最小值,js有相应的方法:Math.min() ...

  6. <js>实现回车键登陆方法,并处理谷歌与火狐不兼容的问题

    1.在body中添加onkeydown事件 <body onkeydown="keyLogin(event);">2.使用js相应登陆添加方法//添加回车登陆事件 fu ...

  7. js中的tostring()方法

    http://blog.sina.com.cn/s/blog_85c1dc100101bxgg.html js中的tostring()方法 (2013-11-12 11:07:43) 转载▼ 标签: ...

  8. js跳转页面方法大全

    js跳转页面方法大全<span id="tiao">3</span><a href="javascript:countDown"& ...

  9. 常见JS(JavaScript)冲突解决方法

    1.一般JS冲突解决办法 a.最容易出现的就是js的命名冲突 ①.变量名冲突 变量有全局变量和局部变量当全局变量变量和局部变量名称一致时,就会js冲突,由于变量传递数值或地址不同就会产生JavaScr ...

随机推荐

  1. Codeforces Round #334 (Div. 1) B. Moodular Arithmetic

    B - Moodular Arithmetic 题目大意:题意:告诉你p和k,其中(0<=k<=p-1),x属于{0,1,2,3,....,p-1},f函数要满足f(k*x%p)=k*f( ...

  2. Gitlab Webhooks, External Services, and API(一)

    一. 和外部服务进行集成 Gitlab支持和不同的外部服务进行集成,比如可以和聊天工具,Slack或者Campfire进行集成,或者和项目管理工具进行集成.如Assembla或者Pivotal Tra ...

  3. thinkphp数据查询方法总结select ,find,getField,query

    thinkphp已经封装好了常用的查询方法,且都比较实用,对于不常用的查询框架也保留了原始查询方法query. 1 2 $Model = new Model() // 实例化一个model对象 没有对 ...

  4. R语言实战(九)主成分和因子分析

    本文对应<R语言实战>第14章:主成分和因子分析 主成分分析(PCA)是一种数据降维技巧,它能将大量相关变量转化为一组很少的不相关变量,这些无关变量成为主成分. 探索性因子分析(EFA)是 ...

  5. spring boot mybatis 多数据源配置

    package com.xynet.statistics.config.dataresources; import org.springframework.jdbc.datasource.lookup ...

  6. Keras/tensorflow出现‘Loaded runtime CuDNN library: 7.0.5 but source was compiled with: 7.1.14’错误的解决办法

    从tensorflow1.10 升级到1.12版本后,对依赖的CuDNN不兼容产生的问题.鉴于一直使用的是Keras,未使用新版本tensorflow的功能,故果断回退到旧版本. 方法为:pip3 i ...

  7. django导出excel

    # coding:utf-8 from django.http import HttpResponse from xlwt import * import StringIO, os from test ...

  8. android viewHolder static 静态

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 不是静态内部类 会 持有 外部类的 引用.  就像经常自定义的 适配器 类 作为内部类 ...

  9. 使用BasicDataSource引发的数据库连接中断的问题和解决方法

    http://blog.csdn.net/itbasketplayer/article/details/44198963 http://blog.sina.com.cn/s/blog_9e3e5499 ...

  10. C# 推送模板

    C#推送模板.安卓个推.消息推送 http://docs.getui.com/server/csharp/template/