0

私はこの優れた例を自分のニーズに適用することができました。

http://code.google.com/p/galleriffic/issues/attachmentText?id=76&aid=-3045121742886940548&name=example-2.html&token=4nlvmgAfVpc5whcXC9UEqHZaSz0%3A1339257750721

少しひねりを加えて:両方のギャラリーが同じスライドショーコンテナに画像を適用するため、「#thumbs0」のサムネイルではなく「#slideshow0」の画像を変更し、「#thumbs1」のサムネイルでは「#slideshow1」の画像を変更します。 「#slideshow」の画像を変更するように両方を設定します。

これは、タブを使用して2つの異なるカテゴリのサムネイルを分離し、1つのスライドショーコンテナ内の画像を変更するためです。

これを行うには、例のように'#slideshow' + iではなく、imageContainerSelを'#slideshow'に設定します。

コードは次のとおりです。

HTML:

<div id="tabs">
<div class="each-gallery">
    <div id="thumbs0" class="navigation">
        <ul>
            <li><a href="#tabs-1">Tab 1</a></li>
            <li><a href="#tabs-2">Tab 2</a></li>
        </ul>

            <div id="tabs-1">
                <ul class="thumbs noscript">
                    <li>
                        <a class="thumb" href="images/1.jpg" title="Title #0">
                        <img src="images/thumbs/1.jpg" alt="Title #0" />
                            Title 1
                        </a>
                        <div class="caption">
                            <div class="image-title">Title 1</div>
                            <div class="image-desc">Description 1</div>
                        </div>
                    </li>
                    <li>
                        <a class="thumb" href="images/2.jpg" title="Title #0">
                            <img src="images/thumbs/2.jpg" alt="Title #0" />
                            Title 2
                        </a>
                        <div class="caption">
                            <div class="image-title">Title 2</div>
                            <div class="image-desc">Description 2</div>
                        </div>
                    </li>

                </ul>
            </div>

        </div>
</div>

            <div id="tabs-2">
                <div class="each-gallery">
                    <div id="thumbs1" class="navigation">

                <ul class="thumbs noscript">
                    <li>
                        <a class="thumb" href="images/3.jpg" title="Title #0">
                        <img src="images/thumbs/3.jpg" alt="Title #0" />
                            Title 3
                        </a>
                        <div class="caption">
                            <div class="image-title">Title 3</div>
                            <div class="image-desc">Description 3</div>
                        </div>
                    </li>
                    <li>
                        <a class="thumb" href="images/4.jpg" title="Title #0">
                            <img src="images/thumbs/4.jpg" alt="Title #0" />
                            Title 4
                        </a>
                        <div class="caption">
                            <div class="image-title">Title 4</div>
                            <div class="image-desc">Description 4</div>
                        </div>
                    </li>

                </ul>
                    </div>
                </div>
            </div>

