자바스크립트를 이용한 슬라이드 형식 갤러리

· 18년 전 · 3926

자바스크립트를 이용한 슬라이드 형식 갤러리

하단의 태그 중 이미지만 변경하시면 됩니다.



< 예제 >

test.jpg







-----------------------------      소스 시작    ---------------------------------



<html>
<head>
<title>http://www.uplusweb.kr</title>

<style type="text/css">
    html {
        overflow: hidden;
    }
    body {
        margin: 0px;
        padding: 0px;
        background: #000;
        position: absolute;
        width: 100%;
        height: 100%;
    }
    #diapo {
        position: absolute;
        left: 0%;
        top: 10%;
        width: 100%;
        height: 80%;
        background: #000;
        overflow: hidden;
    }
    #slider {
        position: absolute;
        width: 100%;
        height: 80%;
    }
    #slider img {
        border: none;
        position:absolute;
        visibility: hidden;
        filter: alpha(opacity=40);
        opacity: 0.4;
    }
    #button {
        position: absolute;
        overflow: hidden;
    }
    #legend {
        position: absolute;
        font-family: arial, helvetica, verdana, sans-serif;
        background: #111;
    }
    #button span {
        position:absolute;
        height: 100%;
    }
    #button span:hover {
        background:#FFF;
    }
    .loaded {
        background: #666;
        cursor: pointer;
    }
    .selected {
        background: #FFF;
    }
    #title {
        float: left;
        margin-left: 0.5em;
        color: #fff;
    }
    #txt {
        float: left;
        margin: 0.5em;
        margin-left: 2em;
        color: #bbb;
    }
    #credit {
        position: absolute;
        color: #888;
        font-family: arial;
        font-size: 0.6em;
        width:99%;
        text-align: right;
        bottom: 2px;
    }
</style>

<script type="text/javascript">

id = function(o){return document.getElementById(o);}

position = function(o, css){for(var i in css)o.style[i]=Math.round(css[i])+'px';}

setOpacity = function(o,alpha){
    if(o.filters)o.filters.alpha.opacity = alpha*100;
    else o.style.opacity = alpha;
}

