5 / 5 / 1
Регистрация: 03.07.2014
Сообщений: 75

Старт анимации при скролле

22.12.2014, 20:07. Показов 3322. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
доброго времени суток! хочу понять как можно реализовать старт анимации при прокрутке до него, вот у меня есть скрипт, каким образом мне надо его обновить, чтобы анимация начиналась только с момента прокрутки до блока? http://jsfiddle.net/muty419x/1/ Заранее спасибо!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.12.2014, 20:07
Ответы с готовыми решениями:

Старт и стоп анимации при повторных кликах
всем привет! использую плагин jqueryrotate не могу сделать так, чтобы при первом клике на объект он начинал вращаться, а при повторном...

Перемещение элемента при скролле
Здравствуйте, есть такой код, $(window).scroll(function() { if ($(this).width() > 1000) { if ($(this).scrollTop() >= 400) { ...

Загрузка gif при скролле
Здравствуйте, хочу сделать загрузку gif анимаций при скролле. Код для скролла я смог сделать, есть проблема. gif анимация полностью...

5
39 / 39 / 43
Регистрация: 14.07.2014
Сообщений: 230
22.12.2014, 21:46
На фиддле этого не показать, объясняю так
Есть метод offset - он возвращает объект из двух свойств - top left - соответсвенно расстояние сверху и слева от начала веб-страницы.
Есть обработчик события scroll который запускает функцию каждый раз при скроллинге, включая кажется и масштабирование
И есть метод scrollTop объекта window который возвращает в пикселях сколько проскролено сверху.
JavaScript
1
2
3
4
var $myElem= $('#myElem');
$(window).scroll(function(){
 if ( $(window).scrollTop() >= $($myElem).offset().top )  { анимация }
});
0
5 / 5 / 1
Регистрация: 03.07.2014
Сообщений: 75
23.12.2014, 16:28  [ТС]
Az Rieil, но как только я помещаю вместо { анимация } свою анимацию, она перестает работать

Добавлено через 2 часа 2 минуты
Вот получается у меня такой скрипт
HTML5
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
166
167
168
169
170
171
172
<!DOCTYPE html>
<html>
  <head>
    <title>Circular Progress test</title>
    <meta charset="utf-8">
  </head>
  <body style="background-color:#00ff00">
 <script>
 
     (function () {
 
 
  var ctxProperties = ['fillStyle', 'font', 'globalAlpha', 'globalCompositeOperation',
        'lineCap', 'lineDashOffset', 'lineJoin', 'lineWidth',
        'miterLimit', 'shadowBlur', 'shadowColor', 'shadowOffsetX',
        'shadowOffsetY', 'strokeStyle', 'textAlign', 'textBaseLine'];
 
 
  var autoscale = function (canvas) {
    var ctx = canvas.getContext('2d'),
    ratio = window.devicePixelRatio || 1;
 
    if (1 !== ratio) {
      canvas.style.width = canvas.width + 'px';
      canvas.style.height = canvas.height + 'px';
      canvas.width *= ratio;
      canvas.height *= ratio;
      ctx.scale(ratio, ratio);
    }
 
    return canvas;
  };
 
 
  var extendCtx = function (ctx, options) {
    for (var i in options) {
      if (ctxProperties.indexOf(i) === -1) continue;
      ctx[i] = options[i];
    }
  };
 
 
  var CircularProgress = this.CircularProgress = function (options) {
    var ctx, i, property;
 
    options = options || {};
    this.el = document.createElement('canvas');
 
    this.options = options;
 
    options.text = options.text || {};
    options.text.value = options.text.value || null;
 
    ctx = this.el.getContext('2d');
 
    for (i in ctxProperties) {
      property = ctxProperties[i];
      options[property]= typeof options[property] !== 'undefined' ? options[property] : ctx[property];
    }
 
    if (options.radius) this.radius(options.radius);
  };
 
 
  CircularProgress.prototype.update = function (value) {
    this._percent = value;
    this.draw();
    return this;
  };
 
 
  CircularProgress.prototype.radius = function (value) {
    var size = value * 2;
    this.el.width = size;
    this.el.height = size;
    autoscale(this.el);
    return this;
  };
 
 
  CircularProgress.prototype.draw = function () {
    var tw, text, fontSize,
        options = this.options,
        ctx = this.el.getContext('2d'),
        percent = Math.min(this._percent, 98),
        ratio = window.devicePixelRatio || 3,
        angle = Math.PI * 2 * percent / 100,
        size = this.el.width / ratio,
        half = size / 2,
        x = half,
        y = half;
    ctx.clearRect(0, 0, size, size);
    ctx.setTransform(0.9, 0, 0.05, 1, 0, 0);
    // Initial circle
    if (options.initial) {
      extendCtx(ctx, options);
      extendCtx(ctx, options.initial);
 
      ctx.beginPath();
      ctx.arc(x, y, half - ctx.lineWidth, 0, 2 * Math.PI, false);
      ctx.stroke();
    }
 
 
    extendCtx(ctx, options);
 
    ctx.beginPath();
    ctx.arc(x, y, half - ctx.lineWidth, 0, angle, false);
    ctx.stroke();
 
    // Text
    if (options.text) {
      extendCtx(ctx, options);
      extendCtx(ctx, options.text);
    }
 
    text = options.text.value === null ? (percent | 0) + '%' : options.text.value;
    tw = ctx.measureText(text).width;
    fontSize = ctx.font.match(/(\d+)px/);
    fontSize = fontSize ? fontSize[1] : 0;
 
    ctx.fillText(text, x - tw / 2 + 1, y + fontSize / 2 - 1);
 
    return this;
  };
 
}).call(this);</script>
<div style="height:1500px"></div>
<div id="myDiv"></div>
    <script>
     var $myElem= $('#mydiv');
$(window).scroll(function(){
 if ( $(window).scrollTop() >= $($myElem).offset().top )  {    (function () {
    (function () {
      var n, id, progress;
 
      progress = new CircularProgress({
        radius: 60,
        strokeStyle: '#4e86c1',
        lineCap: 'square',
        lineJoin: 'round',
        lineWidth: 3,
        shadowBlur: 0,
        shadowColor: '#4e86c1',
        color: '#4e86c1',
        text: {
            font: '24px arial',
            shadowBlur: 0,
            fillStyle:'#247AFF',
            
        },
        initial: {
          strokeStyle: 'white',
          lineCap: 'square',
          lineJoin: 'round',
          lineWidth: 3,
          
          shadowColor: '#4e86c1'
        }
      });
 
     document.getElementById('myDiv').appendChild(progress.el);
 
      n = 0;
      id = setInterval(function () {
        if (n == 100) clearInterval(id);
        progress.update(n++);
      }, 8);
    })();});
    </script>
  </body>
</html>
0
39 / 39 / 43
Регистрация: 14.07.2014
Сообщений: 230
23.12.2014, 22:08
Во первых выложите содержимое консоли ошибок.
Во вторых - используется какой-то сторонний плагин CircularProgress( видимо этот ), он в вашем скрипте не подключается.
0
5 / 5 / 1
Регистрация: 03.07.2014
Сообщений: 75
24.12.2014, 13:32  [ТС]
Az Rieil,
в консоли ошибок всего 1 строчка
Миниатюры
Старт анимации при скролле  
0
5 / 5 / 1
Регистрация: 03.07.2014
Сообщений: 75
24.12.2014, 14:42  [ТС]
я как понял ему нужно скобки поставить, но как только я ставлю скобки, он начинает жаловаться на скобки
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.12.2014, 14:42
Помогаю со студенческими работами здесь

Фиксированное Хедер при скролле
Доброго времени суток! Нужна помощь в фиксированном меню (шапка), при прокрутке шапка распологается под ссылкой &lt;a...

Всплывающий border при скролле
При скролле, появлялось активная ссылка того элемента, на каком уровне он находиться p.s Все элементы, находятся на одной странице ...

Фиксированное меню при скролле
Добрый день. Подскажите, как побороть проблему. Есть скрипт, который скролит страницу при клике на якорь ...

Анимация только при скролле.
Хочу чтобы у меня работала анимация только при скролле! &lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;meta...

Выполнять анимацию только при скролле
как написать на jquery чтобы у меня анимация выполнялась только при scroll. &lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru