Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 06.10.2016, 17:46
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

Как сделать сопротивление при touch управление слайдером
Всем доброго времени суток.

Суть вопроса в следующем. Есть слайдер, который состоит из списка ul в котором любое количество li, в которых есть какой то контент.

Управляется touch и mouse событиями. Как сделать, если перед (назад листаем) или после (вперед листаем) нет предыдущего или следующего слайда, сопротивление (если я правильно это называю).

Если кто нибудь делал уже такие вещи помогите советом. Или где почитать подробнее можно об этом
Заранее благодарю.
Ответить с цитированием
  #2 (permalink)  
Старый 06.10.2016, 18:12
Аватар для Coriolan161
Профессор
Отправить личное сообщение для Coriolan161 Посмотреть профиль Найти все сообщения от Coriolan161
 
Регистрация: 21.11.2015
Сообщений: 440

Роман Андреевич,
Роман Андреевич, либо делать цикл из слайдов, либо return в touch и mousemove обработчиках
Ответить с цитированием
  #3 (permalink)  
Старый 06.10.2016, 18:14
Аватар для Coriolan161
Профессор
Отправить личное сообщение для Coriolan161 Посмотреть профиль Найти все сообщения от Coriolan161
 
Регистрация: 21.11.2015
Сообщений: 440

Роман Андреевич,
можно залезть в карусельные плагины и подсмотреть
Ответить с цитированием
  #4 (permalink)  
Старый 06.10.2016, 18:21
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121

Роман Андреевич,
может код, а лучше макет
Ответить с цитированием
  #5 (permalink)  
Старый 06.10.2016, 18:21
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

Coriolan161,
changeStyle($this, "margin-left", distance);

					if (directionSide == "left") {

						if (!nextItem.length) {

							//different = 

							distance = distance + (distance / 10);

							changeStyle($this, "margin-left", distance);

						}

					} else if (directionSide == "right") {


						if (!prevItem.length) {

							distance = distance / 10;

							changeStyle($this, "margin-left", distance);

						}

					}


Слайды поставлены float:left а ширина списка ul равна ширине слайда * их кол-во.

Слайдер двигается с помощью координат при touchstart или mousedown а потом соответственно move.

Двигаем свойство margin-left. distance это как раз и есть смещение. Если стоит слайдер первый, то перед ним ничего нет, соответственно distance делим на какое нибудь число и получается нужный эффект, тут исчисления идут от 0. А вот если слайдер последний, то distance нельзя делить на 10, потому что получается, слайдер смещается в ненужную сторону.

если не сложно, поясните как сделать через цикл и для чего return в move событиях????
Ответить с цитированием
  #6 (permalink)  
Старый 06.10.2016, 18:23
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

<section class="slider">
		<h2>slider</h2>
		<nav class="slider_block">
			<ul class="slider_list">
				<li class="slider_item first active">
					<div class="div_block"></div>
				</li>
				<li class="slider_item second">
					<div class="div_block"></div>
				</li>
				<li class="slider_item third">
					<div class="div_block"></div>
				</li>
				<li class="slider_item fourth">
					<div class="div_block"></div>
				</li>
				<li class="slider_item fifth">
					<div class="div_block"></div>
				</li>
			</ul>
			<ul class="control">
				<li class="button right"></li>
				<li class="button left"></li>
			</ul>
		</nav>
	</section>

