Arama butonu
Bu konudaki kullanıcılar: 1 misafir, 1 mobil kullanıcı
1
Cevap
278
Tıklama
0
Öne Çıkarma
Lütfen Yardım Edin Basit Bir SORU
K
6 yıl
Er
Konu Sahibi

Elimde şöyle bi kod var yazıların üstüne gelince parıltı efekti veriyo ama ben üstüne gelmeden sürekli parıldamasını istiyorum gerekli düzenlemeyi söylermisiniz



<script>


$(function() {


// default is varying levels of transparent white sparkles
$(".sparkley:first").sparkleh();

// rainbow as a color generates random rainbow colros
// count determines number of sparkles
// overlap allows sparkles to migrate... watch out for other dom elements though.
$(".sparkley:last").sparkleh({
color: "rainbow",
count: 100,
overlap: 10
});

// here we create fuscia sparkles
$("h1").sparkleh({
count: 80,
color: ["#ff0080","#ff0080","#0000FF"]
});



$("p").sparkleh({
count: 20,
color: "#00ff00",
speed: 0.05
});


// an array can be passed, too for colours
// for an image, the image needs to be fully loaded to set
// the canvas to it's height/width.
// speed allows us to control... the ... velocity
$("#image").imagesLoaded( function() {
$(".img").sparkleh({
count: 25,
color: ["#f3edc4","#253943","#659e3f"],
speed: 1.5
});
});


});







$.fn.sparkleh = function( options ) {

return this.each( function(k,v) {

var $this = $(v).css("position","relative");

var settings = $.extend({
width: $this.outerWidth(),
height: $this.outerHeight(),
color: "#FFFFFF",
count: 30,
overlap: 0,
speed: 1
}, options );

var sparkle = new Sparkle( $this, settings );

$this.on({
"mouseover focus" : function(e) {
sparkle.over();
},
"mouseout blur" : function(e) {
sparkle.out();
}
});

});

}




function Sparkle( $parent, options ) {
this.options = options;
this.init( $parent );
}

Sparkle.prototype = {

"init" : function( $parent ) {

var _this = this;

this.$canvas =
$("<canvas>")
.addClass("sparkle-canvas")
.css({
position: "absolute",
top: "-"+_this.options.overlap+"px",
left: "-"+_this.options.overlap+"px",
"pointer-events": "none"
})
.appendTo($parent);

this.canvas = this.$canvas[0];
this.context = this.canvas.getContext("2d");

this.sprite = new Image();
this.sprites = [0,6,13,20];
this.sprite.src = this.datauri;

this.canvas.width = this.options.width + ( this.options.overlap * 2);
this.canvas.height = this.options.height + ( this.options.overlap * 2);


this.particles = this.createSparkles( this.canvas.width , this.canvas.height );

this.anim = null;
this.fade = false;

},

"createSparkles" : function( w , h ) {

var holder = [];

for( var i = 0; i < this.options.count; i++ ) {

var color = this.options.color;

if( this.options.color == "rainbow" ) {
color = '#'+ ('000000' + Math.floor(Math.random()*16777215).toString(16)).slice(-6);
} else if( $.type(this.options.color) === "array" ) {
color = this.options.color[ Math.floor(Math.random()*this.options.color.length) ];
}

holder[i] = {
position: {
x: Math.floor(Math.random()*w),
y: Math.floor(Math.random()*h)
},
style: this.sprites[ Math.floor(Math.random()*4) ],
delta: {
x: Math.floor(Math.random() * 1000) - 500,
y: Math.floor(Math.random() * 1000) - 500
},
size: parseFloat((Math.random()*2).toFixed(2)),
color: color
};

}

return holder;

},

"draw" : function( time, fade ) {

var ctx = this.context;

ctx.clearRect( 0, 0, this.canvas.width, this.canvas.height );

for( var i = 0; i < this.options.count; i++ ) {

var derpicle = this.particles[i];
var modulus = Math.floor(Math.random()*7);

if( Math.floor(time) % modulus === 0 ) {
derpicle.style = this.sprites[ Math.floor(Math.random()*4) ];
}

ctx.save();
ctx.globalAlpha = derpicle.opacity;
ctx.drawImage(this.sprite, derpicle.style, 0, 7, 7, derpicle.position.x, derpicle.position.y, 7, 7);

if( this.options.color ) {

ctx.globalCompositeOperation = "source-atop";
ctx.globalAlpha = 0.5;
ctx.fillStyle = derpicle.color;
ctx.fillRect(derpicle.position.x, derpicle.position.y, 7, 7);

}

ctx.restore();

}


},

"update" : function() {

var _this = this;

this.anim = window.requestAnimationFrame( function(time) {

for( var i = 0; i < _this.options.count; i++ ) {

var u = _this.particles[i];

var randX = ( Math.random() > Math.random()*2 );
var randY = ( Math.random() > Math.random()*3 );

if( randX ) {
u.position.x += ((u.delta.x * _this.options.speed) / 1500);
}

if( !randY ) {
u.position.y -= ((u.delta.y * _this.options.speed) / 800);
}

if( u.position.x > _this.canvas.width ) {
u.position.x = -7;
} else if ( u.position.x < -7 ) {
u.position.x = _this.canvas.width;
}

if( u.position.y > _this.canvas.height ) {
u.position.y = -7;
u.position.x = Math.floor(Math.random()*_this.canvas.width);
} else if ( u.position.y < -7 ) {
u.position.y = _this.canvas.height;
u.position.x = Math.floor(Math.random()*_this.canvas.width);
}

if( _this.fade ) {
u.opacity -= 0.02;
} else {
u.opacity -= 0.005;
}

if( u.opacity <= 0 ) {
u.opacity = ( _this.fade ) ? 0 : 1;
}

}

_this.draw( time );

if( _this.fade ) {
_this.fadeCount -= 1;
if( _this.fadeCount < 0 ) {
window.cancelAnimationFrame( _this.anim );
} else {
_this.update();
}
} else {
_this.update();
}

});

},

"cancel" : function() {

this.fadeCount = 100;

},

"over" : function() {

window.cancelAnimationFrame( this.anim );

for( var i = 0; i < this.options.count; i++ ) {
this.particles[i].opacity = Math.random();
}

this.fade = false;
this.update();

},

"out" : function() {

this.fade = true;
this.cancel();

},



"datauri" : ""

};





// $('img.photo',this).imagesLoaded(myFunction)
// execute a callback when all images have loaded.
// needed because .load() doesn't work on cached images

// mit license. paul irish. 2010.
// webkit fix from Oren Solomianik. thx!

// callback function is passed the last image to load
// as an argument, and the collection as `this`


$.fn.imagesLoaded = function(callback){
var elems = this.filter('img'),
len = elems.length,
blank = "";

elems.bind('load.imgloaded',function(){
if (--len <= 0 && this.src !== blank){
elems.unbind('load.imgloaded');
callback.call(elems,this);
}
}).each(function(){
// cached images don't fire load sometimes, so we reset src.
if (this.complete || this.complete === undefined){
var src = this.src;
// webkit hack fromhttps://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
// data uri bypasses webkit log warning (thx doug jones)
this.src = blank;
this.src = src;
}
});

return this;
};



</script>