Javascript:

 <script type="text/javascript">
                    jQuery(document).ready(function($) {
                            // We only want these styles applied when javascript is enabled
                            // We only want these styles applied when javascript is enabled
                            $('div.navigation').css({'width' : '960px', 'float' : 'left'});
                            $('div.content').css('display', 'block');

                            $(".each-gallery").each(function(i){
                                    // Initially set opacity on thumbs and add
                                    // additional styling for hover effect on thumbs
                                    var onMouseOutOpacity = 0.67;
                                    $('#thumbs + i + ul.thumbs li').opacityrollover({
                                            mouseOutOpacity:   onMouseOutOpacity,
                                            mouseOverOpacity:  1.0,
                                            fadeSpeed:         'fast',
                                            exemptionSelector: '.selected'
                                    });

                                    // Initialize Advanced Galleriffic Gallery
                                    var gallery = $('#thumbs'+i).galleriffic({

                                            delay:                     2500,
                                            numThumbs:                 20,
                                            preloadAhead:              0,
                                            enableTopPager:            false,
                                            enableBottomPager:         false,
                                            maxPagesToShow:            7,
                                            imageContainerSel:         '#slideshow',
                                            controlsContainerSel:      '#controls',
                                            captionContainerSel:       '#caption',
                                            loadingContainerSel:       '#loading',
                                            renderSSControls:          true,
                                            renderNavControls:         true,
                                            playLinkText:              'Play Slideshow',
                                            pauseLinkText:             'Pause Slideshow',
                                            prevLinkText:              '&lsaquo; Previous Photo',
                                            nextLinkText:              'Next Photo &rsaquo;',
                                            nextPageLinkText:          'Next &rsaquo;',
                                            prevPageLinkText:          '&lsaquo; Prev',
                                            enableHistory:             false,
                                            autoStart:                 false,
                                            syncTransitions:           true,
                                            defaultTransitionDuration: 900,
                                            onSlideChange:             function(prevIndex, nextIndex) {
                                                    // 'this' refers to the gallery, which is an extension of $('#thumbs')
                                                    this.find('ul.thumbs').children()
                                                            .eq(prevIndex).fadeTo('fast', onMouseOutOpacity).end()
                                                            .eq(nextIndex).fadeTo('fast', 1.0);
                                            },
                                            onPageTransitionOut:       function(callback) {
                                                    this.fadeTo('fast', 0.0, callback);
                                            },
                                            onPageTransitionIn:        function() {
                                                    this.fadeTo('fast', 1.0);
                                            }
                                    });
                            });

                    });
            </script>

問題:

ページの読み込み時に、両方のギャラリーが最初の画像を同時に#slideshowに読み込むため、最初のページの読み込み時に、画像が上下に2回表示されます。別のサムネイルをクリックした後にのみ、2番目の画像が消え、すべてが期待どおりに機能します。

どうすれば修正できますか?

4

2 に答える 2

1

私はなんとか自分で問題を解決することができました。

誰かが興味を持っている場合、ここに解決策があります:

最初のギャラリーの最初の親指に一意の名前を付けました。

<a class="thumb" name="first" href="images/1.jpg" title="Title #0">

そして変更されたjquery.galleriffic.js:

                var buuga = this.data[nextIndex].hash;
            if(buuga !== 'first') {
                            var newSlide = this.$imageContainer
                .append('<span class="image-wrapper current"><a class="advance-link" rel="history" href="#'+this.data[nextIndex].hash+'" title="'+imageData.title+'">&nbsp;</a></span>')
                .find('span.current').css('opacity', '0');
            }

私が変更したのは、名前を格納するために「buuga」変数を追加し、名前が「first」の場合は実行されない「if」条件で画像の新しい非表示スパンを構成する部分をラップしたことです。

于 2012-06-15T13:34:12.413 に答える
0

私の場合、そうすると最初の画像だけが非表示になります。使用するギャラリー/フォルダーの数は可変なので、3つのギャラリーの場合、他の2つの画像が表示されます。

今、私がそれを変更すると:

var buuga = this.data[nextIndex].hash;

に:

var buuga = this.data[imageData.index].hash;

ページの読み込み時に完全に機能します。ただし、最初の画像がサムネイルをクリックしたときに表示される唯一の画像です。結局起こったことは、ギャラリフィックが最初のスパンに3つの画像を追加しようとしたことでした。

私がやったのは、カウント数と合計フォルダー数の2つのグローバルを追加することでした。

firstImageCount = 0;  
totalFolderCount = 3; // this number is generated with php

そして私がjquery.galleriffic.jsに対してやったこと:

// Construct new hidden span for the image
var firstHash = this.data[nextIndex].hash; // I changed buuga to this more descriptive name
if(firstImageCount >= totalFolderCount-1){  
    var newSlide = this.$imageContainer  
       .append('<span class="image-wrapper current"><a class="advance-link" rel="history" href="#'+this.data[nextIndex].hash+'" title="'+imageData.title+'">&nbsp;</a></span>')  
       .find('span.current').css('opacity', '0');  
}  
firstImageCount++;

次に、ロードする画像であるため、シリーズの最後のフォルダーを最初に表示しました。

于 2012-08-22T20:08:17.530 に答える