С Новым годом! Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 2

Некорректно отображается анимация слайдера

01.03.2016, 22:06. Показов 870. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, столкнулся со следующей проблемой. Пишу сайт на html и css. Анимацию слайдера решил сделать на java script, так как готовое решение было в свободном доступе.

В index.html есть код для самого слайдера:

HTML5
1
2
3
4
5
<div id="slider">
  <img src="img/slide1.jpg" title="1-е фото" />
  <img src="img/slide2.jpg" title="2-е фото" />
  <img src="img/slide3.jpg" title="3-е фото" />
</div>
анимация и действия заданы в файле powerSlide.js:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
(function($){
 
    $.fn.powerSlide = function(options){  
 
        var opt ={
            'width': 908, // Width and height of the images
            'height': 340,
            'row': 10, // Thumbnails per row
            'auto': false, // Auto rotate
            'autoSpeed': 3000,
            'fadeSpeed': 1000
        };
 
        this.each(function(){        
        
            if (options){ 
                $.extend(opt, options);
            }
 
            /* Container and wrapper
            -----------------------------------------------*/
            $(this).children().wrapAll('<div class="powerSlide" />');
            var container = $(this).find('.powerSlide');
            container.find('img').wrapAll('<div class="wrapper" />');
            var wrapper = container.find('.wrapper');
 
 
            /* Previous & next buttons
            -----------------------------------------------*/
            wrapper.append('<a href="#" class="prev">Prev</a><a href="#" class="next">Next</a>');
 
 
            /* Navigation & captions
            -----------------------------------------------*/
            switch (opt.position){ // Navigation position 
                case 'top': container.prepend('<div class="nav" />'); break;
                case 'bottom': container.append('<div class="nav" />'); break;
            }
 
            var nav = container.find('.nav');
 
            wrapper.find('img').each(function(i){ // Captions
                var title = $(this).attr('title');
                $(this).wrapAll('<div class="image" />');
                if (title !== undefined){
                    $(this).attr('title', '');
                    $(this).after('<p>'+ title +'</p>');
                }
            });         
            
            
            /* Slider Object
            -----------------------------------------------*/       
            var Slider = function(){
                this.imgs = wrapper.find('div.image');
                this.imgCount = (this.imgs.length) - 1; // Match index
                this.navPrev = wrapper.find('a.prev');
                this.navNext = wrapper.find('a.next');
                this.bullets = container.find('.nav a');
                this.thumbs = container.find('.nav img.thumb');
                this.captions = this.imgs.find('p');
 
                this.getCurrentIndex = function() { // Index
                    return this.imgs.filter('.current').index();
                };
 
                this.go = function(index){ // Rotate images
                    this.imgs
                        .removeClass('current')
                        .fadeOut(opt.fadeSpeed)
                        .eq(index)
                        .fadeIn(opt.fadeSpeed)
                        .addClass('current');
                    this.bullets
                        .removeClass('current')
                        .eq(index)
                        .addClass('current');
                    this.thumbs
                        .removeClass('current')
                        .eq(index)
                        .addClass('current');
                };      
    
                this.next = function(){
                    var index = this.getCurrentIndex();
                    if (index < this.imgCount){
                            this.go(index + 1); // Go next
                    } 
                        else{
                            this.go(0); // If last go first
                        }
            };
    
            this.prev = function(){
                    var index = this.getCurrentIndex();
                    if (index > 0) {
                        this.go(index - 1); // Go previous
                    } else {
                        this.go(this.imgCount); // If first go last
                    }
            };  
    
            this.init = function(){ //Init
                wrapper
                    .width(opt.width)
                    .height(opt.height); /* Set width and height */
                
                this.imgs.hide().first().addClass('current').show(); /* Set current image */
                this.bullets.first().addClass('current');
                this.thumbs.first().addClass('current');
                
                // Dimensions for thumbnails and captions
                var padding = wrapper.css('padding-left').replace('px', '');
                var captionsPadding = this.captions.css('padding-left').replace('px', '');
                nav.width(opt.width);
                if (opt.thumbs === true) { // thumbs
                    var thumbBorder = this.thumbs.css('border-left-width').replace('px', '');
                    var thumbMargin = this.thumbs.css('margin-right').replace('px', '');
                    var thumbMaxWidth = opt.width/opt.row;
                    this.thumbs.width( (thumbMaxWidth - (thumbMargin * 2)) - (thumbBorder * 2) );
                }
                this.captions // captions
                    .width(opt.width - (captionsPadding * 2) + 'px')
                    .css('margin-bottom', padding + 'px');
                this.navNext.css('margin-right', padding + 'px');
                };
            };
            
            var slider = new Slider();
            slider.init();      
            
            
            /* Mouse Events
            -----------------------------------------------*/
            wrapper.hover(function(){ // Hover image wrapper
                slider.captions.stop(true, true).fadeToggle();
                slider.navNext.stop(true, true).fadeToggle();
                slider.navPrev.stop(true, true).fadeToggle();
            });
            slider.navNext.click(function(e){ // Click next button
                e.preventDefault();
                slider.next(); 
            });
            slider.navPrev.click(function(e){ // Click previous button
                e.preventDefault();
                slider.prev();
            });
            
            
            /* Auto Rotate  
            -----------------------------------------------*/           
            if (opt.auto === true){
 
                var timer = function(){
                        slider.next();
                        slider.captions.hide();
                };
                var interval = setInterval(timer, opt.autoSpeed);
    
                // Pause when hovering image
                wrapper.hover(function(){clearInterval(interval);}, function(){interval=setInterval(timer, opt.autoSpeed);});
            }
        });
    };
})(jQuery);