diapo = {
    N:0,
    W:0,
    H:0,
    image_ratio:4/3,
    ims:0,
    imx:[],
    tit:[],
    txt:[],
    thu:0,
    pos:0,
    xc:0,
    xd:0,
    xm:0,
    dt:0,
    xs:0,
    move:false,

    slide:function(){
        with(this){
            // ===== scrolling loop =====
            xm += xs;
            xc += (dt*xm*.01);
            id("slider").style.left = Math.round(xc)+"px";
            if (xm == 10) xs = -1;
            if (xm) setTimeout("diapo.slide();", 16);
            else {
                // ===== enlighten pic =====
                for(var i=.5;i<=1;i+=.1)setTimeout("setOpacity(diapo.ims[diapo.pos], "+i+")", 160*i);
                setTimeout("diapo.move=false", 160);
            }
        }
    },

    cxd:function(p){
        with(this){
            // ===== calculates slider position =====
            if(W/H>image_ratio){
                wi = Math.round(H*(ims[p].width/ims[p].height));
                xd = -imx[p]+((W-wi)/2);
            } else xd = -imx[p];
            // ===== display text =====
            thu[p].className = "selected";
            id("title").innerHTML = tit[p];
            id("txt").innerHTML = txt[p];
        }
    },

    scroll:function(p){
        with(this){
            if(move){
                // ===== already scrolling: queue event =====
                setTimeout("diapo.scroll("+p+");", 128);
            } else {
                if(thu[p].className == "loaded"){
                    // ===== start scrolling =====
                    cxd(p);
                    setOpacity(ims[pos], .4);
                    thu[pos].className = "loaded";
                    pos = p;
                    dt = xd-xc;
                    xm = 0;
                    xs = 1;
                    move = true;
                    slide();
                }
            }
        }
    },

    pos_button:function(x,y,w){
        with(this){
            // ===== button bar & text positioning =====
            position(id("button"), {'left':x,'top':y+3,'width':w,'height':H/20});
            position(id("legend"), {'left':x,'top':y+6+H/20,'width':w,'height':H});
            position(id("title"), {'fontSize':Math.max(16,H/16)});
            position(id("txt"), {'fontSize':Math.max(8,H/32)});
            thu = id("button").getElementsByTagName("span");
            for(var i=0;i<N;i++){
                var wi = Math.round(w/N)-3;
                position(thu[i], {'left':2+i*(wi+3),'width':wi});
                if(ims[i].complete)thu[i].className = (i==pos)?"selected":"loaded";
            }
        }
    },

    resize:function(){
        with(diapo){
            // ===== resize layout =====
            W=id("slider").offsetWidth;
            H=id("slider").offsetHeight;
            var w=0;
            var h=0;
            var x=0;
            for(var i=0;i<N;i++){
                if(ims[i].complete){
                    w=ims[i].width;
                    h=ims[i].height;
                    ims[i].style.visibility="visible";
                    setOpacity(ims[i], (i==pos)?1:.4);
                    if(W/H>image_ratio){
                        // ===== horizontal centering =====
                        wi = Math.round(H*(w/h));
                        position(ims[i], {'left':x,'top':0,'width':wi,'height':H});
                        imx[i] = x;
                        x += wi+3;
                        if(i==0) pos_button((W-wi)/2,H,wi);
                    } else {
                        // ===== vertical centering =====
                        hi = Math.round(W/(w/h));
                        position(ims[i], {'left':x,'top':(H-hi)/2,'width':W,'height':hi});
                        imx[i] = x;
                        x += W+3;
                        if(i==0) pos_button(0,hi+(H-hi)/2,W);
                    }
                }
                if(xs==0)xc=xd;
            }
            // ===== reajust scroll position =====
            if(!move){
                cxd(pos);
                position(id("slider"), {'left':xd});
            }
        }
    },

    images_load:function(){
        with(this){
            // ===== loop until all images are loaded =====
            var M=0;
            for(var i=0;i<N;i++) if(ims[i].complete) M++;
            if(!move && ims[0].complete) resize();
            if(M<N || move) setTimeout("diapo.images_load();", 128);
        }
    },

    init:function(){
        with(this){
            // ===== images source =====
            ims = id("slider").getElementsByTagName("img");
            N = ims.length;
            // ===== create buttons =====
            for(var i=0;i<N;i++) {
                o = document.createElement("span");
                tit[i] = ims[i].title;
                txt[i] = ims[i].alt;
                ims[i].title = "";
                ims[i].alt = "";
                o.onmousedown = new Function("diapo.scroll("+i+");");
                id("button").appendChild(o);
            }
            images_load();
        }
    }
}

</script>
</head>

<body>

<div id="diapo">
    <div id="slider">
        <!--이곳에 갤러리 이미지를 포함하세요-->
        <img src=http://cbingoimage.naver.com/data/bingo_92/imgbingo_92/kinisky/29847/kinisky_37.jpg title="이미지 1">
        <img src=http://cbingoimage.naver.com/data3/bingo_82/imgbingo_29/mony87/29907/mony87_87.jpg title="설명 2">
        <img src=http://cbingoimage.naver.com/data3/bingo_5/imgbingo_45/tok888/24617/tok888_118.jpg title="설명 3">
        <img src=http://cbingoimage.naver.com/data/bingo_92/imgbingo_92/kinisky/29847/kinisky_37.jpg title="설명 4">
        <img src=http://cbingoimage.naver.com/data3/bingo_98/imgbingo_84/windyemail/30864/windyemail_13.jpg title="설명 5">
        <img src=http://cbingoimage.naver.com/data3/bingo_5/imgbingo_99/hanb5/29359/hanb5_12.jpg title="설명 6">
        <img src=http://cbingoimage.naver.com/data3/bingo_56/imgbingo_91/seulkee0926/37699/seulkee0926_27.jpg title="설명 7">
        <img src=http://cbingoimage.naver.com/data3/bingo_40/imgbingo_79/sashin60/37578/sashin60_4.jpg title="설명 8">
        <img src=http://cafe.naver.com/ViewImage.nhn?img=http://cafefiles.naver.net/data24/2006/5/30/192/%BC%DB%C7%FD%B1%B36.jpg title="설명 9">
        <!--이곳에 갤러리 이미지를 포함하세요-->
    </div>
    <div id="button"></div>
    <div id="legend">
        <span id="title"></span>
        <span id="txt"></span>
    </div>
