Скрыть содержимое под прозрачным div при прокрутке

Изменить с помощью возможного решения ниже кода

На сайте есть полностраничное видео.

Действие прокрутки: не отображать содержимое, которое расположено на 250 пикселей или меньше сверху - так что 250 пикселей верхней части видео всегда видны.

Возможно, лучший способ понять это: скрыть контент под прозрачным div. Но я думаю, что первое объяснение более важно для кода.

Второе объяснение приводит к многочисленным вопросам и полу-ответам. Однако ни одна из них не решает мою проблему.

Здесь есть неотвеченный вопрос, который охватывает много: Как скрыть содержимое, которое прокручивается под прозрачным div?

Я бы предпочла, чтобы полоса прокрутки была полной.

Может быть, это может быть подсказка: Добавить класс в DIV, когда верхняя часть окна достигает определенного элемента и удаляет его, если нет
Этот код может определять позицию содержимого. Теперь, чтобы скрыть это верхнее переполнение.

Demo
http://jsfiddle.net/4TgmF/

HTML

<div id="header">
    <video autoplay loop poster="https://dl.dropboxusercontent.com/u/9200106/rsz_dreamstimefree_252880.jpg" id="bgvid">
        <source src="video.mp4" type="video/mp4">
        <source src="video.ogv" type="video/ogg">
    </video>
    <div id="visible_part">Part of the background that shoud be visible at all times. This DIV and its styling is for demonstration only</div>
</div>

<div id="content">
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec a diam lectus. Sed sit amet ipsum mauris. Maecenas congue ligula ac quam viverra nec consectetur ante hendrerit. Donec et mollis dolor. Praesent et diam eget libero egestas mattis sit amet vitae augue. Nam tincidunt congue enim, ut porta lorem lacinia consectetur. Donec ut libero sed arcu vehicula ultricies a non tortor. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean ut gravida lorem. Ut turpis felis, pulvinar a semper sed, adipiscing id dolor. Pellentesque auctor nisi id magna consequat sagittis. Curabitur dapibus enim sit amet elit pharetra tincidunt feugiat nisl imperdiet. Ut convallis libero in urna ultrices accumsan. Donec sed odio eros. Donec viverra mi quis quam pulvinar at malesuada arcu rhoncus. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. In rutrum accumsan ultricies. Mauris vitae nisi at sem facilisis semper ac in est.</p>
</div>

CSS

* { margin:0; }
html, body {
  width:100%;
  height:100%;
}
#header {
    width:100%;
    height:100%;
}
#bgvid {
    position:fixed;
    z-index:-1000;
    width:auto;
    height:auto;
    min-width:100%;
    min-height:100%;
}
#visible_part {
    position:fixed;
    height:250px;
    border-bottom:1px solid rgba(255,255,255,0.1);
    color:#fff;
    background:rgba(0,0,0,0.1);
}
#content {
    width:100%;
    min-height:100%;
    background:#fafafa;
}

Edit
Гаюс Куизинас предложил в комментариях повторить фон и использовать его в качестве маски, что на самом деле не решает проблему, но он заставил меня задуматься (спасибо). Ключевое слово здесь - маска. Я нашел хорошую статью по этому поводу: http://thenittygritty.co/css-masking Я думаю, что это может быть отличным решением. Маска имела бы position:fixed;, top:250px;, height:100%; (- 250px). Единственная проблема - я не могу понять, как сделать маску с фиксированным положением и прокручиваемым контентом. Вы видите, что я имею в виду?

Ответ 1

Вот рабочее решение в скрипке.

Описание

  • Разместите заголовок в фоновом режиме
  • Установите высоту тела для высоты заголовка плюс высота содержимого
  • Поместите содержимое в обертку в нижней части тела: position: absolute; bottom: 0
  • Поместите содержимое в верхнюю часть его обертки: position: absolute; top: 0
  • Установите высоту обертки для соответствия высоте содержимого
  • Когда верхняя часть обертки содержимого прокручивается в нижней части видимой части, измените ее положение на фиксированное в этой точке: position: fixed; top: bottom of the visible part
  • Если оболочка содержимого position: fixed, сдвиньте содержимое внутри своей оболочки, чтобы продолжить прокрутку

