首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TED Talk主页是如何组织视频网格的?

TED Talk主页是如何组织视频网格的?
EN

Stack Overflow用户
提问于 2011-07-03 19:40:44
回答 3查看 1.4K关注 0票数 11

我一直在尝试弄清楚TED Talk homepage到底是如何工作的。抛开所有的动画垃圾不谈,我发现盒子的组织方式真的很吸引人。

乍一看,它看起来像jQuery masonry plugin,但很快就会发现,它倾向于创建几个直角三角形形状,但没有固定的列数或行数,并且最终生成的形状始终是完全实心的(没有中空部分)。

我最初的假设是,这些盒子(它们的大小是由网站上的一些因素预先确定的)是随机排序的,然后使用一些简单的规则按顺序添加到网格中,但是我无法确定这些规则是什么,也不知道它们如何防止最终形状中的任何凹陷。

有谁知道这是怎么回事吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-08-12 08:43:35

我想我已经想好了。

首先,项目的数量变化很大,我目前正在查看的页面只有13个框。

首先,我将4个大小的块从大到小分别命名为: A、B、C、D

正如我们所知,第一个“行”包含两个A和两个垂直的B堆栈,例如:

代码语言:javascript
复制
 _______________________
|   A   | B |   A   | B |
|       |___|       |___|
|       | B |       | B |
|_______|___|_______|___|

它们的排列看起来是随机的,但B始终处于相同的垂直模式中。看到这里,我意识到只有两行,第二行的工作方式是一样的。

第二行的高度是第一行的两倍,占据了页面的其余部分。它是由水平堆叠的形状模式构建的,这些形状(至少部分)是随机选择的。

我已经找到了9种形状的模式,其中两种是单一的A或B,其余的是:

代码语言:javascript
复制
  _______    _______    _______    ___    ___    _______    ___
 | B | B |  |   A   |  | B | B |  |C|C|  | B |  |   A   |  |C|C|
 |___|___|  |       |  |___|___|  | B |  |___|  |       |
 |   A   |  |       |  | B | B |  |___|  |C|D   |       |
 |       |  |_______|  |___|___|                |_______|
 |       |  | B | B |  |   A   |                | B |    
 |_______|  |___|___|  |       |                |___|    
 |B  |C|    |B  |C|    |       |
 |___|      |___|      |_______|

下一个问题是如何选择这些?可能会有一些巧妙的搜索来找到最佳配置:例如,如果有X个项目要显示,我们需要找到一个总X个不超过行宽的配置。

这可以使用模式密度的度量来完成,该度量将是块的数量除以模式的宽度。

票数 0
EN

Stack Overflow用户

发布于 2011-07-03 22:22:14

可能是错误的,但有几点观察:

  • 每个部分有19个视频
  • 有4个大小1 (#1)、1/4 (#2)、1/16 (#3)和1/32 (#4)

(#2)、(#3)和(#4)的数量可以是:

  • 4(#1),10(#2),4(#3),1(#1) = 19
  • 4(#1),11(#2),4(#3),0(#1) = 19
  • 4(#1),11(#2),3(#3),1(#1) = 19
  • 4(#1),12(#2),2(#3),1(#1) =19

<代码>H1154(#1),13(#2),

至于顺序:

  • 第一行始终包含2(#1)和4(#2)
  • (#4)始终位于列

的底部

票数 4
EN

Stack Overflow用户

发布于 2013-11-24 05:37:41

下面是执行此操作的javascript代码(您需要一个带有div#container的html页面):

代码语言:javascript
复制
function ted_layout(settings, coordinates_array, num_elements, start_x, start_y, arrangement, remaining_elements, is_child){
    var num_columns = arrangement.length;
    var col = 0;
    var current_x = start_x;
    while( col < num_columns){
        var column_x_scale = 100 / arrangement[col];
        var current_column_arrangement;
        if(is_child){
            if(num_elements > 14){
                if(column_x_scale == 50){
                    current_column_arrangement = random_shuffle([1, 2, 2]);
                } else {
                    current_column_arrangement = random_shuffle([1, 2]);
                }
            } else if(num_elements > 10){
                if(column_x_scale == 50){
                    current_column_arrangement = [1];
                } else {
                    current_column_arrangement = random_shuffle([1, 2]);
                }
            } else{
                    current_column_arrangement = random_shuffle([1, 2]);
            }
        } else {
            if(num_elements > 14){
                if(column_x_scale == 25){
                    current_column_arrangement = [1, 1];
                } else {
                    current_column_arrangement = [1];
                }
            } else if(column_x_scale == 25){
                    current_column_arrangement = [1, 1];
            } else {
                    current_column_arrangement = [1];
            }
        }


        var num_rows = current_column_arrangement.length;
        var current_y = start_y;
        var row = 0;
        while(row < num_rows){

            var numRects = current_column_arrangement[row];
            var current_rectangle = 0;
            var current_rectangle_x = current_x;

            while( current_rectangle < numRects){
                if(remaining_elements == 0){
                   return coordinates_array;
                }
                var currScale = column_x_scale/numRects;
                var height = settings.height * currScale*0.01;
                var width = settings.width * currScale*0.01;
                if(current_rectangle == numRects-1 && row == num_rows-1 && is_child && Math.random() > 0.5){
                    coordinates_array.push({x: current_rectangle_x, y:current_y, w:width/2, h:height/2, scale:currScale/2*0.01*2})
                }
                else{
                    coordinates_array.push({x: current_rectangle_x, y:current_y, w:width, h:height, scale:currScale*0.01*2})
                }
                current_rectangle_x += width;
                remaining_elements--;
                current_rectangle++;
            }
            row++;
            current_y += height;
        }
        current_x = current_rectangle_x;
        col++;
    }
    if( remaining_elements > 0){
        coordinates_array = ted_layout(settings, coordinates_array, num_elements, start_x, current_y, random_shuffle([2, 4, 4, 2]), remaining_elements, true);
    }
    return coordinates_array;
}


function generate_ted_layout(num_elements){
    var settings = {
        width: 640,
        height: 480,
    };
    var coordinates_array=[];
    returned = ted_layout(settings, coordinates_array, num_elements, 0, 0, random_shuffle([2, 4, 4, 2]), num_elements, false);
    console.log("Returned", returned)
    return returned;
}

function random_shuffle(array){
    var temp;
    for(var i = array.length - 1; i >= 1; i--){
        var elem = Math.floor(Math.random() * (i + 1));
        temp = array[elem];
        array[elem] = array[i];
        array[i] = temp;
    }
    return array;
}


function initAndLayout() {
    var items = generate_ted_layout(20);

    var container = $('#container');    // cache jquery object
    console.log(items);
    for (var i = 0; i < items.length; i++)
    {
        var item = items[i];
        console.log(item);
        $('#container').append($('<div class="item"></div>').css({'left': item.x, 'top': item.y, 'width': item.w, 'height': item.h}));
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6562651

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档