* {padding: 0;margin: 0;list-style-type: none;text-decoration: none;outline: none;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;-ms-box-sizing: border-box;-o-box-sizing: border-box;box-sizing: border-box;}

		section.slider {width: 100%;padding: 5% 0;}
		nav.slider_block {width: 100%;position: relative;overflow: hidden;}
		ul.slider_list {width: 100%;}
		ul.slider_list:after {content: "";display: block;width: 0;height: 0;clear: both;}

		ul.slider_list li.slider_item {float: left;}
		ul.slider_list li.slider_item.first {background-color: #e43c1e;}
		ul.slider_list li.slider_item.second {background-color: #f0b21b;}
		ul.slider_list li.slider_item.third {background-color: green;}
		ul.slider_list li.slider_item.fourth {background-color: black;}
		ul.slider_list li.slider_item.fifth {background-color: blue;}
		
		div.div_block {width: 100%;height: 300px;}

		ul.control.hiden {display: none;}		
		ul.control li.button {width: 50px;height: 50px;background-color: #ccc;position: absolute;top: 50%;transform: translateY(-50%);}
		ul.control li.button.right {right: 0;}
		ul.control li.button.left {left: 0;}

$(document).ready(function() {

			var   animationFlag = 0,
				slider = $(".slider_list"), // блок который сдвигаем
				control = $(".control"), // кнопки управления слайдером
				needOffset = 0, // порог смещения слайда для перелиставния к следующему слайду
				gor = 0, // первоначальная координата X косания или нажатия мышиной кнопки
				gortwo = 0, // копируем перовначальную координату 
				tor = 0, // переменная для определения направления движения курсора или пальца
				flag = 0, // метка начала череды событий
				direction = 0,
				distance = 0,
				newdistance = 0, 
				directionSide = 0, // направление движения слайдера
				standartDuration = 200,
				sliderDuration, // время движения слайдера 
				eventCounter = 0, //время между событиями в милисекундах
				startEventCounter = 0, // время начала 
				endEventCounter = 0, // время конца 
				firstMargin = 0,
				moveMargin = 0,
				different = 0;

			sliderSize();

			slider.on("touchstart mousedown", function(e){
				e.preventDefault();

				var $this = $(this);

				startEventCounter = Date.now();
				flag = 1;

			    if (e.type == "touchstart") {

			    	var pos = $this.offset();

						gor = e.changedTouches[0].pageX - pos.left;

			    } else if (e.type == "mousedown") {

					var pos = $this.offset();

						gor = e.pageX - pos.left;

				    $this.css("cursor", "move");

			    }
				
				gortwo = gor;

			});	

			slider.on("touchmove mousemove", function(e) {
				e.preventDefault();

				var $this = $(this),
					sliderBlock = $this.closest(".slider_block"),
					list = sliderBlock.find(".slider_list"),
					item = list.find(".slider_item"),
					itemWidth= item.width(),
					itemLength = item.length,
					activeItem = item.filter(".active"),
					nextItem = activeItem.next(),
					prevItem = activeItem.prev(),
					lastMargin = 0;


				if (flag === 1) {

					if (e.type == "touchmove") {

						direction = e.changedTouches[0].pageX;
						distance = direction - gortwo;
						tor = gor - e.changedTouches[0].pageX;
						gor = e.changedTouches[0].pageX;

					} else if (e.type == "mousemove") {

						direction = e.pageX;
						distance = direction - gortwo;
						tor = gor - e.pageX;
						gor = e.pageX;

					}

					direction_Side();
					changeStyle($this, "margin-left", distance);

					if (directionSide == "left") {

						if (!nextItem.length) {

							//different = 

							distance = distance + (distance / 10);

							changeStyle($this, "margin-left", distance);

						}

					} else if (directionSide == "right") {


						if (!prevItem.length) {

							distance = distance / 10;

							changeStyle($this, "margin-left", distance);

						}

					}

				}

			});

			slider.on("touchend mouseup", function(e) {
		    	e.preventDefault();

		    	endEventCounter = Date.now();

				var $this = $(this),
					controlButton = $this.siblings(".control"),
					sliderBlock = $this.closest(".slider_block"),
					sliderOffset = sliderBlock.offset().left,
					sliderList = sliderBlock.find(".slider_list"),
					item = sliderList.find(".slider_item"),
					itemIndex = item.index(),
					activeItem = item.filter(".active"),
					nextItem = activeItem.next(),
					prevItem = activeItem.prev(),
					itemLength = item.length,
					ass = 0;

				if (e.type == "touchend") {



				} else if (e.type == "mouseup") {

					$(this).css("cursor", "default");
					
				}

				if (directionSide == "left") {

					if (nextItem.length) {

						newdistance = (distance * - 1) - (item.width() * activeItem.index());

						letsRide(sliderList, nextItem, sliderOffset);	

					} else {

						letsRide(sliderList, activeItem, sliderOffset);

					}

				} else if (directionSide == "right") {

					if (prevItem.length) {

						newdistance = ((distance * - 1) - (item.width() * activeItem.index())) * - 1;

						letsRide(sliderList, prevItem, sliderOffset);

					} else {

						letsRide(sliderList, activeItem, sliderOffset);

					}

				}

				if (eventCounter > 300 && newdistance < needOffset) {

					letsRide(sliderList, activeItem, sliderOffset);

				}

				flag = 0;
				distance = 0;
				tor = 0;
				directionSide = "undefined";

			});

			function showElements() {for (var i = 0; i < arguments.length; i++) {arguments[i].show(100);}}
			function hideElements() {for (var i = 0; i < arguments.length; i++) {arguments[i].hide(100);}}

			function letsRide(moveelement, slide, distance) {

				eventCounter = endEventCounter - startEventCounter;

				if (eventCounter < 200) {

					sliderDuration = eventCounter;

				} else {

					sliderDuration = 200;

				}

				slidePosition = slide.offset().left - distance;
				slide.addClass("active").siblings().removeClass("active");
				moveelement.stop().animate({"margin-left": "-=" + slidePosition}, sliderDuration);

			}

			function direction_Side() {

				if (tor > 0) {

					directionSide = "left";	

				} else if (tor < 0) {

					directionSide = "right";		

				}

			}

			function sliderSize() {

				var container = $(".slider_block");
										
				container.each(function() {

					var $this = $(this),
						win = $this.closest(".slider"),
						winWidth = win.width(),
						list = $this.find(".slider_list"),
						item = list.find("li"),
						itemLength = item.length,
						itemWidth = item.width(winWidth),
						listWidth = list.width(winWidth * itemLength),
						activeItem = item.filter(".active"),
						activeItemIndex = activeItem.index(),
						position = winWidth * activeItemIndex;

					changeStyle(list, "margin-left" , - position);

					needOffset = winWidth/3;

				});	

			}
			
			function changeStyle(element, property, value) {
				
				element.css(property, value);

			}

			function newClass(element, className) {element.addClass(className);}
			function deleteClass(element, className) {element.removeClass(className);}

			$(window).on("orientationchange resize", sliderSize);

		});
Ответить с цитированием
  #7 (permalink)  
Старый 06.10.2016, 18:24
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

Я думаю что галактику я не открыл, но просто понять хочу как сделать сопротивление при последнем слайде.
Все работает, код конечно не идеален но для новичка должен пойти)))

