Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Движущийся текст. Как изменить направление? (https://javascript.ru/forum/dom-window/53490-dvizhushhijjsya-tekst-kak-izmenit-napravlenie.html)

Владимир777 05.02.2015 21:31

Движущийся текст. Как изменить направление?
 
Есть такой скрипт: http://area7.ru/scroll/scroll.htm
Блоки текста в нём движутся снизу вверх.

Как сделать, чтобы они двигались сверху вниз?

var Ticker = new Class({
	setOptions: function(options) {
		this.options = Object.extend({
			speed: 1500,
			delay: 5000,
			direction: 'vertical',
			onComplete: Class.empty,
			onStart: Class.empty
		}, options || {});
	},
	initialize: function(el,options){
		this.setOptions(options);
		this.el = $(el);
		this.items = this.el.getElements('li');
		var w = 0;
		var h = 0;
		if(this.options.direction.toLowerCase()=='horizontal') {
			h = this.el.getSize().size.y;
				this.items.each(function(li,index) {
				w += li.getSize().size.x;
			});
	} else {
			w = this.el.getSize().size.x;
			this.items.each(function(li,index) {
				h += li.getSize().size.y;
			});
		}
		this.el.setStyles({
			position: 'absolute',
			top: 0,
			left: 0,
			width: w,
				height: h
		});
		this.fx = new Fx.Styles(this.el,{duration:this.options.speed,onComplete:function() {
			var i = (this.current==0)?this.items.length:this.current;
			this.items[i-1].injectInside(this.el);
			this.el.setStyles({
				left:0,
				top:0
			});
		}.bind(this)});
		this.current = 0;
		this.next();
		},
	
	pause: function() {
	    $clear(mytimer);
	    mytimer = null;
	},
	resume: function() {
	    if (mytimer == null) {
	    this.next();
	    }
	},
	next: function() {
		this.current++;
		if (this.current >= this.items.length) this.current = 0;
		var pos = this.items[this.current];
		this.fx.start({
			top: -pos.offsetTop,
			left: -pos.offsetLeft
		});
		mytimer = this.next.bind(this).delay(this.options.delay+this.options.speed);
	}
});

var mytimer = null;

window.addEvent('domready', function() {
   var hor = new Ticker('TickerVertical', {
      speed : 500, delay : 5000, direction : 'vertical'});
    $('stop_scroll').addEvent('click', function() {
		$('play_scroll_cont').style.display='block';
		$('stop_scroll_cont').style.display='none';
		hor.pause();
	});
    $('play_scroll').addEvent('click', function() {
		$('stop_scroll_cont').style.display='block';
		$('play_scroll_cont').style.display='none';
		hor.resume();
	});
});

рони 06.02.2015 04:29

Владимир777,
скрипт очень старый!!!
http://learn.javascript.ru/play/ywauuc

Владимир777 06.02.2015 09:52

Это не совсем то.
Если блоки фиксированной высоты, то всё работает нормально. Но если в них разное количество текста, то скрипт отображает их неправильно: http://area7.ru/scroll/scroll1.htm

Как это исправить?

рони 06.02.2015 10:49

Цитата:

Сообщение от Владимир777
Как это исправить?

поискать нормальный скроллер в этом используются функции устаревшей версии mootools - за это время сама библиотека переписывалась не раз (убирались ошибки модернизация) плюс если вы собираитесь использовать другие библиотеки вам придётся разбираться в конфликтах между ними (например jquery)

рони 06.02.2015 10:57

Цитата:

Сообщение от Владимир777
если в них разное количество текста

вариант под блоки разной высотыhttp://learn.javascript.ru/play/Q0MLbb

Владимир777 06.02.2015 11:45

Спасибо!


Часовой пояс GMT +3, время: 10:02.