-------------------------------

--@ CreateDate: 2015.08.05

--@ Author:     王成成

--@ FileName:   BaoShiTabXiangQianLayer.lua

--@ Brief:      宝石镶嵌

-------------------------------
local UIUtil = require("app.utils.UIUtil")

local curBaoShiTypeIndex = nil

local BaoShiTabXiangQianLayer = class("BaoShiTabXiangQianLayer", function()

  return  display.newLayer("BaoShiTabXiangQianLayer")

end)

function BaoShiTabXiangQianLayer:ctor()

  local object, UITable = UIUtil:createLayerFromCSB("baoshi_xiangqian_layer", callBackProvider,true)
  object:addTo(self)
  self.scrollView = UITable["ScrollView"]
  self.scrollViewBaoShiType = UITable["ScrollViewBaoShiType"]

  self:loadData()
  self:loadBaoshiTypeData()
end

-------------------------------------
------ 左边的 scrollview start -----
------ 左边的 scrollview start -----

-- 获取子节点的起始坐标
function BaoShiTabXiangQianLayer:getStartPoisition(count)

local x,y = 135,490
if count < 6 then
return x, y
end
y = y + ((count - 5) * 101)
return x, y
end

function BaoShiTabXiangQianLayer:getContentSize(count)

local size = self.scrollView:getContentSize()
if count < 6 then
return size
end

local rowcount = (count - 5)
size.height = size.height + (rowcount * 101)
return size
end

function BaoShiTabXiangQianLayer:loadData()

self.scrollView:removeAllChildren()

local count = 7
local x, y = self:getStartPoisition(count)

local size = self:getContentSize(count)
self.scrollView:setInnerContainerSize(size)

for i = 1, count do
local data = nil
local item, list = self:createItem(data)

item:setPosition({x = x, y = y})
y = y - 101
self.scrollView:addChild(item)
end
end

function BaoShiTabXiangQianLayer:createItem(data)

local callBackProvider = function(path, node, funcName)
if funcName == "itemClick" then
local function itemClick()
print("itemClick")
end
return itemClick
end
end

local object, UITable = UIUtil:createLayerFromCSB("baoshi_xiangqian_item", callBackProvider)
UITable["Image_root"]:setSwallowTouches(false)

return object, UITable
end

------ 左边的 scrollview end -----
------ 左边的 scrollview end -----
-------------------------------------

-------------------------------------
------ 中间的 scrollview start -----
------ 中间的 scrollview start -----

-- 获取子节点的起始坐标
function BaoShiTabXiangQianLayer:getMiddleStartPoisition(count)

local x,y = 135,420
if count < 8 then
return x, y
end
y = y + ((count - 7) * 64)
return x, y
end

function BaoShiTabXiangQianLayer:getMideleContentSize(count)

local size = self.scrollViewBaoShiType:getContentSize()
if count < 8 then
return size
end

local rowcount = (count - 7)
size.height = size.height + (rowcount * 64)
return size
end

function BaoShiTabXiangQianLayer:loadBaoshiTypeData(index)

self.scrollViewBaoShiType:removeAllChildren()

local count = 10

local x, y = self:getMiddleStartPoisition(count)

local size = self:getMideleContentSize(count)
self.scrollViewBaoShiType:setInnerContainerSize(size)

local countSub = 3
if index ~= nil then
y = y + 100 * countSub
end

for i = 1, count do
local data = {}
data.tag = i

local item, list = self:createBaoShiTypeItem(data)
item:setPosition({x = x, y = y})
self.scrollViewBaoShiType:addChild(item)
y = y - 64

--subitem
if i == index then
list["btnBaoShiType"]:loadTextureNormal("ui/baoshi/btn_qiexuan02.png")
for i = 1 , countSub do
item, list = self:createBaoShiTypeItemItem(data)

if i == 1 then
y = y - 20
end

item:setPosition({x = 133, y = y})
self.scrollViewBaoShiType:addChild(item)
y = y - 100

if i == countSub then
y = y + 20
end
end

self.scrollViewBaoShiType:setInnerContainerSize(cc.size(size.width, size.height + countSub * 100))
end

end
end

function BaoShiTabXiangQianLayer:createBaoShiTypeItem(data)

local callBackProvider = function(path, node, funcName)
if funcName == "typeClick" then
local function typeClick()
print("typeClick")

print("-----curBaoShiTypeIndex = "..table.tostring(curBaoShiTypeIndex))
print("----- data.tag = "..table.tostring(data.tag))

if curBaoShiTypeIndex == data.tag then
self:loadBaoshiTypeData()
curBaoShiTypeIndex = nil

else
self:loadBaoshiTypeData(data.tag)
curBaoShiTypeIndex = data.tag

end

end
return typeClick
end
end

local object, UITable = UIUtil:createLayerFromCSB("baoshi_type_item", callBackProvider)
UITable["btnBaoShiType"]:setSwallowTouches(false)
return object, UITable
end

end
return typeClick
end
end

local object, UITable = UIUtil:createLayerFromCSB("baoshi_type_item", callBackProvider)
UITable["btnBaoShiType"]:setSwallowTouches(false)
return object, UITable
end

function BaoShiTabXiangQianLayer:createBaoShiTypeItemItem(data)

local callBackProvider = function(path, node, funcName)
if funcName == "itemClick" then
local function itemClick()
print("itemClick")
end
return itemClick
end
end

local object, UITable = UIUtil:createLayerFromCSB("baoshi_item", callBackProvider)
UITable["Image_root"]:setSwallowTouches(false)

return object, UITable
end

------ 中间的 scrollview end -----
------ 中间的 scrollview end -----
-------------------------------------

function BaoShiTabXiangQianLayer:onExit()
print("onExit")
curBaoShiTypeIndex = nil
end

return BaoShiTabXiangQianLayer

scrollview 嵌套 折叠效果的更多相关文章

  1. 阻尼回弹效果的ScrollView嵌套GridView

    以前写过一篇带阻尼回弹效果的ScrollView,但是有些小问题,于是又重新整理了一下,这篇文章一是一个带阻尼的Scrollview,再个就是Scrollview嵌套GridView实现,而GridV ...

  2. Android仿掌上英雄联盟首页,实现折叠效果

    概述 仿掌上英雄联盟首页的demo 详细 代码下载:http://www.demodashi.com/demo/10695.html 首页大概分为几个部分 状态栏 标题栏 轮播图 切换的Tab 资讯列 ...

  3. 关于ScrollView嵌套ListView问题

    Android开发之ScrollView中嵌套ListView的解决方案   原文:http://blog.csdn.net/minimicall/article/details/40983331   ...

  4. (转)ViewPager,ScrollView 嵌套ViewPager滑动冲突解决

    ViewPager,ScrollView 嵌套ViewPager滑动冲突解决 本篇主要讲解一下几个问题 粗略地介绍一下View的事件分发机制 解决事件滑动冲突的思路及方法 ScrollView 里面嵌 ...

  5. 四种方案解决ScrollView嵌套ListView问题(转)

    以下文章转自@安卓泡面 在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollVie ...

  6. Scrollview 嵌套 RecyclerView 及在Android 5.1版本滑动时 惯性消失问题

    标签:scrollview   android   滑动   嵌套 scrollview 嵌套recyclerview 时,recyclerview不显示,这就需要我们自己计算recyclerview ...

  7. 冲突--ScrollView嵌套ListView冲突问题的最优解决方案

    项目做多了之后,会发现其实 ScrollView嵌套ListVew或者GridView等很常用,但是你也会发现各种奇怪问题产生.根据个人经验现在列出常见问题以及代码最少最简单的解决方法. 问题一 :  ...

  8. android 解决ScrollView嵌套ListView的问题,不能全屏,全屏不能显示下面控件

    在开发中遇到ScrollView嵌套ListView的问题,最开始发出不能全屏,效果是这样的: 但我想要的效果是这样的: 下面看一下布局文件: <?xml version="1.0&q ...

  9. ScrollView嵌套ListView的滑动冲突问题,是看大神的方法的,作为学习以后用的到

    在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结 ...

随机推荐

  1. javascript创建对象的一些方式

    通过创建一个Object实例 var person = new Object(); person.name = "zhouquan"; person.age = 21; perso ...

  2. [BZOJ3173][Tjoi2013]最长上升子序列

    [BZOJ3173][Tjoi2013]最长上升子序列 试题描述 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上 ...

  3. js 阻止事件冒泡

    function stopBubble(e) { //如果提供了事件对象,则这是一个非IE浏览器 if ( e && e.stopPropagation ) //因此它支持W3C的st ...

  4. 深度学习入门教程UFLDL学习实验笔记三:主成分分析PCA与白化whitening

    主成分分析与白化是在做深度学习训练时最常见的两种预处理的方法,主成分分析是一种我们用的很多的降维的一种手段,通过PCA降维,我们能够有效的降低数据的维度,加快运算速度.而白化就是为了使得每个特征能有同 ...

  5. java20

    1:递归(理解) (1)方法定义中调用方法本身的现象 举例:老和尚给小和尚讲故事,我们学编程 (2)递归的注意事项: A:要有出口,否则就是死递归 B:次数不能过多,否则内存溢出 C:构造方法不能递归 ...

  6. Unity3D 摄像机的Transform通过摇杆输出的方向

    要解决的问题是:摄像机的方向不固定,当摇杆向前(0,1)推时,主角要往摄像机的朝向(忽略Y方向)走,当摇杆往右(1,0)推的时,主角朝摄像机的右方向 /// <summary> /// 摄 ...

  7. Java 类初始化顺序

    总的来说: 父类静态代码块->子类静态代码块->子类main()方法->父类构造块->父类构造方法->子类构造块->子类构造方法 注意,就算是静态的方法也需要调用才 ...

  8. win8 app内存溢出检测工具PerfView.exe的使用

    PerfView使用教程:https://msdn.microsoft.com/en-us/magazine/jj721593.aspx PerfView下载地址:https://www.micros ...

  9. Sass安装(windows版)

    Sass安装(windows版) 在 Windows 平台下安装 Ruby 需要先有 Ruby 安装包,大家可以到 Ruby 的官网(http://rubyinstaller.org/download ...

  10. VS更改编辑窗背景

    打开Visual Studio  工具→扩展和更新→联机  在搜索框里输入“background”后,搜索结果有很多插件可以更改 Visual Studio 的背景,选择其中的一项,可以在右边进行预览 ...