jQueryとphpの画像rotaterパズル
質問
Jqueryパズル
私のphpスクリプトの名前を返しますランダムjpg画像からフォルダにまとめた。しているのは嬉しいでない名前の変更の画像ですので、私はここからのフォルダとフォルダのrandomizerます。今、私のようなスクリプトこれ- http://mydomain.com/images/rotate.php -には、簡易webページの再読み込み、それ替えます。
がたいと思っていますので仕事jQueryにおきたいと思いますをイメージのスワップに新たな画像間の間隔の数十秒以内なので、フェードして、色んで頂きたいと思います。
編集1/23/10:
この作品の入れ替えるspacer.gif.がある場合がございます。エレガントな解決方法が、この作品だった。ムンク板で、アイデアによりMidnightLightning:
function swapImage(){
var time = new Date();
$('#image').fadeOut(1000)
.attr('src', 'http://mydomain.com/spacer.gif')
.attr('src', 'http://mydomain.com/images/rotate.php?'+time.getTime())
.fadeIn(1000);
}
var imageInterval = setInterval('swapImage()',10*1000);
このrotate.php:
<?php
$folder = '.';
$extList = array();
$extList['gif'] = 'image/gif';
$extList['jpg'] = 'image/jpeg';
$extList['jpeg'] = 'image/jpeg';
$extList['png'] = 'image/png';
$img = null;
if (substr($folder,-1) != '/') {
$folder = $folder.'/';
}
if (isset($_GET['img'])) {
$imageInfo = pathinfo($_GET['img']);
if (
isset( $extList[ strtolower( $imageInfo['extension'] ) ] ) &&
file_exists( $folder.$imageInfo['basename'] )
) {
$img = $folder.$imageInfo['basename'];
}
} else {
$fileList = array();
$handle = opendir($folder);
while ( false !== ( $file = readdir($handle) ) ) {
$file_info = pathinfo($file);
if (
isset( $extList[ strtolower( $file_info['extension'] ) ] )
) {
$fileList[] = $file;
}
}
closedir($handle);
if (count($fileList) > 0) {
$imageNumber = time() % count($fileList);
$img = $folder.$fileList[$imageNumber];
}
}
if ($img!=null) {
$imageInfo = pathinfo($img);
$contentType = 'Content-type: '.$extList[ $imageInfo['extension'] ];
header ($contentType);
readfile($img);
} else {
if ( function_exists('imagecreate') ) {
header ("Content-type: image/png");
$im = @imagecreate (100, 100)
or die ("Cannot initialize new GD image stream");
$background_color = imagecolorallocate ($im, 255, 255, 255);
$text_color = imagecolorallocate ($im, 0,0,0);
imagestring ($im, 2, 5, 5, "IMAGE ERROR", $text_color);
imagepng ($im);
imagedestroy($im);
}
}
?>
解決
下の方に見えるが、そのようなことがあります負荷期間のための新しい画像やアニメーションはちょっと個性豊かなくようになっています。かが有益であると考えられるてるパーツにファイルのパスが返される場合は$_GET値が等しい一は、このような背景の下で、画像が返される場合は$_GET値が設定されていないか等、地下鉄からも近くて便利。そのようにきプリロードの画像がスムーズにアニメと。
とはいえ、このようなことすべきます。
$(document).ready(function(){
function swapImage(){
var time = new Date();
$('#image').fadeOut(1000)
.attr('src', 'http://mydomain.com/images/rotate.php?'+time.getTime())
.fadeIn(1000);
}
var imageInterval = setInterval('swapImage()',10*1000);
});
にすることが可能で、ブラウザだと思っていく新しいイメージです。
Spacer.gif
この黒のスペーサーされています。を包んだ画像は、事業部の本部長は、#000背景色に合わせてスペーサー:
#image-wrap{background-color:#000;}
ことができるとされていることで画像の実際の色を黒にすると、より退色に現在の背景色、黒色も行っております。のjs非常に上記と同様:
function swapImage(){
var time = new Date();
$('#image').fadeOut(1000)
.attr('src', 'http://mydomain.com/spacer.gif')
.attr('src', 'http://mydomain.com/images/rotate.php?'+time.getTime())
.fadeIn(1000);
}
var imageInterval = setInterval('swapImage()',10*1000);
常に時間がろん必要だが、こんにちは、その他の安全-防ブラウザのキャッシュにあたっては、以下の"image".
他のヒント
以降のphpスクリプトのソースの新しい画像されることもありますので、最高のサービスの利用 load()
利用シajax通話するスワップのイメージのソースです。
var img=$('#image');//cache the element
function refreshNotification(){
$.ajax({
url: 'http://mydomain.com/images/rotate.php',
success: function(src){
img.attr({src: src});
}
});
}
setInterval(refreshNotification, 10000);
のようなことが、このPHPスクリプトを返すだけのURLの画像:
$(document).ready(function(){
window.setInterval(switchImage, 10000);
function switchImage() {
var rn = Math.floor(Math.random() * 100000)
$.get('http://mydomain.com/images/rotate.php',
{ n: rn },
receiveNewImage);
}
function receiveNewImage(src) {
$('#image').fadeTo(1000, 0.0, function() { switchAndFadeIn(src); } );
}
function switchAndFadeIn(newSrc) {
$('#image').attr('src', newSrc).fadeTo(1000, 1.0);
}
});
編集:追加のランダムパラメータとします。
編集:PHPはこんな感じですか?
header("Cache-Control: no-cache, must-revalidate");
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Expires data in the past
かを定義する swapImage()
機能以外の $(document).ready()
ブロック?
<script type="text/javascript" scr="path/to/jquery.js"></script>
<script type="text/javascript">
function swapImage(){
var time = new Date();
$('#rotate').fadeOut(1000)
.attr('src', 'rotate.php?'+time.getTime())
.fadeIn(1000);
}
$(document).ready(function(){
var imageInterval = setInterval('swapImage()',5000);
});
</script>
<img src="rotate.php" id="rotate" />
$("#image").each(function({
$(this).fadeOut(function() {
$(this).attr("src", "http://mydomain.com/images/image.jpg");
$(this).load(function() { $(this).fadeIn(); }); // this should be on the bottom....
});
})
チェック機能にJQ各
って更新され、スクリプトという作業ですのを待って画像への負荷ものではないものの源泉---チェックアウト> <img onerror="alert('there was an error') />"
を取得する場合エラーということはソースファイルが存在しない.ちなみを使用しないでください#の場合、イメージについては、これまで複数の画像ができますユニークなidおhtml限を取得しま紛争
武器agiは、dexで下がらないboxerぐ
アライメントが抜けての一歩を占jQueryなキャッシュのAJAXます。あ 'キャッシュ'パラメータ 追加することのできるAJAXの呼び出力で掴む新しいコピー:
$.ajax({
url: 'http://mydomain.com/images/rotate.php',
cache: false,
success: function(src){
img.attr({src: src});
}
});