連続的にJS包装類を転がして、基本的にすべての転がり効果を実現できます。強すぎます。


//*MSClass (クラス Of Markee Scroll共通非連続スクロールJSパッケージ類) Ver. 1.6*\  制作時間:2006-08-29 (Ver. 0.5)  发布时间:2006-08-31 (Ver. 0.8)  更新日時:2007-01-31 (Ver. 1.6)  説明を更新: + 機能を追加 * 修正する      1.6.070131          + マウス制御の一時停止または継続を禁止します。 (9番目のパラメータを−1または動的な割当値に設定し、SrollSetpを−1に設定します。          + スクロールできるかどうかを判断します。 (コンテンツ範囲が表示領域より小さい場合は、スクロールは自動的にキャンセルされます。          + スキップ初期化エラー (他のスクロールの停止を避ける)          + 標準値 (容器IDを必ず選択する以外に、他のパラメータは状況に応じて選択できます。)          + パラメータダイナミック割り当て (方向は英語でtop_bottom_ft_rightを表して、より直感的で便利です。          * テキストのスクロールが不正です。 (今回の更新の主な目的はこのBugを解決します。テストに参加してくれてありがとうございます。)      1.4.061211          + マウスのスクロール方向を変更します。 (マウスストップ制御で左右にスクロール)          * ドキュメントのダウンロードが遅すぎて、取得した高さ/幅が不正です。          * ブラウザ対応問題 (IE、FF、Opera、NS、MYIE)      1.2.060922          + 指定範囲間欠スクロール          * プログラム調整          * 連続間欠スクロール停止のエラー      1.0.060901          + 下、右にスクロール          + 開始待ち時間          + 連続スクロール          * 時間の単位を調整する          * スクロール誤差          * ランダム・サイクル          * 性能を強化する          * プログラム最適化      0.8.060829            画面を上下にして、左にスクロールします。  プレゼンテーションのアドレス:http://www.popub.net/script/MSClass.html  ダウンロード先:http://www.popub.net/script/MSClass.js  アプリケーション説明:ページには<スクリプトが含まれています。 type=「text/javascript」 src=「MSClass.js」      作成例:          //パラメータ直接付与法          new マルク(「マルク」)          new マルク(「マルク」「top」)          ......          new マルク(「マルク」0,1,760,52)          new Markee(「markee」、「top」、1,760,52,50,5000)          ......          new マルク(「マルク」、0,1,760,104,50,5000,3000,52)          new Marquee(「marquee」、null、null、760、104、null、5000、null、-1)          //パラメータ動態赋値法          var マルク1 = new マルク(「マルク」)    *このパラメータは必須です          マルクショー1.ディレクション = "トップ";    または    マルクショー1.ディレクション = 0;          マルク1.Step = 1;          マルク1.Width = 760;          マルク1.Height = 52;          マルク1.Timer = 50;          markee 1.DelayTime = 5000;          markee 1.WaitTime = 3000;          markee 1.ScrrollStep = 52;          markee 1.Start()      パラメータの説明:          ID        "markee    コンテナID        (必ず選ぶ          ディレクション    (0)        スクロール方向    (オプションで、デフォルトは0を上にスクロールします) 設定可能な値は、0,1,2,3,top,"bottom","left","Right"があります。 (0を上に 1下へ 2左に 3右)          Step        (1)        転がる歩幅    (オプションで、デフォルトは2です。値が大きいほど、スクロールが速くなります。)          Width        (760)        コンテナの可視幅    (オプションで、標準値は容器の初期設定の幅です。          ヘight        (52)        コンテナの可視高さ    (オプションで、標準値は容器の初期設定の高さです。          Timer        (50)        タイマー        (オプションとして、デフォルトの値は30で、数値が小さいほど、スクロールの速度が速くなります。1000=1秒は20以下ではないことをお勧めします。          DelayTime    (5000)        間欠遅延時間(オプションで、デフォルトは0で停止せず、1000=1秒)          WaitTime    (3000)        開始時の待ち時間(オプション、デフォルトまたは0は待ち時間なし、1000=1秒)          SrollStep    (52)        間欠スクロール間隔    (オプションとして、デフォルトではスクリーン幅/高さを反転させます。この値と遅延は0であればマウスのストップコントロール、-1マウスのコントロールを禁止します。  使用アドバイス:          1、容器の表示領域の幅と高さを直接与えることを提案します。 id=「マルク」 style="width:760 px;height:52 px;"……)          2、容器にスタイルoverflowを追加することを提案します。 = atot,如〔div〕 id=「マルク」 style="width:760 px;height:52 px;overflow:atot;"……)          3、より正確にスクロールエリアの幅と高さを取得するために、各スクロール単位をできるだけ正確な幅と高さに直接付与してください。          4、TABLEマークの横スクロールに対して、TABLEにスタイルdisplayを追加する必要があります。 = inline、例えば id=「マルク」 style="width:760 px;height:52 px;overflow:atot;"<><テーブル style=「display:inline」…          5、スクリーンをひっくり返したり、間欠的に転がしたりする場合、各スクロール単位間の間隔に注意しながら、コンテナの視認高さと視認幅を正確に設定する必要があり、各スクロール単位間の間隔は行間隔またはセルの幅を設定することによって調整できます。          6、LIが自動的に改行する問題に対して、しばらくはより良い解決方法がないので、それを表(TABLE)の形式に転換して、同等の効果を達成することを提案します。          7、横にスクロールするテキスト段落に対して、一番端がスペースである場合 "最後にスペースを入れてください。 "に変換します          8、マウスのローリング思想はFlashに由来しているので、一定の限界がある(容器内では写真
またはリンクされた画像
の形式だけを使用して、自動的に改行することを禁止する必要がある)  感謝します      周B zhoujun啝yuchengtech.com (テキストスクロールジャンプのbug) 2007/01/31      このプログラムの発表以来、多くの友達からメールをもらいました。たくさんの意見と提案を出しました。ありがとうございます。  \***プログラム作成/著作権所有:崔永祥(333) E-Mail:[email protected] URL:http://www.popub.net***/ 

