Помогите разобраться c javascript`ом. Скрипт ротатор нескольких изображений

K
На сайте с 04.12.2012
Offline
2
1549

    
var previmg=5;
var timeout_id;

function endm1(a)
{
if (a.src.indexOf("cover")>0)
{
str = a.src;
re = /cover\/(.*).jpg/i;
found = str.match(re);
b=(found[1].length)-1;
sti = found[1].substr(0,b);
clearTimeout(timeout_id);
a.src="/uploads/posts/cover/"+sti+0+".jpg";
}
}

function startm1(a)

{
if (a.src.indexOf("cover")>0)
{
str = a.src;
re = /cover\/(.*)0.jpg/i;
found = str.match(re);
base =found[1];
changepic1(base,1,previmg,a.id);
}
}

function changepic1(base,i,previmg,code)
{
if (i>=previmg) { i=0;}
document.getElementById(code).src="/uploads/posts/cover/"+base+i+".jpg";
timeout_id=setTimeout("changepic1('"+base+"',"+(i+1)+",'"+previmg+"','"+code+"')",500);

}

это ротатор изображений, объясните раскомментируйте пожалуйста каждую строчку сам не как не допру =(

Как его переделать под такую структуру

  
<html>
<head>
<title>Ротатор Изображений</title>
<style>
body{
width: 500px;
margin: 0 auto;
text-align: center;
}
img{margin: 200px 0;}
</style>
</head>
<body>
<a title="" href="/123">
<img id="1 id поста" onmouseout="endm1(this);" onmouseover="startm1(this);" src="post/image/1/1_0 от нуля до 10.jpg" width="160" height="120">
</a>
<a title="" href="/321">
<img id="2" onmouseout="endm1(this);" onmouseover="startm1(this);" src="post/image/2/2_0.jpg" width="160" height="120">
</a>
</body>
</html>
K
На сайте с 04.12.2012
Offline
2
#1

ау народ:(:(:(:(:(

H
На сайте с 09.10.2012
Offline
11
#2

Я бы на вашем месте вообще выкинул этот код и просто сформулировал свою задачу)

Код в приведенном примере - ужасен, начиная от неиспользования var в функциях (в итоге все переменные пойдут в глобальную область видимости), заканчивая использованием indexOf без заглушки для старых браузеров.

DiAksID
На сайте с 02.08.2008
Offline
236
#3
kondratt:
... это ротатор изображений, объясните ...

вот "ротатор" изображений: cycle один из лучших...

show must go on !!!...
K
На сайте с 04.12.2012
Offline
2
#4

нет мне нужен именно такой без всяких эффектов обычная смена картинок с настройкой интервала

---------- Добавлено 13.01.2013 в 00:44 ----------

hedint:
Я бы на вашем месте вообще выкинул этот код и просто сформулировал свою задачу)
Код в приведенном примере - ужасен, начиная от неиспользования var в функциях (в итоге все переменные пойдут в глобальную область видимости), заканчивая использованием indexOf без заглушки для старых браузеров.

я не силен в javascript :(

DiAksID
На сайте с 02.08.2008
Offline
236
#5
kondratt:
нет мне нужен именно такой без всяких эффектов обычная смена картинок с настройкой интервала... (

сказано же - один из лучших плагинов 😂 людям надо верить + научиться читать: cycle lite - отдельный вариант "без спец-эффектов" весом 8 Кб

K
На сайте с 04.12.2012
Offline
2
#6

Так ладно а как его прикрутить мне ? он же работает как слайдер а мне нужна что бы при наведении на изображение картинка менялась на следующую....

/*!
* jQuery Cycle Lite Plugin
* http://malsup.com/jquery/cycle/lite/
* Copyright (c) 2008-2012 M. Alsup
* Version: 1.6 (02-MAY-2012)
* Dual licensed under the MIT and GPL licenses:
* http://www.opensource.org/licenses/mit-license.php
* http://www.gnu.org/licenses/gpl.html
* Requires: jQuery v1.3.2 or later
*/
;(function($) {
"use strict";

var ver = 'Lite-1.6';

$.fn.cycle = function(options) {
return this.each(function() {
options = options || {};

if (this.cycleTimeout) clearTimeout(this.cycleTimeout);

this.cycleTimeout = 0;
this.cyclePause = 0;

var $cont = $(this);
var $slides = options.slideExpr ? $(options.slideExpr, this) : $cont.children();
var els = $slides.get();
if (els.length < 2) {
if (window.console)
console.log('terminating; too few slides: ' + els.length);
return; // don't bother
}

// support metadata plugin (v1.0 and v2.0)
var opts = $.extend({}, $.fn.cycle.defaults, options || {}, $.metadata ? $cont.metadata() : $.meta ? $cont.data() : {});
var meta = $.isFunction($cont.data) ? $cont.data(opts.metaAttr) : null;
if (meta)
opts = $.extend(opts, meta);

opts.before = opts.before ? [opts.before] : [];
opts.after = opts.after ? [opts.after] : [];
opts.after.unshift(function(){ opts.busy=0; });

// allow shorthand overrides of width, height and timeout
var cls = this.className;
opts.width = parseInt((cls.match(/w:(\d+)/)||[])[1], 10) || opts.width;
opts.height = parseInt((cls.match(/h:(\d+)/)||[])[1], 10) || opts.height;
opts.timeout = parseInt((cls.match(/t:(\d+)/)||[])[1], 10) || opts.timeout;

if ($cont.css('position') == 'static')
$cont.css('position', 'relative');
if (opts.width)
$cont.width(opts.width);
if (opts.height && opts.height != 'auto')
$cont.height(opts.height);

var first = 0;
$slides.css({position: 'absolute', top:0}).each(function(i) {
$(this).css('z-index', els.length-i);
});

$(els[first]).css('opacity',1).show(); // opacity bit needed to handle reinit case
if ($.browser.msie) els[first].style.removeAttribute('filter');

if (opts.fit && opts.width)
$slides.width(opts.width);
if (opts.fit && opts.height && opts.height != 'auto')
$slides.height(opts.height);
if (opts.pause)
$cont.hover(function(){this.cyclePause=1;}, function(){this.cyclePause=0;});

var txFn = $.fn.cycle.transitions[opts.fx];
if (txFn)
txFn($cont, $slides, opts);

$slides.each(function() {
var $el = $(this);
this.cycleH = (opts.fit && opts.height) ? opts.height : $el.height();
this.cycleW = (opts.fit && opts.width) ? opts.width : $el.width();
});

if (opts.cssFirst)
$($slides[first]).css(opts.cssFirst);

if (opts.timeout) {
// ensure that timeout and speed settings are sane
if (opts.speed.constructor == String)
opts.speed = {slow: 600, fast: 200}[opts.speed] || 400;
if (!opts.sync)
opts.speed = opts.speed / 2;
while((opts.timeout - opts.speed) < 250)
opts.timeout += opts.speed;
}
opts.speedIn = opts.speed;
opts.speedOut = opts.speed;

opts.slideCount = els.length;
opts.currSlide = first;
opts.nextSlide = 1;

// fire artificial events
var e0 = $slides[first];
if (opts.before.length)
opts.before[0].apply(e0, [e0, e0, opts, true]);
if (opts.after.length > 1)
opts.after[1].apply(e0, [e0, e0, opts, true]);

if (opts.click && !opts.next)
opts.next = opts.click;
if (opts.next)
$(opts.next).unbind('click.cycle').bind('click.cycle', function(){return advance(els,opts,opts.rev?-1:1);});
if (opts.prev)
$(opts.prev).unbind('click.cycle').bind('click.cycle', function(){return advance(els,opts,opts.rev?1:-1);});

if (opts.timeout)
this.cycleTimeout = setTimeout(function() {
go(els,opts,0,!opts.rev);
}, opts.timeout + (opts.delay||0));
});
};

function go(els, opts, manual, fwd) {
if (opts.busy)
return;
var p = els[0].parentNode, curr = els[opts.currSlide], next = els[opts.nextSlide];
if (p.cycleTimeout === 0 && !manual)
return;

if (manual || !p.cyclePause) {
if (opts.before.length)
$.each(opts.before, function(i,o) { o.apply(next, [curr, next, opts, fwd]); });
var after = function() {
if ($.browser.msie)
this.style.removeAttribute('filter');
$.each(opts.after, function(i,o) { o.apply(next, [curr, next, opts, fwd]); });
queueNext(opts);
};

if (opts.nextSlide != opts.currSlide) {
opts.busy = 1;
$.fn.cycle.custom(curr, next, opts, after);
}
var roll = (opts.nextSlide + 1) == els.length;
opts.nextSlide = roll ? 0 : opts.nextSlide+1;
opts.currSlide = roll ? els.length-1 : opts.nextSlide-1;
} else {
queueNext(opts);
}

function queueNext(opts) {
if (opts.timeout)
p.cycleTimeout = setTimeout(function() { go(els,opts,0,!opts.rev); }, opts.timeout);
}
}

// advance slide forward or back
function advance(els, opts, val) {
var p = els[0].parentNode, timeout = p.cycleTimeout;
if (timeout) {
clearTimeout(timeout);
p.cycleTimeout = 0;
}
opts.nextSlide = opts.currSlide + val;
if (opts.nextSlide < 0) {
opts.nextSlide = els.length - 1;
}
else if (opts.nextSlide >= els.length) {
opts.nextSlide = 0;
}
go(els, opts, 1, val>=0);
return false;
}

$.fn.cycle.custom = function(curr, next, opts, cb) {
var $l = $(curr), $n = $(next);
$n.css(opts.cssBefore);
var fn = function() {$n.animate(opts.animIn, opts.speedIn, opts.easeIn, cb);};
$l.animate(opts.animOut, opts.speedOut, opts.easeOut, function() {
$l.css(opts.cssAfter);
if (!opts.sync)
fn();
});
if (opts.sync)
fn();
};

$.fn.cycle.transitions = {
fade: function($cont, $slides, opts) {
$slides.not(':eq(0)').hide();
opts.cssBefore = { opacity: 0, display: 'block' };
opts.cssAfter = { display: 'none' };
opts.animOut = { opacity: 0 };
opts.animIn = { opacity: 1 };
},
fadeout: function($cont, $slides, opts) {
opts.before.push(function(curr,next,opts,fwd) {
$(curr).css('zIndex',opts.slideCount + (fwd === true ? 1 : 0));
$(next).css('zIndex',opts.slideCount + (fwd === true ? 0 : 1));
});
$slides.not(':eq(0)').hide();
opts.cssBefore = { opacity: 1, display: 'block', zIndex: 1 };
opts.cssAfter = { display: 'none', zIndex: 0 };
opts.animOut = { opacity: 0 };
opts.animIn = { opacity: 1 };
}
};

$.fn.cycle.ver = function() { return ver; };

// @see: http://malsup.com/jquery/cycle/lite/
$.fn.cycle.defaults = {
animIn: {},
animOut: {},
fx: 'fade',
after: null,
before: null,
cssBefore: {},
cssAfter: {},
delay: 0,
fit: 0,
height: 'auto',
metaAttr: 'cycle',
next: null,
pause: false,
prev: null,
speed: 1000,
slideExpr: null,
sync: true,
timeout: 4000
};

})(jQuery);
DiAksID
На сайте с 02.08.2008
Offline
236
#7
kondratt:
Так ладно а как его прикрутить мне ? он же работает как слайдер а мне нужна что бы при наведении на изображение картинка менялась на следующую ...

просили "ротатор" изображений - получили ссылку. попросили ли бы "карусель" изображений - получили бы другую ссылку. хоть идеологически похожие, но всё же разные по назначению и использованию скрипты. в гугол...

ЗЫ: если

kondratt:

я не силен в javascript :(

не стоит упорно лезть в код плагина, толку не будет, ешьте то что дают - пытайтесь настроить под себя. ну или освойте JS...

K
На сайте с 04.12.2012
Offline
2
#8

так то что я хочу называется карусель?)

DiAksID
На сайте с 02.08.2008
Offline
236
#9
kondratt:
так то что я хочу называется карусель?)

хоть бульдозером назовите, просто хотелку сформулируйте более подробно - народ поймёт и простит ;) ... в гугел !!! их там мильён, берёте попопулярнее + с нужным функционалом + читаете API + вставляете и настраиваете под себя...

K
На сайте с 04.12.2012
Offline
2
#10

не ну я же писал что хочу такое чтоб навел пользователь курсор на изображение и изображения начали меняться. Гугл бесполезен когда не знаешь что ищешь :D или как оно называется

Авторизуйтесь или зарегистрируйтесь, чтобы оставить комментарий