Все работает замечательно, слайды переключаются, при наведении мыши на слайдер, наоборот останавливаются. Но когда открываешь в браузере другую вкладку, и находишься на ней какое-то время, а затем обратно возвращаешься к сайту, слайдер начинает перелистывать изображения с огромной скоростью. Скорее всего, это происходит потому, что таймер не останавливается, когда окно теряет фокус, а когда снова попадает в фокус, слайдер начинает пролистывать слайды быстрее до тех пор, пока не отмотает все-то время, что окно было без фокуса.

Вопрос следующий: каким образом можно обнулить таймер или остановить прокрутку слайдов, когда страница вне фокуса, и продолжить, когда опять в фокусе применительно к конкретному коду?

За скорость анимации отвечает вот этот код:

JavaScript
1
2
3
4
5
6
7
8
        var opt ={
            'width': 908, // Width and height of the images
            'height': 340,
            'row': 10, // Thumbnails per row
            'auto': false, // Auto rotate
            'autoSpeed': 3000,
            'fadeSpeed': 1000
        };
За авто переключение этот:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
            /* Auto Rotate  
            -----------------------------------------------*/           
            if (opt.auto === true){
 
                var timer = function(){
                        slider.next();
                        slider.captions.hide();
                };
                var interval = setInterval(timer, opt.autoSpeed);
    
                // Pause when hovering image
                wrapper.hover(function(){clearInterval(interval);}, function(){interval=setInterval(timer, opt.autoSpeed);});
            }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.03.2016, 22:06
Ответы с готовыми решениями:

Некорректно отображается слайдер
Здравствуйте,я установил слайдер на сайт,но он не правильно отображается: все что я подключил я заскринил. скинул бы ссылку страницы,но...

Не отображается автор и некорректно отображается дата в слайдбаре
Подскажите из-за чего в слайдах отображаются не те даты, что в обычном новостном блоке. То есть, выводятся даты на подобии: 01-01-70. ...

Анимация слайдера Owl Carusel 2
Доброго всем дня. Подскажите пожалуйста, как сменить анимацию при прокрутке слайдера. Сейчас это выглядит так: одна картинка сменяет...

2
Философ-разговорник
 Аватар для Padonak
1066 / 391 / 120
Регистрация: 20.02.2016
Сообщений: 884
Записей в блоге: 1
07.03.2016, 13:59
Попробуйте в последнем фрагменте кода (где wrapper.hover(function...) добавить:

JavaScript
1
2
$(window).blur(function(){clearInterval(interval);});
$(window).focus(function(){interval=setInterval(timer, opt.autoSpeed);});
У меня ваш слайдер почему-то не работает, так что проверить я свои предложения не смог. Вообще, я всегда рекомендую людям, использующим чьи-то готовые слайдеры/галереи/и прочую хрень, обращаться со всеми вопросами К АВТОРАМ кода, т.к. лучше них никто не разбирается в их заклинаниях.
1
0 / 0 / 0
Регистрация: 01.03.2016
Сообщений: 2
10.03.2016, 20:56  [ТС]
Огромное спасибо! Теперь таймер обнулятся и при возвращении на вкладку анимация отображается корректно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.03.2016, 20:56
Помогаю со студенческими работами здесь

Сайт некорректно отображается
Столкнулся вот с какой загвоздкой. На телефоне отображается только центральная часть сайта. Т.е. на ПК выглядит как на первой картинке,...

Некорректно отображается SVG
Вверху слева - моё приложение, вверху справа - окно Dolphin, внизу слева - открытое изображение в Gimp, такое, как оно должно быть. ...

Некорректно отображается сайт
http://www.shinmonster.kz/glavnaya.html Код через компьютер отображается корректно, а в интернете нет. Нет фона и все ссылки ...

Изображение отображается некорректно
Почему-то изображение выглядит так, как будто оно вертикально, но в при просмотре фотографий оно выглядит нормально, я даже перевернул его...

Некорректно отображается сайт
Здравствуйте уважаемые Вебмастера. Ко мне обратился за помощью мой знакомый. В общем есть сайт souzuristov.com и он некорректно стал...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru