jquery - Change background color saturation based on percentage loaded -


i want make preloader of sorts page loads instead of resizing divs width based on % loaded change saturation of background-color of div based on % loaded.

to honest don't mind if have set #fff , fade color red don't know how saturation change or % of color faded % loaded.

this have been trying:

js

$("#preloader").each(function() {     $(this)         .data("origcolor", $(this).backgroundcolor())         .backgroundcolor('#f4421a')         .animate({             backgroundcolor: $(this).data("origcolor")         }, 1200); }); 

css

@-webkit-animation changecolor {    0% { background-color: $white; }    100% { background-color: $orange; } } .js div#preloader {      @include position(fixed, $z:9999);     width: 100%;      height: 100%;      overflow: visible;      background: $loading no-repeat center center, $header-bg-mobile repeat top left, lighten($black,70%);     -webkit-animation: changecolor 2s linear infinite; } 

example

keep background-color is, change opacity value via jquery

$("#preloader").each(function() {   $(this).css('opacity','0');   //function calculate % loading ...   $(this).animate({opacity: '1'}, 4000); }); 

update... since can't use opacity property, can use 1 of following 2 methods:

*p.s: not efficient they're working

first method: can create multiple css classes in each define background color, each class name has numerical value can change through loop while loading , use toggle class property in code:

example1: background color

the html

<div id="preloader" class="pclass0c"></div> 

the jquery

 var currclass= 0;  var totalclasses= 15;     window.setinterval(preloading, 200);     function preloading(){       if (currclass < totalclasses){              $('#preloader').toggleclass('pclass'+currclass+'c');                 currclass++;         };     } 

the css - color classes sample

.pclass3c{ background-color:#dddeff; } .pclass4c{ background-color:#c8c9ff; } .pclass5c{ background-color:#aaacff; } .pclass6c{ background-color:#989aff; } .pclass7c{ background-color:#7c7fff; } 

this method easier , more flexible since easy alter colors or add more fades, , remember more number of color classes is, smoother animation , more precise %loading value.


example1: using .png background image

second method can use css image-sprite , animate background imag's top value depending on %loading, like:

var bgpos= -15500;         $('#preloader').css( {backgroundposition: "0 -15500px"} );         window.setinterval(preloading, 200);         function preloading(){             if (bgpos < 0){                 $('#preloader').css({backgroundposition: "0 "+bgpos+"px"});                 bgpos= bgpos+ 1500;             };         } 

but in method need jquery pluging called jquery.bgpos.js can check if view page source.


Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -