Como esconder / mostrar a barra de navegação quando o usuário rola para cima / baixo

Ocultar / mostrar a barra de navegação quando o usuário rola para cima / baixo

Aqui está o exemplo que estou tentando alcançar: http://haraldurthorleifsson.com/ ouhttp://www.teehanlax.com/story/readability/

A barra de navegação desliza para fora da tela quando você rola para baixo e desliza para baixo na tela quando você rola para cima. Eu descobri como fazê-lo com o fade in / fade out, mas eu gostaria de alcançá-lo com a mesma animação que no exemplo.Nota: Eu já tentei SlideIn () e gosto da maneira que ele faz a animação de alongamento ...

JQUERY:

var previousScroll = 0,
headerOrgOffset = $('#header').offset().top;

$('#header-wrap').height($('#header').height());

$(window).scroll(function() {
    var currentScroll = $(this).scrollTop();
    console.log(currentScroll + " and " + previousScroll + " and " + headerOrgOffset);
    if(currentScroll > headerOrgOffset) {
        if (currentScroll > previousScroll) {
            $('#header').fadeOut();
        } else {
            $('#header').fadeIn();
            $('#header').addClass('fixed');
        }
    } else {
         $('#header').removeClass('fixed');   
    }
    previousScroll = currentScroll;
});

CSS:

#header {
    width: 100%;
    z-index: 100;
}

.fixed {
    position: fixed;
    top: 0;
}

#header-wrap {
    position: relative;
}

HTML:

    <div id="header-wrap">
    <div id="header" class="clear">
        <nav>
            <h1>Prototype</h1>
        </nav>
    </div>
</div>

questionAnswers(5)

yourAnswerToTheQuestion