Заранее благодрю
Ответить с цитированием
  #8 (permalink)  
Старый 06.10.2016, 18:26
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121

Роман Андреевич,
может плагин взять и не мучатся
http://owlgraphic.com/owlcarousel/
Ответить с цитированием
  #9 (permalink)  
Старый 06.10.2016, 18:26
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

Coriolan161,
В карусельные плагины залазил, особо не помогло, это нужно слишком много времени, что бы разобрать хороший код. А зачастую такой функционал не каждый слайдер поддерживает.
Ответить с цитированием
  #10 (permalink)  
Старый 06.10.2016, 18:28
Профессор
Отправить личное сообщение для Роман Андреевич Посмотреть профиль Найти все сообщения от Роман Андреевич
 
Регистрация: 12.08.2016
Сообщений: 299

рони,
Да, может, но хочу понимать суть. Использовать чужие плагины проще, но не факт что лучше. ПОэтому прошу помощи у тех, кто решал такие задачи
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как сделать, чтоб глобус при клике вращался вокруг указателя мышки? missbells Events/DOM/Window 1 05.12.2015 00:48
ipad, как сделать немигающее поле при нажатии Floyd (X)HTML/CSS 0 23.10.2015 12:03
А как сделать , чтоб при выполнении условия сохранялись данные о времени его выполнен Валерий1996 Общие вопросы Javascript 4 27.08.2015 15:51
Как сделать чтобы textarea тянулась в высоту при добавлении в нее текста? javasc Общие вопросы Javascript 4 27.03.2012 22:14
Как сделать, чтобы при наведении на кнопку справа от нее появлялись текстовые ссылки? Tass Общие вопросы Javascript 7 17.02.2011 09:06