scrollview 嵌套 折叠效果

-------------------------------
--@ 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 嵌套 折叠效果的更多相关文章
- 阻尼回弹效果的ScrollView嵌套GridView
以前写过一篇带阻尼回弹效果的ScrollView,但是有些小问题,于是又重新整理了一下,这篇文章一是一个带阻尼的Scrollview,再个就是Scrollview嵌套GridView实现,而GridV ...
- Android仿掌上英雄联盟首页,实现折叠效果
概述 仿掌上英雄联盟首页的demo 详细 代码下载:http://www.demodashi.com/demo/10695.html 首页大概分为几个部分 状态栏 标题栏 轮播图 切换的Tab 资讯列 ...
- 关于ScrollView嵌套ListView问题
Android开发之ScrollView中嵌套ListView的解决方案 原文:http://blog.csdn.net/minimicall/article/details/40983331 ...
- (转)ViewPager,ScrollView 嵌套ViewPager滑动冲突解决
ViewPager,ScrollView 嵌套ViewPager滑动冲突解决 本篇主要讲解一下几个问题 粗略地介绍一下View的事件分发机制 解决事件滑动冲突的思路及方法 ScrollView 里面嵌 ...
- 四种方案解决ScrollView嵌套ListView问题(转)
以下文章转自@安卓泡面 在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollVie ...
- Scrollview 嵌套 RecyclerView 及在Android 5.1版本滑动时 惯性消失问题
标签:scrollview android 滑动 嵌套 scrollview 嵌套recyclerview 时,recyclerview不显示,这就需要我们自己计算recyclerview ...
- 冲突--ScrollView嵌套ListView冲突问题的最优解决方案
项目做多了之后,会发现其实 ScrollView嵌套ListVew或者GridView等很常用,但是你也会发现各种奇怪问题产生.根据个人经验现在列出常见问题以及代码最少最简单的解决方法. 问题一 : ...
- android 解决ScrollView嵌套ListView的问题,不能全屏,全屏不能显示下面控件
在开发中遇到ScrollView嵌套ListView的问题,最开始发出不能全屏,效果是这样的: 但我想要的效果是这样的: 下面看一下布局文件: <?xml version="1.0&q ...
- ScrollView嵌套ListView的滑动冲突问题,是看大神的方法的,作为学习以后用的到
在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结 ...
随机推荐
- PHP5不重新编译,如何安装自带的未安装过的扩展,如soap扩展?
在虚拟机的CentOS5.5中,一键安装了PHP运行环境,但发现并没有 soap 扩展,而近期项目用需要用到 webservice. 上述的一键安装(lamp0.4),其实是源码编译安装,PHP配置文 ...
- 在浏览器上直接输入url 时,中文传参乱码问题
这样的地址 xxx.asp?name=中国 ,通过 超链接打开这个链接 ,xxx.asp能够成才接收参数,但是如果将地址直接放到浏览器地址栏上,回车, xxx.asp就无法正确接收中文参数,一直显示 ...
- ASP.NET MVC中的两个Action之间值的传递--TempData
一. ASP.NET MVC中的TempData 在ASP.NET MVC框架的ControllerBase中存在一个叫做TempData的Property,它的类型为TempDataDictiona ...
- ReactiveCocoa学习
ReactiveCocoa常见类 6.1RACSiganl:信号类,一般表示将来有数据传递,只要有数据改变,信号内部接收到数据,就会马上发出数据. 注意: 信号类(RACSiganl),只是表示当数据 ...
- 2. iOS程序的生命周期
程序启动-生命周期 来自: QQ: 853740091 1.首先讲解UIApplication对象 (1)UIApplication对象是应用程序的象征,一个UIApplication对象就代表一个 ...
- javascript学习 真正理解DOM脚本编程技术背后的思路和原则
本文学习来源于<javascriptDOM编程艺术>仅作笔记 学会怎样才能利用DOM脚本编程技术以一种既方便自己更体贴用户的方式去充实和完善你们的网页. 循序渐进:从最核心的内容开始,逐步 ...
- iOS之tabBar随tableView的滑动而隐藏/显现
` @property(nonatomic,assign)CGFloat historyY; #pragma mark Delegate //设置滑动的判定范围 - (void)scrollViewW ...
- Redis的缓存策略和主键失效机制
作为缓存系统都要定期清理无效数据,就需要一个主键失效和淘汰策略. >>EXPIRE主键失效机制 在Redis当中,有生存期的key被称为volatile,在创建缓存时,要为给定的key设置 ...
- 基于类的命令行notebook的实现
在看一本书<PYTHON3 面向对象编程> 内容丰富,作作记录. notebook.py __author__ = 'chengang882' import datetime # Stor ...
- python多线程编程
Python多线程编程中常用方法: 1.join()方法:如果一个线程或者在函数执行的过程中调用另一个线程,并且希望待其完成操作后才能执行,那么在调用线程的时就可以使用被调线程的join方法join( ...