Большинство этих значений заданы в JavaScript для получения фактических вычисленных значений, а не процентов. Это также позволяет пересчитать размер окна.

код

HTML

<div id="header">
    <video id="bgvid" autoplay loop muted>
        <source src="http://techslides.com/demos/sample-videos/small.mp4" type="video/mp4">
        <source src="http://techslides.com/demos/sample-videos/small.ogv" type="video/ogg">
    </video>
</div>

<div id="content_wrapper">            
    <div id="content">
    </div>
</div>

CSS

* { 
    margin:0; 
}
html, body {
    position: relative;
    width:100%;
    height:100%;
}
#header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1000;
    width:100%;
    height:100%;
}
#bgvid {
    width:auto;
    height:auto;
    min-width:100%;
    min-height:100%;
}
#content_wrapper {
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    overflow: hidden;    
    z-index: -10;
}
#content {
    background: white;
    position: absolute;
    left: 0px;
    top: 0px;
}

JavaScript (где происходит настоящая магия)

var $window = $(window);
var $body = $('body');
var $contentWrapper = $('#content_wrapper');
var $content = $('#content');
var minHeaderHeight = 250; // the height of the "visible part"

var lastWindowHeight = $window.height(); // save window height to calculate difference in height on resize

checkScroll(); // make sure scroll and all heights are correct on first load
stickyTop();   // make sure sticky top is used if needed on first load

$window.resize(function() {
    checkScroll();
    stickyTop();
});
$window.scroll(function() {
    stickyTop();
});

function checkScroll() {
    var newWindowHeight = $window.height();
    var windowHeightDif = newWindowHeight - lastWindowHeight;
    lastWindowHeight = newWindowHeight; // save current height for next call

    var contentHeight = $content.height();
    $contentWrapper.height(contentHeight);         // make sure wrapper will show entire content
    $body.height(newWindowHeight + contentHeight); // allow content to be scrolled off the screen by
                                                   // pushing content down by the amount of window height

    var windowScrollTop = $window.scrollTop();
    if (windowScrollTop > 0) {                                // don't scroll if at top to avoid video getting covered
        $window.scrollTop(windowScrollTop + windowHeightDif); // scroll by window height difference to keep content 
                                                              // in the same position on window resize
    }
}

function stickyTop() {
    var windowScrollTop = $window.scrollTop();
    var maxScroll = ($window.height() - minHeaderHeight);
    if (windowScrollTop >= maxScroll) {
        $contentWrapper.css('position', 'fixed').css('top', minHeaderHeight); // stop wrapper top at bottom of header
    } else {
        $contentWrapper.css('position', 'absolute').css('top', ''); // allow regular scrolling
    }

    if ($contentWrapper.css('position') === 'fixed') {       // if wrapper is fixed,
        $content.css('top', -(windowScrollTop - maxScroll)); // continue scrolling by shifting content up
    } else {
        $content.css('top', 0); // make sure content is lined up with wrapper
    }
}

Ответ 2

Вы можете превратить видимую часть в position: fixed; height: 250px, как только прокрутите ее:

JS:

$(document).ready(function () {
    var bottom = $('#content').offset().top - 250; // this needs to be the same as #inner.fixed height
    $(window).scroll(function () {
        if ($(this).scrollTop() > bottom) {
            $('#inner').addClass('fixed');
        } else {
            $('#inner').removeClass('fixed');
        }
    });
});

CSS

#header, #inner {
    width:100%;
    height:100%;
}
#inner.fixed {
    position: fixed;
    height: 250px;
    overflow-y: hidden;
    overflow-x: hidden;
}
#bgvid {
    position: fixed;
    z-index:-1000;
    width:auto;
    height:auto;
    min-width:100%;
    min-height:100%;
}
.fixed #bgvid {
    position: relative;
}

HTML: Оберните #bgvid в <div id="inner">

Скрипка: http://jsfiddle.net/4TgmF/11/