如何让CCLayer创造的地图,左右滑动不出现黑边
在都是scale为1的情况下,效果图如下:
,
绿色的是Screen,它的大小和坐标不变,可以理解为CCScene,下面两个就是用CCLayer的地图,有2个Layer,深颜色的就是和Scrren一样大小的Layer,浅颜色的是一张大地图,或者一张大图片,也可以是一个Layer,里面有个CCTMXTiledMap,都可以,它们的特点是尺寸大于Screen,坐标在Layer中是0,0,所以无论深颜色Layer怎么变化,它们的坐标始终都是0,只是大小可能会改变。代码为:
CCScene *scene=[CCScene node];
CCLayerColor *layercolor2=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor2 z:MaxZorder-];
layercolor2.position=ccp(,);
CCLayerColor *layercolor5=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor5 z:MaxZorder-];
layercolor5.position=ccp(,);
//layercolor5.scaleX=0.75;
CCLayerColor *layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor5 addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
// layercolor4.scaleX=0.75;
// layercolor5.position=ccp(500+layercolor5.contentSize.width/2*(layercolor5.scaleX-1),400);
CCLayerColor * layercolor=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor z:MaxZorder-];
layercolor.position=ccp(,);
//layercolor.scaleX=0.75;
layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
[[CCDirector sharedDirector] runWithScene:[CCTransitionFade transitionWithDuration:0.5 scene:scene withColor:ccBLACK]];
现在如果地图支持缩放,比如深颜色Layer比例变为0.75了,那么会如何变化呢,如图所示的变化:

代码如下:
CCScene *scene=[CCScene node];
CCLayerColor *layercolor2=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor2 z:MaxZorder-];
layercolor2.position=ccp(,);
CCLayerColor *layercolor5=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor5 z:MaxZorder-];
layercolor5.position=ccp(,);
layercolor5.scaleX=0.75;
CCLayerColor *layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor5 addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
// layercolor5.position=ccp(500+layercolor5.contentSize.width/2*(layercolor5.scaleX-1),400);
CCLayerColor * layercolor=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor z:MaxZorder-];
layercolor.position=ccp(,);
layercolor.scaleX=0.75;
layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
[[CCDirector sharedDirector] runWithScene:[CCTransitionFade transitionWithDuration:0.5 scene:scene withColor:ccBLACK]];
,为啥会这样呢,因为Layer是比较特殊的,她是以左下角为坐标,但是锚点确实在中间,所以缩小的时候是从2头缩小,而坐标保持不变,所以我们看到虽然坐标不变,但是已经偏移了。那么现在我们就讨论,如何在缩放之后,大地图仍然保持原来的位置不变,这样就能保证左右两边不出现黑边。先看左边的,第二个图就是左边的
这里调整下layercolor5的坐标,代码如下
layercolor5.position=ccp(500+layercolor5.contentSize.width/2*(layercolor5.scaleX-1),400);因为缩小之后,左边缩放的大小为
layercolor5.contentSize.width/2*(layercolor5.scaleX-1),所以为了回到以前的位置,x坐标减少相应大小即可。 下面再调整右边的。也就是调整layercolor的坐标,加上这一行
layercolor.position=ccp(layercolor.position.x+(1-layercolor.scaleX)*500-(layercolor.contentSize.width/2)*0.25,layercolor.position.y);
为什么会这样做
layercolor.position.x+(1-layercolor.scaleX)*500,首先layercolor.position.x是未缩放前的坐标,(1-layercolor.scaleX)*500是大地图缩小后减少的部分。
两者相加,layercolor向右移动这些,但是还没完,因为Layer缩小的时候,其实是向两边缩,所以大地图为了保持不变,也相当于向右移动了一些,也就是(layercolor.contentSize.width/2)*0.25,就是说相对坐标不变,但是世界坐标变了,向右移动了,所以要减去向右移动的这块,才是最重layercolor应该移动的距离。
如果感觉这个不好理解,还有一种思路,就是说想让layercolor缩放后,仍然对齐右边,我们不考虑layercolor在缩放后移动多少才能对齐,我们直接算在layercolor缩放后,坐标应该不变,但是图像会向左边缩,也就是x增大,我们先让layercolor变得和layercolor5一样,移动到和左边对齐,也就是使
layercolor.position= layercolor5.position,此时就是做对齐了,然后要想让右边对齐,现在看图得知,需要移动的距离为
(layercolor4.contentSize.width*layercolor.scaleX-layercolor.contentSize.width),大地图缩放后的长度-screen的长度,就是差值
所以综上layercolor.position=ccp(layercolor5.position.x-(layercolor4.contentSize.width*layercolor.scaleX-layercolor.contentSize.width),300)
全部的代码为
CCScene *scene=[CCScene node];
CCLayerColor *layercolor2=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor2 z:MaxZorder-];
layercolor2.position=ccp(,);
CCLayerColor *layercolor5=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor5 z:MaxZorder-];
layercolor5.position=ccp(,);
layercolor5.scaleX=0.75;
CCLayerColor *layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor5 addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
layercolor5.position=ccp(layercolor5.position.x+layercolor5.contentSize.width/*(layercolor5.scaleX-),);
CCLayerColor * layercolor=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[scene addChild:layercolor z:MaxZorder-];
layercolor.position=ccp(-(-),);
layercolor.scaleX=0.75;
layercolor4=[[[CCLayerColor alloc]initWithColor:ccc4(, , , ) width: height:]autorelease];
[layercolor addChild:layercolor4 z:MaxZorder-];
layercolor4.position=ccp(,);
//***********************************第一种方法******************************/
//layercolor.position=ccp(layercolor.position.x+(1-layercolor.scaleX)*500-(layercolor.contentSize.width/2)*0.25,layercolor.position.y);
//***********************************第二种方法******************************/
int px=layercolor5.position.x-(layercolor4.contentSize.width*layercolor.scaleX-layercolor.contentSize.width);
layercolor.position=ccp(px,);
[[CCDirector sharedDirector] runWithScene:[CCTransitionFade transitionWithDuration:0.5 scene:scene withColor:ccBLACK]];
效果为:

如何让CCLayer创造的地图,左右滑动不出现黑边的更多相关文章
- ArcGIS api for javascript——地图配置-滑动器的刻度线、方向、大小的改变
描述 本例展示了如果删除缩放等级滑动器的刻度线.通过设置esriConfig里的sliderLabel为null来实现: esriConfig.defaults.map.sliderLabel = n ...
- javascript实现百度地图鼠标滑动事件显示、隐藏
其实现思路是给label设置样式,我们来看下具体做法吧 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 var label = new BMap.Labe ...
- 解决ListView滑动时出现黑边的问题
[声明]转载请注明出处,此文出自指尖飞落的博客:http://blog.csdn.net/huntersnail --尊重作者,知识无价.交流无限! 两种方法 1.代码去边缘线 myList.setF ...
- 解决ScrollView嵌套百度地图滑动冲突
一.问题描述 scrollview中嵌套百度地图时会出现滑动冲突,地图无法滑动的情况. 二.期望结果 焦点在地图上时,只有地图移动,焦点在地图外部时,可以滑动scrollview. 三.解决方法 自定 ...
- 一行代码,让你的应用中UIScrollView的滑动与侧滑返回并存
侧滑返回是iOS系统的一个很贴心的功能,特别是在大屏手机上,单手操作的时候去按左上角的返回键特别不方便.当我在使用一个APP的时候,如果控制器不能侧滑返回,我会觉得这个APP十分不友好...这款产品在 ...
- 如何在iOS地图上高效的显示大量数据
2016-01-13 / 23:02:13 刚才在微信上看到这篇由cocoachina翻译小组成员翻译的文章,觉得还是挺值得参考的,因此转载至此,原文请移步:http://robots.thought ...
- Google Map Api 谷歌地图接口整理
一:基本知识: 1. 使用谷歌地图 API 的第一步就是要注册一个 API 密钥,需要注重一下两点: 1.假如使用 API 的页面还没有发布,只是在本地调试,可以不用密钥,随便用个字符串代替就可以了. ...
- [ios3-地图] 如何在iOS地图上高效的显示大量数据 [转]
[转至:http://blog.csdn.net/pjk1129/article/details/17358337] 原文:How To Efficiently Display Large Amoun ...
- ArcGIS api for javascript——创建地图
描述 这个示例显示ArcGIS Server的一个地图.ArcGIS Server地图是缓存的,意味着它有服务器管理员建来提升性能的一组预先渲染的切片.由于这个原因地图通过ArcGISTiledMap ...
随机推荐
- 关于C语言的问卷调查(补交)
你对自己的未来有什么规划?做了哪些准备?(还是处于比较迷茫的状态:我做的准备是吧自己对计算机的兴趣提起来!) 你认为什么是学习?学习有什么用?现在学习动力如何?为什么?(学习就是学自己不会的东西:增加 ...
- CSS3的nth-child(n)选择器学习
写法:tr:nth-child(2),表示非tr的子元素中的第二个元素,并非从0开始计数,跟编程语言中的数组有区别. 参考网址:http://www.w3schools.com/cssref/sel_ ...
- 最小的N个和
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 有两个长度为 N 的序列 A 和 B,在 A 和 B 中各任取一个数可以得到 ...
- NOIP2016报零记
其实,NOIP2016已经于10天之前就结束了,但是由于种种原因,没有写总结. 现在就来填上这个坑吧. DAY1: T1:一道简(kun)单(nan)的模拟,虽然ac,但是考试的时候总觉得怪怪的.并且 ...
- python之读取cdv
csv是Comma-Separated Values的缩写,是用文本文件形式储存的表格数据,比如如下的表格: 就可以存储为csv文件,文件内容是:No.,Name,Age,Score1,Apple,1 ...
- Static List
Static ListStatic List is the smart implementation of list data structure for those languages that h ...
- multithreading - Reader/Writer Locks in C++
You Only Need To Note This: only 1 single thread can acquire an upgrade_lock at one time. others are ...
- Android开发中的输入合法性检验
Why ? 合法性检查对于程序的健壮性具有重要作用.在Android开发中,良好的合法性检查设计机制可以使程序更加清晰,产生bug更少,交互更加友好. What ? 合法性检查的目的在于确定边界.对于 ...
- C#模拟键盘事件
public partial class Form1 : Form { public Form1() { InitializeComponent(); } [DllImport("USER3 ...
- 其他信息: 未找到源,不过,未能搜索部分或所有事件日志。 若要创建源,您需要用于读取所有事件日志的权限以确保新的源名称是唯一的。 不可访问的日志: Security。
其他信息: 未找到源,不过,未能搜索部分或所有事件日志. 若要创建源,您需要用于读取所有事件日志的权限以确保新的源名称是唯一的. 不可访问的日志: Security. System.Diagnos ...