<!--
function Marquee()
{
    this.ID = document.getElementById(arguments[0]);
    if(!this.ID)
    {
        alert(" \"" + arguments[0] + "\" \r
ID !");
        this.ID = -1;
        return;
    }
    this.Direction = this.Width = this.Height = this.DelayTime = this.WaitTime = this.Correct = this.CTL = this.StartID = this.Stop = this.MouseOver = 0;
    this.Step = 1;
    this.Timer = 30;
    this.DirectionArray = {"top":0 , "bottom":1 , "left":2 , "right":3};
    if(typeof arguments[1] == "number")this.Direction = arguments[1];
    if(typeof arguments[2] == "number")this.Step = arguments[2];
    if(typeof arguments[3] == "number")this.Width = arguments[3];
    if(typeof arguments[4] == "number")this.Height = arguments[4];
    if(typeof arguments[5] == "number")this.Timer = arguments[5];
    if(typeof arguments[6] == "number")this.DelayTime = arguments[6];
    if(typeof arguments[7] == "number")this.WaitTime = arguments[7];
    if(typeof arguments[8] == "number")this.ScrollStep = arguments[8]
    this.ID.style.overflow = this.ID.style.overflowX = this.ID.style.overflowY = "hidden";
    this.ID.noWrap = true;
    this.IsNotOpera = (navigator.userAgent.toLowerCase().indexOf("opera") == -1);
    if(arguments.length >= 7)this.Start();
}


Marquee.prototype.Start = function()
{
    if(this.ID == -1)return;
    if(this.WaitTime < 800)this.WaitTime = 800;
    if(this.Timer < 20)this.Timer = 20;
    if(this.Width == 0)this.Width = parseInt(this.ID.style.width);
    if(this.Height == 0)this.Height = parseInt(this.ID.style.height);
    if(typeof this.Direction == "string")this.Direction = this.DirectionArray[this.Direction.toString().toLowerCase()];
    this.HalfWidth = Math.round(this.Width / 2);
    this.BakStep = this.Step;
    this.ID.style.width = this.Width;
    this.ID.style.height = this.Height;
    if(typeof this.ScrollStep != "number")this.ScrollStep = this.Direction > 1 ? this.Width : this.Height;
    //this.ID.innerHTML += this.ID.innerHTML;
    var msobj = this;
    var timer = this.Timer;
    var delaytime = this.DelayTime;
    var waittime = this.WaitTime;
    msobj.StartID = function(){msobj.Scroll()}
    msobj.Continue = function()
                {
                    if(msobj.MouseOver == 1)
                    {
                        setTimeout(msobj.Continue,delaytime);
                    }
                    else
                    {    clearInterval(msobj.TimerID);
                        msobj.CTL = msobj.Stop = 0;
                        msobj.TimerID = setInterval(msobj.StartID,timer);
                    }
                }

    msobj.Pause = function()
            {
                msobj.Stop = 1;
                clearInterval(msobj.TimerID);
                setTimeout(msobj.Continue,delaytime);
            }

    msobj.Begin = function()
        {
            msobj.ClientScroll = msobj.Direction > 1 ? msobj.ID.scrollWidth : msobj.ID.scrollHeight;
            if((msobj.Direction <= 1 && msobj.ClientScroll <msobj.Height) || (msobj.Direction > 1 && msobj.ClientScroll <msobj.Width))return;
            msobj.ID.innerHTML += msobj.ID.innerHTML;
            msobj.TimerID = setInterval(msobj.StartID,timer);
            if(msobj.ScrollStep < 0)return;
            msobj.ID.onmousemove = function(event)
                        {
                            if(msobj.ScrollStep == 0 && msobj.Direction > 1)
                            {
                                var event = event || window.event;
                                if(window.event)
                                {
                                    if(msobj.IsNotOpera)
                                    {
                                        msobj.EventLeft = event.srcElement.id == msobj.ID.id ? event.offsetX - msobj.ID.scrollLeft : event.srcElement.offsetLeft - msobj.ID.scrollLeft + event.offsetX;
                                    }
                                    else
                                    {
                                        msobj.ScrollStep = null;
                                        return;
                                    }
                                }
                                else
                                {
                                    msobj.EventLeft = event.layerX - msobj.ID.scrollLeft;
                                }
                                msobj.Direction = msobj.EventLeft > msobj.HalfWidth ? 3 : 2;
                                msobj.AbsCenter = Math.abs(msobj.HalfWidth - msobj.EventLeft);
                                msobj.Step = Math.round(msobj.AbsCenter * (msobj.BakStep*2) / msobj.HalfWidth);
                            }
                        }
            msobj.ID.onmouseover = function()
                        {
                            if(msobj.ScrollStep == 0)return;
                            msobj.MouseOver = 1;
                            clearInterval(msobj.TimerID);
                        }
            msobj.ID.onmouseout = function()
                        {
                            if(msobj.ScrollStep == 0)
                            {
                                if(msobj.Step == 0)msobj.Step = 1;
                                return;
                            }
                            msobj.MouseOver = 0;
                            if(msobj.Stop == 0)
                            {
                                clearInterval(msobj.TimerID);
                                msobj.TimerID = setInterval(msobj.StartID,timer);
                            }
                        }
        }
    setTimeout(msobj.Begin,waittime);
}

Marquee.prototype.Scroll = function()
{
    switch(this.Direction)
    {
        case 0:
            this.CTL += this.Step;
            if(this.CTL >= this.ScrollStep && this.DelayTime > 0)
            {
                this.ID.scrollTop += this.ScrollStep + this.Step - this.CTL;
                this.Pause();
                return;
            }
            else
            {
                if(this.ID.scrollTop >= this.ClientScroll)
                {
                    this.ID.scrollTop -= this.ClientScroll;
                }
                this.ID.scrollTop += this.Step;
            }
        break;

        case 1:
            this.CTL += this.Step;
            if(this.CTL >= this.ScrollStep && this.DelayTime > 0)
            {
                this.ID.scrollTop -= this.ScrollStep + this.Step - this.CTL;
                this.Pause();
                return;
            }
            else
            {
                if(this.ID.scrollTop <= 0)
                {
                    this.ID.scrollTop += this.ClientScroll;
                }
                this.ID.scrollTop -= this.Step;
            }
        break;

        case 2:
            this.CTL += this.Step;
            if(this.CTL >= this.ScrollStep && this.DelayTime > 0)
            {
                this.ID.scrollLeft += this.ScrollStep + this.Step - this.CTL;
                this.Pause();
                return;
            }
            else
            {
                if(this.ID.scrollLeft >= this.ClientScroll)
                {
                    this.ID.scrollLeft -= this.ClientScroll;
                }
                this.ID.scrollLeft += this.Step;
            }
        break;

        case 3:
            this.CTL += this.Step;
            if(this.CTL >= this.ScrollStep && this.DelayTime > 0)
            {
                this.ID.scrollLeft -= this.ScrollStep + this.Step - this.CTL;
                this.Pause();
                return;
            }
            else
            {
                if(this.ID.scrollLeft <= 0)
                {
                    this.ID.scrollLeft += this.ClientScroll;
                }
                this.ID.scrollLeft -= this.Step;
            }
        break;
    }
}
//-->
オンラインデモンストレーション