Ver Mensaje Individual
  #37 (permalink)  
Antiguo 24/06/2014, 05:44
Avatar de IsaBelM
IsaBelM
Colaborador
 
Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 7 meses
Puntos: 1012
Respuesta: [APORTE] efectos sin jquery

Código:
		// ARRASTRAR scroll bar

				if (('ontouchstart' in scrollDiv.bar[indice])) {

					lib.Evento(scrollDiv.bar[indice], 'touchstart', function(evt) {

						lib.EventoCancelar(evt);
						lib.EventoParar(evt);

						offset1 = {y : (evt.touches[0].pageY) ? evt.touches[0].pageY : evt.touches[0].clientY};

						lib.Evento(document.body, 'touchmove', scrollDiv.arrastrar[indice]);
						lib.Evento(document, 'touchend', scrollDiv.mouseupDocument[indice]);
					});


					scrollDiv.arrastrar[indice] = function(evt) {

						lib.EventoCancelar(evt);
						lib.EventoParar(evt);

						offset2 = {y : (evt.touches[0].pageY) ? evt.touches[0].pageY : evt.touches[0].clientY};

						if (offset2.y != offset1.y) {

							if (parseInt(lib.cssComputado(scrollDiv.vTxt[indice], 'top')) > 1) {

								scrollDiv.vTxt[indice].style.top = '1px';
								vTxtTop = 1;

							} else if ((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) >= (trackH - barH)) {

								scrollDiv.bar[indice].style.top = (trackH - barH) + 'px';
								var scrll = -parseInt(((trackH - barH) * alto_cont) / largoCarril);
								scrollDiv.vTxt[indice].style.top = scrll + 'px';
								vTxtTop = scrll;

							} else if (parseInt(((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) * alto_cont) / largoCarril) >= 1){

								scrollDiv.bar[indice].style.top = (parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) + 'px';
								var scrll =  -parseInt(((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) * alto_cont) / largoCarril)
								scrollDiv.vTxt[indice].style.top = scrll + 'px';
								vTxtTop = scrll;
							}

							offset1.y = offset2.y;
						}	
					}

				} else {

					lib.Evento(scrollDiv.bar[indice], 'mousedown', function(evt) {

						lib.EventoCancelar(evt);
						lib.EventoParar(evt);

						offset1 = {y : (evt.pageY) ? evt.pageY : window.event.clientY};

						lib.Evento(document.body, 'mousemove', scrollDiv.arrastrar[indice]);
						lib.Evento(document, 'mouseup', scrollDiv.mouseupDocument[indice]);
					});


					scrollDiv.arrastrar[indice] = function(evt) {

						lib.EventoCancelar(evt);
						lib.EventoParar(evt);

						offset2 = {y : (evt.pageY) ? evt.pageY : window.event.clientY};

						if (offset2.y != offset1.y) {

							if (parseInt(lib.cssComputado(scrollDiv.vTxt[indice], 'top')) > 1) {

								scrollDiv.vTxt[indice].style.top = '1px';
								vTxtTop = 1;

							} else if ((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) >= (trackH - barH)) {

								scrollDiv.bar[indice].style.top = (trackH - barH) + 'px';
								var scrll = -parseInt(((trackH - barH) * alto_cont) / largoCarril);
								scrollDiv.vTxt[indice].style.top = scrll + 'px';
								vTxtTop = scrll;

							} else if (parseInt(((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) * alto_cont) / largoCarril) >= 1){

								scrollDiv.bar[indice].style.top = (parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) + 'px';
								var scrll =  -parseInt(((parseInt(lib.cssComputado(scrollDiv.bar[indice], 'top')) + (offset2.y - offset1.y)) * alto_cont) / largoCarril)
								scrollDiv.vTxt[indice].style.top = scrll + 'px';
								vTxtTop = scrll;
							}

							offset1.y = offset2.y;
						}	
					}
				}

		// ARRASTRAR scroll bar

			}

			scrollDiv.mouseupDocument[indice] = function(event) {scrollDiv.elimimarEventos(event, indice);}

	},



	elimimarEventos : function(evt, indiceObj) {

		lib.EventoParar(evt);
		lib.EventoEliminar(document.body, 'keydown', scrollDiv.flechas[indiceObj]);
		lib.EventoCancelar(evt);
		lib.EventoEliminar(document.body, 'mousemove', scrollDiv.arrastrar[indiceObj]);
		lib.EventoEliminar(document, 'mouseup', scrollDiv.mouseupDocument[indiceObj]);
		lib.EventoEliminar(document.body, 'touchmove', scrollDiv.arrastrar[indiceObj]);
		lib.EventoEliminar(document, 'touchend', scrollDiv.mouseupDocument[indiceObj]);
	}

}


lib.Evento(document, 'DOMContentLoaded', scrollDiv.init);
</script>
</head>
<body>

<div class="margenes">

<div class="contenedor">

	<div class="scrollbar">
		<div class="carril">
			<div class="barra"></div>
		</div>
	</div>


	<div class="txtarea">
		<div class="valorTxtarea">
			Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut 
			laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
		</div>
	</div>

</div>

</div>




<br><br>




<div class="margenes">

<div class="contenedor">

	<div class="scrollbar">
		<div class="carril">
			<div class="barra"></div>
		</div>
	</div>


	<div class="txtarea">
		<div class="valorTxtarea">
			Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut 
			laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
		</div>
	</div>

</div>

</div>

</body>
</html>
aquí podéis verlo en funcionamiento
__________________
if(ViolenciaDeGénero) {alert('MUJER ASESINADA');}

Última edición por IsaBelM; 07/12/2016 a las 13:40