24/06/2014, 05:44
|
| Colaborador | | Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 6 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
Última edición por IsaBelM; 07/12/2016 a las 13:40 |