0

ホームページのスライド ショーに JQuery サイクルを使用しています。主なアイデアは、特定のグループの画像が一緒に表示されることです。そのため、間隔を同期して、次のパターン 1-2-3 -> 1-4-3 -> 5-4-6 -> 1- を作成したいと考えています。 4-3 -> 1-2-3 ->... (画像 1,2,3,4,5,6 があると想像してください。たとえば、1-2-3 は、画像 1 と 2 と 3 が一緒に表示されることを示しています、および -> 遷移を示します)。これが私のコードです:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<style type="text/css">
pre { display:none }
#main h2 { text-align: center }
#right { cursor: pointer }
</style>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
<script type="text/javascript" src="http://malsup.github.com/jquery.cycle.all.js"></script>
<script type="text/javascript">

$(function() {
// run the code in the markup!
$('#demos pre code').each(function() {
    eval($(this).text());
});

});
</script>
</head>
<body>

<div id="main">

<div id="demos">
 <div id="slider">

    <div id="bxo" class="pics">
        <img id="letter-b" src="01.jpg" width="300" height="330" />
        <img id="veggi1" src="02.jpg" width="300" height="330" />
        <img id="letter-o" src="03.jpg" width="300" height="330" />

    </div>
    <div id="bio" class="pics">
        <img id="letter-b" src="01.jpg" width="300" height="330" />
        <img id="letter-i" src="05.jpg" width="300" height="330" />
        <img id="letter-o" src="03.jpg" width="300" height="330" />
    </div>
    <div id="xix" class="pics">
        <img  id="veggi2" src="04.jpg" width="300" height="330" />
        <img id="letter-i" src="05.jpg" width="300" height="330" />
        <img  id="veggi3" src="06.jpg" width="300" height="330" />
    </div>
    <div id="bio" class="pics">
        <img id="letter-b" src="01.jpg" width="300" height="330" />
        <img id="letter-i" src="05.jpg" width="300" height="330" />
        <img id="letter-o" src="03.jpg" width="300" height="330" />
    </div>



       </div>
       <pre><code class="mix">$('#slider').cycle(
    { 
                    fx:     'fade', 
                    speed:   500, 
                    timeout: 3000, 
                    pause:   1 
                    });
                    </code></pre>
 </body>
 </html>

ここで、いくつかのスライドを短時間で表示する必要があります。したがって、スライドごとに異なる速度を定義する必要があります。次のようなパターンが必要です: 1-2-3 -----> 1-4-3 -> 5-4-6 -----> 1-4-3 -> 1-2-3 -- ---> (高速と低速の 2 つの速度が必要です。長い矢印は遅い遷移を示し、短い矢印は速い遷移を示します)。カスタムトランジションを定義して、速度の2つの値を取得し、各サイクルでそれらを切り替えることを考えていましたが、JQuery Cycleで実装する方法がわかりません...

4

1 に答える 1

0

プラグインを少し変更することでこの問題を解決しました.JQueryサイクルのソースコードでは、各トランジションで実行される関数function go(els, opts, manual, fwd)は奇妙な遷移。このようなもの:

function go(els, opts, manual, fwd) {
    $.cycleno++;
    if($.cycleno%2==0)
        opts.timeout=3000;
    else
        opts.timeout=10;
    ....
}

これで、必要な効果が得られました: スライド 1 -----> スライド 2 -> スライド 3 -----> スライド 4 -> スライド 5 ----->...

于 2012-06-01T10:24:13.993 に答える