dicas blog
Home » , , » Como adicionar no blogger um gadget flutuante

Como adicionar no blogger um gadget flutuante

2
Nesse tutorial  vou  mostrar  como  transformar   no  blogger  qualquer  gadget  em  um gadget  flutuante,  O  sistema  desse   gadget  é bem  divertido  ao rolar  a  pagina o gadget  deci  junto  com  a pagina,  subindo  a  pagina  de volta  ele  retorna  ao  seu  lugar de  origem.  É  ótimo  para destacarmos  algo  como  uma  fan page ou  caixa  assinar  por  e-mail etc.  se  você  esta  personalizando  seu  blog  ou  começou  agora   a  blogar  não  vai encontrar dificuldades  para  criar  um  gadge flutuante  em  seu  blog,  siga  os  passos abaixo  e  vamos  ao  tutorial.
 
Tutorial para blogspot e blogger.



Primeiro    em  modelo  editar  HTML  e procure  por </head> e  adicione o código  abaixo   acima desse trecho e  salve  o modelo.

<script src='http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js' type='text/javascript'/>

Tutorial  atualizado:código na caixinha abaixo.

Agora vá  layout e adicione  um  gadget  javascript  e copie  o código  abaixo  e  adicione  o  código  dentro  do  gadget,  note você vai encontrar  no  final  do  código  esse  trecho  SEU CÓDIGO GADGET AQUI   adicione  seu  gadget nesse  local  e  salve  o  gadget  e araste  para  onde  quiser   que ele seja  visto.

Lembrandoquando  eu  falei seu  gadget,  quis dizer  seu  código  de botões  de rede  sociais  ou  uma  fan page ou publicidade  tanto faz.

 <script type="text/javascript">
//<![CDATA[
(function($) {
    var defaults = {
            topSpacing: 0,
            bottomSpacing: 0,
            className: 'is-sticky',
            wrapperClassName: 'sticky-wrapper'
        },
        $window = $(window),
        $document = $(document),
        sticked = [],
        windowHeight = $window.height(),
        scroller = function() {
            var scrollTop = $window.scrollTop(),
                documentHeight = $document.height(),
                dwh = documentHeight - windowHeight,
                extra = (scrollTop > dwh) ? dwh - scrollTop : 0;
            for (var i = 0; i < sticked.length; i++) {
                var s = sticked[i],
                    elementTop = s.stickyWrapper.offset().top,
                    etse = elementTop - s.topSpacing - extra;
                if (scrollTop <= etse) {
                    if (s.currentTop !== null) {
                        s.stickyElement
                            .css('position', '')
                            .css('top', '')
                            .removeClass(s.className);
                        s.stickyElement.parent().removeClass(s.className);
                        s.currentTop = null;
                    }
                }
                else {
                    var newTop = documentHeight - s.stickyElement.outerHeight()
                        - s.topSpacing - s.bottomSpacing - scrollTop - extra;
                    if (newTop < 0) {
                        newTop = newTop + s.topSpacing;
                    } else {
                        newTop = s.topSpacing;
                    }
                    if (s.currentTop != newTop) {
                        s.stickyElement
                            .css('position', 'fixed')
                            .css('top', newTop)
                            .addClass(s.className);
                        s.stickyElement.parent().addClass(s.className);
                        s.currentTop = newTop;
                    }
                }
            }
        },
        resizer = function() {
            windowHeight = $window.height();
        },
        methods = {
            init: function(options) {
                var o = $.extend(defaults, options);
                return this.each(function() {
                    var stickyElement = $(this);
                    stickyId = stickyElement.attr('id');
                    wrapper = $('<div></div>')
                        .attr('id', stickyId + '-sticky-wrapper')
                        .addClass(o.wrapperClassName);
                    stickyElement.wrapAll(wrapper);
                    var stickyWrapper = stickyElement.parent();
                    stickyWrapper.css('height', stickyElement.outerHeight());
                    sticked.push({
                        topSpacing: o.topSpacing,
                        bottomSpacing: o.bottomSpacing,
                        stickyElement: stickyElement,
                        currentTop: null,
                        stickyWrapper: stickyWrapper,
                        className: o.className
                    });
                });
            },
            update: scroller
        };
    // should be more efficient than using $window.scroll(scroller) and $window.resize(resizer):
    if (window.addEventListener) {
        window.addEventListener('scroll', scroller, false);
        window.addEventListener('resize', resizer, false);
    } else if (window.attachEvent) {
        window.attachEvent('onscroll', scroller);
        window.attachEvent('onresize', resizer);
    }
    $.fn.sticky = function(method) {
        if (methods[method]) {
            return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
        } else if (typeof method === 'object' || !method ) {
            return methods.init.apply( this, arguments );
        } else {
            $.error('Method ' + method + ' does not exist on jQuery.sticky');
        }
    };
    $(function() {
        setTimeout(scroller, 0);
    });
})(jQuery);

//]]>
</script>
<script>
$(document).ready(function(){
$("#rbtSocialFloat").sticky({topSpacing:0});
$("#topside_box").sticky({topSpacing:6});
});
</script>
<div class="sticky-wrapper" id="topside_box-sticky-wrapper" style="height: 222px;text-align:center;"><div id="topside_box-sticky-wrapper" class="sticky-wrapper" style="height: 112px;"><div class="" id="topside_box" style="">
SEU CÓDIGO GADGET AQUI
</div></div></div>

Tutorial  atualizado:código na caixinha abaixo.


Depões de ter  adicionado  o  código salve o  gadget,  era  isso duvidas  é só  perguntar.

2 comentários:

  1. Olá :)
    Adorei as dicas do teu blog :)
    Eu já tinha um gadget flutuante no meu blog e agora surgiu-me a ideia de adicionar uma borda do lado direito, mas que fosse do tamanho do conteúdo do gadget e que flutua-se no blog com este, já tentei de imensas maneiras mas a borda fica ou estática ou de todo o comprimento da sidebar, achas que podes ajudar-me?
    Deixo aqui o link do meu blog: http://blog-le-dernier.blogspot.pt/

    ResponderExcluir
  2. O tutorial é bom mais o gadget não eh flutuante

    ResponderExcluir