</div>

<script type="text/javascript">
// ===== start script while loading images =====
function dom_onload() {
    if(id("slider")) diapo.init(); else setTimeout("dom_onload();", 128);
}
dom_onload();
// ===== window resize event =====
onresize = diapo.resize;
// ================================================
</script>

</body>
</html>



-----------------------------   소스 끝  -------------------------------

[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]

첨부파일

|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
18년 전 조회 1,903
18년 전 조회 3,685
18년 전 조회 2,374
18년 전 조회 3,816
18년 전 조회 5,260
18년 전 조회 3,912
18년 전 조회 2,750
18년 전 조회 3,030
18년 전 조회 2,533
18년 전 조회 2,875
18년 전 조회 1,983
18년 전 조회 3,520
18년 전 조회 2,214
18년 전 조회 2,346
18년 전 조회 2,174
18년 전 조회 3,135
18년 전 조회 2,080
18년 전 조회 2,749
18년 전 조회 3,936
18년 전 조회 4,649
18년 전 조회 2,456
18년 전 조회 2,935
18년 전 조회 4,695
18년 전 조회 2,761
18년 전 조회 1,955
18년 전 조회 3,394
18년 전 조회 3,203
18년 전 조회 3,930
18년 전 조회 2,259
18년 전 조회 2,419
18년 전 조회 1만
18년 전 조회 3,598
18년 전 조회 3,388
18년 전 조회 3,252
18년 전 조회 2,892
18년 전 조회 4,233
18년 전 조회 5,563
18년 전 조회 3,821
18년 전 조회 3,269
18년 전 조회 3,693
18년 전 조회 2,337
18년 전 조회 2,767
18년 전 조회 4,002
18년 전 조회 2,929
18년 전 조회 4,446
18년 전 조회 2,158
18년 전 조회 2,598
18년 전 조회 2,497
18년 전 조회 3,859
18년 전 조회 3,927
18년 전 조회 2,654
18년 전 조회 2,739
18년 전 조회 3,050
18년 전 조회 2,878
18년 전 조회 2,095
18년 전 조회 2,262
18년 전 조회 4,915
18년 전 조회 4,274
18년 전 조회 2,888
18년 전 조회 2,443
18년 전 조회 2,959
18년 전 조회 2,424
18년 전 조회 3,595
18년 전 조회 2,257
18년 전 조회 2,042
18년 전 조회 1,907
18년 전 조회 1,725
18년 전 조회 3,316
18년 전 조회 4,642
18년 전 조회 4,919
18년 전 조회 2,211
18년 전 조회 3,669
18년 전 조회 3,379
18년 전 조회 4,667
18년 전 조회 3,327
18년 전 조회 4,308
18년 전 조회 3,989
18년 전 조회 3,691
18년 전 조회 3,094
18년 전 조회 2,988
18년 전 조회 3,569
18년 전 조회 2,229
18년 전 조회 2,170
18년 전 조회 5,571
18년 전 조회 2,752
18년 전 조회 2,502
18년 전 조회 2,798
18년 전 조회 2,150
18년 전 조회 3,135
18년 전 조회 1만
18년 전 조회 1,982
18년 전 조회 2,905
18년 전 조회 2,946
18년 전 조회 2,184
18년 전 조회 3,043
18년 전 조회 4,048
18년 전 조회 2,996
18년 전 조회 2,376
18년 전 조회 6,108
18년 전 조회 3,730