对数组中的 z 索引进行排序
我有一个数组,看起来类似于
resourceData[0][0] = "pic1.jpg";
resourceData[0][1] = 5;
resourceData[1][0] = "pic2.jpg";
resourceData[1][1] = 2;
resourceData[2][0] = "pic3.jpg";
resourceData[2][1] = 900;
resourceData[3][0] = "pic4.jpg";
resourceData[3][1] = 1;
数字表示图像的 z 索引。最小 z-index 值是 1。最大值(不是很重要)是 2000。
我已经完成了所有渲染和设置 z-indexes。我的问题是,我想要四个函数:
// Brings image to z front
function bringToFront(resourceIndex) {
// Set z-index to max + 1
resourceData[resourceIndex][1] = getBiggestZindex() + 1;
// Change CSS property of image to bring to front
$('#imgD' + resourceIndex).css("z-index", resourceData[resourceIndex][1]);
}
function bringUpOne(resourceIndex) {
}
function bringDownOne(resourceIndex) {
}
// Send to back z
function sendToBack(resourceIndex) {
}
因此给定索引 [3] (900 z):
如果我们将其发送到后面,它将取值 1,而 [3] 将必须变为 2,但是这与 [1] 冲突,[1] 的 z 索引为 2,所以他们需要转到 3,等等。
有没有一种简单的编程方法可以做到这一点,因为一旦我开始这样做,它就会变得混乱。
数组的索引不改变是重要的。不幸的是,由于设计原因,我们无法对数组进行排序。
更新 感谢您的回答,一旦编写好函数,我就会在这里发布这些函数,以防将来有人遇到这个问题(请注意,此代码在[6]中列出了 zindex)
// Send to back z
function sendToBack(resourceIndex) {
resourceData[resourceIndex][6] = 1;
$('#imgD' + resourceIndex).css("z-index", 1);
for (i = 0; i < resourceData.length; i++) {
if (i != resourceIndex) {
resourceData[i][6]++;
$('#imgD' + i).css("z-index", resourceData[i][6]);
}
}
}
I have an array which looks something along the lines of
resourceData[0][0] = "pic1.jpg";
resourceData[0][1] = 5;
resourceData[1][0] = "pic2.jpg";
resourceData[1][1] = 2;
resourceData[2][0] = "pic3.jpg";
resourceData[2][1] = 900;
resourceData[3][0] = "pic4.jpg";
resourceData[3][1] = 1;
The numeric represents the z-index of the image. Minimum z-index value is 1. Maximum (not really important) is 2000.
I have all the rendering and setting z-indexes done fine. My question is, I want to have four functions:
// Brings image to z front
function bringToFront(resourceIndex) {
// Set z-index to max + 1
resourceData[resourceIndex][1] = getBiggestZindex() + 1;
// Change CSS property of image to bring to front
$('#imgD' + resourceIndex).css("z-index", resourceData[resourceIndex][1]);
}
function bringUpOne(resourceIndex) {
}
function bringDownOne(resourceIndex) {
}
// Send to back z
function sendToBack(resourceIndex) {
}
So given then index [3] (900 z):
If we send it to the back, it will take the value 1, and [3] will have to go to 2, but that conflicts with [1] who has a 2 z-index so they need to go to three etc.
Is there an easy programatical way of doing this because as soon as I start doing this it's going to get messy.
It's important that the indexes of the array don't change. We can't sort the array unfortunately due to design.
Update
Thanks for answers, I'll post the functions here once they are written incase anyone comes across this in the future (note this code has zindex listed in [6])
// Send to back z
function sendToBack(resourceIndex) {
resourceData[resourceIndex][6] = 1;
$('#imgD' + resourceIndex).css("z-index", 1);
for (i = 0; i < resourceData.length; i++) {
if (i != resourceIndex) {
resourceData[i][6]++;
$('#imgD' + i).css("z-index", resourceData[i][6]);
}
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
循环!此功能将对其周围受影响的图像重新排序。它将适用于具有广泛分离的 z-index 值的图像。除非需要,它也不会执行任何更改。
编辑:添加了完成 CSS 工作的功能
编辑2:更正了顶部/底部功能的问题 - 它没有移动所有受影响的图像,现在是了。
Loops! This function will reorder affected images around it. It will work with images that have widely separated z-index values. It also does not perform any changes unless it needs to.
EDIT: added function to do the CSS work
EDIT 2: Corrected problem with top/bottom functions - it wasn't moving all the images affected, now it is.
就是这样:复制您的结构并对其进行正确排序,或者如果您愿意将其称为索引。当您需要图片时,找到正确的 z-index 并继续进行渲染。
如果您不想复制整个结构,您可以动态地执行此操作并使用堆。
There it is: copy your structure and have it properly ordered, or if you prefer call it indexed. When you need the picture find the proper z-index and proceed w/ the rendering.
You can do that dynamically and use heap, if you don't wish to copy the entire structure.
没有测试过,但是这个怎么样。对于bringUpOne、bringDownOne,您可以交换z-indexes,例如:
对于带到前面:
现在一切都很好。但是,如果您想连续将图像设置到后面,会发生什么情况呢?您可以每次将 zIndex 设置为 0(不知道在任何时候实际上有多少个可见),或者您可以从最低的 zIndex 设置为 2000 或 10000 等,这将容纳许多调用设置为返回。
编辑:这假设列表是按 zIndex 排序的。
Not tested, but how about this. For bringUpOne, bringDownOne one you can swap the z-indexes, e.g:
For bringing to the front:
Now that's all fine. But what happens if you want to successively set images to the back? You can either set the zIndex to 0 each time (don't know how many you'll have actually visiable at any time) or you can start with the lowest zIndex set to something like 2000 or 10000 or whatever, which will acccomodate many calls to setToBack.
Edit: This assumes the list is ordered by zIndex to start with.