Entradas en la categoría ‘Tutoriales’

Noviembre 21st, 2009 | Sin comentarios

Muestra las últimas canciones que escuchas en Grooveshark en tu blog de WordPress

Sin duda una aplicación web que uso a diaro es Grooveshark, y últimamente pense en si era posible integrar una especie de widget ó simplemente hubiera una manera de mostrar las últimas canciones que he escuchado (algo parecido a lo que Rogie King hizo en KomodoMedia con Last.fm), pero al parecer no hay una API que permita hacerlo :(

Last.fm en Komodo MediaSin embargo, Grooveshark nos ofrece 3 feeds RSS (que muchos no saben de ellos), uno de ellos es de las últimas canciones que hemos escuchado, y puedes encontrarlas en tu configuración de feeds de Grooveshark (necesitas haber iniciado sesión).

GroovesharkEn mi caso la dirección del feed es http://api.grooveshark.com/feeds/1.0/users/raymundoaaron/recent_favorite_songs.rss; ahora, para insertar las últimas canciones que escuchamos simplemente usaremos una especie de lector de feeds que puedes insertar en WordPress como un sencillo código PHP.

get_item_quantity(5);
	$rss_items = $rss->get_items(0, $maxitems);
?>
    No hay canciones '; else foreach ( $rss_items as $item ) : ?>
  • get_title(); ?>

En el código de arriba solo hay que sustituir la dirección al feed mío por el suyo, y personalizamos cuantos canciones como límite podemos mostrar, además, hay muchas otras posibilidades de personalizar tu código si sabes de las funciones de WordPress ;)

Si alguien sabe de alguna forma de localizar la carátula del albúm lo comenta abajo.

Septiembre 15th, 2009 | 3 comentarios

Aprende lo básico de jQuery desde cero en 15 días ó menos

Hace poco que me propuse aprender JavaScript, y una de las cosas de las que me percaté pronto fue que no me sería tan útil como aprender a usar jQuery, pues se mi hizo más sencillo y conseguía mejores resultados :P

Logotipo de jQueryDebo decirles que apesto en JavaScript, es más, no se JavaScript, pero ahora ya estoy aprendiendo un poco :)

Gracias a una serie de videotutoriales publicados en el blog de ThemeForest.

jQuery para principiantesSin duda son muy buenos y resultan realmente útiles, ya que estan muy claros y empiezan desde lo más básico (descargar la librería e incluirla a una página), luego aprendemos cómo animar elementos entre otras cosas y así seguimos aprendiendo cosas nuevas.

Aún no los he terminado de ver, tengo 3 días viéndolos, me han gustado mucho y veo al menos uno cada día :P

Los recomiendo a todos los que quieran aprender jQuery de una forma fácil, poco a poco y de manera eficaz.

En total son 15 capítulos, el último está dividido en 2 partes

Enjoy it! ;)

jQuery para principiantes

Vía | NetTuts+

Agosto 17th, 2009 | Un comentario

Cómo mudar de dominio un blog de WordPress

Supongo que ya lo habrás notado, ó te habrás enterado por Twitter, que desde el 12 de Agosto ya tengo dominio .com

Además de que cambié de hosting debido a que necesitaba más espacio :P

Sin duda uno de los grandes líos fue la mudanza, aunque claro que el hecho de tener el blog con WordPress hizo fácil algunas cosas :)

Por ello he decido crear un pequeño post sobre cómo mudé el blog ;)

Instalar WordPress en el nuevo dominio

Así es, se tiene que instalar WordPress al nuevo dominio, no es tan simple como Copiar y pegar U_U

Deberás de instalar WordPress en el nuevo dominio, no importa el nombre/contraseña/usuario de la base de datos anterior, tu házlo como si fuera la primera vez que lo haces y vas a empezar un nuevo blog.

Instalar los plugins en el nuevo blog

Si eres cómo yo, que uso varios plugins sobre todo para tener contenido en áreas del blog como el footer, lo primero que recomendaría es instalar los plugins anteriores en el blog.

Para ello los descargas he instalas como los harías comunmente, pero si eres como yo, que modifico el código para que funcionen como yo quiera, ó para no perder la configuración te recomiendo que descargues la carpeta wp-content/plugins del dominio anterior y la subas al nuevo dominiopor FTP

Instalar el theme

Algo básico, es mantener el aspecto de tu blog anterior, por lo que si tenías una plantilla en especial solo deberás volverla a instalar.

De igual forma, si la modificaste, haces lo mismo que con los plugins.

Configurar las opciones generales

Debes de igualar las preferencias de los plugins que hayas instalado, así como la carpeta de subidas, los permalinks, y demás cosas.

Hacer un backup de la base de datos

Por seguridad quize hacer una copia de seguridad de la base de datos, solo deben de entrar al phpMyadmin y exportar la base de datos, ó pueden usar el plugin WP-DB-Backup.

Exportar el contenido del blog

Una de las ventajas de WordPress es que permite exportar e importar un blog mediante un archivo XML que genera, para obtener tu archivo WXR lo único que tienes que hacer es ir a Herramientas » Exportar y descargar el archivo mediante el botón que estará ahí.

Trasladar la multimedia subida

Seguro que tambien haz subido varias imágenes a tu blog, por lo que tendras una gran carpeta wp-content/uploads en la que se encuentran tus archivos subidos.

Mediante el archivo de exportación, es posible sacar las multimedia subida y colocarla en el nuevo blog, pero como toda acción automatisada corres el riesgo de que se detenga en el proceso y todo, absolutamente todo se vaya al carajo.

La probabilidad de que no funcione bien esto, es mayor si tienes varias imágenes y/o post’s

Por ello preferí hacerlo manualmente y descargar la carpeta uploads por FTP a mi PC y de ahí subirla a la carpeta wp-content en el nuevo dominio.

Esto se hace para no depender del dominio anterior :P

Modificar las URL’s de la carpeta de subidas

En el archivo de exportación se encuentra la multimedia (imágenes, videos, etc.) escrita en enlaces que la insertarán en cada post, como se exportó basado en el viejo dominio lestarán enlazadas a él, y seguirás dependiendo el él :P

Para evitar esto, debes de modificar las URL’s para que apunten a la carpeta de subidas que ya debiste haber trasladado al nuevo dominio.

Obviamente no vas a hacerlo manualmente (ya que suelen ser muchas XD) por lo que vas a abrir el archivo de exportación con un editor de texto como el bloc de notas y pones que busque y reemplaze dominioviejo.com/wp-content/uploads por dominionuevo.com/wp-content/uploads

Con eso las imágenes se enlazarán al nuevo sitio ;)

Importar el contenido del blog

Ya que modificaste el archivo de exportación, te diriges en tu nuevo blog a Herramientas » Importar y escoges como opción de importación WordPress.

Tendrás que subir tu archivo de exportación, luego de eso te preguntará si deseas trasladar la multimedia al nuevo dominio (cosa que ya debiste hacer manualmente), por ello le dices que no.

Con esto tendrás tus entradas, comentarios, categorías, tags, etc. :)

Si tenías emoticones personalizados solo debes de volver a subirlos a la carpeta wp-include/images/smilies

Nota importante: Si usas el plugin Google XML Sitemap desactivalo antes de importar las entradas porque si no se sobre cargará y dará error :S

Establecer una redirección 301 del antigüo dominio al nuevo

Esto lo puedes hacer mediante un archivo .htaccess pero si quieres evitar problemas de código te recomiendo que mejor uses el plugin Moving your blog que creará un redireccionamiento a tu nuevo dominio ^^

Lo instalas en el viejo blog y solo lo configuras poniendo la URL del nuevo blog.

Eso fue todo lo que hice y ahora anda super bien ;)

Agosto 4th, 2009 | Sin comentarios

Fotografía Tilt-Shift con Photoshop

Hola de nuevo a todos, desde hace un tiempo que no he escrito nada en el blog, y por ello me he decidido a traerles un nuevo tutorial, nuevamente de fotografía.

En esta ocasión crearemos una fotografía Tilt-shift, este tipo de fotografías consiste en lograr que una imagen que parezca una especie de maqueta, suelen ser fotografías aéreas ó simplemente que tengan un punto de vista elevado, por lo que necesitarás tomar la imágen desde algún lugar alto.

Si quieren algunos ejemplos, pueden ver álgunos ejemplos en Flickr ó una recopilación por parte de HongKiat.

Empezaré diciendo cómo debemos de tomar la fotografía.

No voy a decir que usen una cámara avanzada, ni que compren un lente especial ni nada de eso; usaremos una cámara común y corriente (OK, tiene que ser digital de preferencia, pero, ¿alguien siquiera conoce otro tipo de cámara?).

Qué es necesario para saber si mi montaje quedará bien

Desde el momento en que tomaremos la fotografía debemos saber que hacer para que no salga mal y el montaje se vea bien.

Básicamente se necesitan 3 cosas:

  • Un punto de vista elevado
  • Mucha gente ó  tráfico (no de C_C :P )
  • Elementos pequeños (sillas, luces, árboles, etc.)
  • Opcional: Edificios y/o casas

El punto de vista elevado es indispensable para que una fotografía tilt-shift se vea bien, pero si logras captar mucha gente y edificios puede que el resultado sea bueno.

Carros, trailers y gente, mucha gente ayudan a darle vida a tu maqueta.

Objetos como bancas, postes de luz, bicicletas, árboles, plantas vuelven creativa tu fotografía y más parecida a una maqueta.

Edificios y casas hacen que tu foto no se vea vacía y ayudan a dar un efecto de maqueta llena.

Para mi desgracia, vivo en un lugar donde es imposible encontrar mucha gente junta, pues apenas y hay personas XD

Asi que me fuí a la Cd. de México a tomar la foto (si, suena loco pero al menos aproveché para ver que a cambiado :P ) y aunque el problema era que no había un punto de vista alto logré fotografiar a un grupo de personas juntas:

1_original

Esa es mi imagen, una completa asquerosidad gracias a el que se puso en medio, pues sale muy cerca >:S

Proceder a crear el efecto

Una vez que logremos tener la fotografía vamos a abrirla en Photoshop.

Lo primero que yo suelo hacer por seguridad es duplicar la capa (Ctrl+J) aunque si lo prefieres puedes no hacerlo.

Luego usando la herramienta marco rectangular (M) hacemos una selección en lo que es el área donde se concentra más la gente ó donde queremos aplicar el efecto:

2_seleccion

En este caso la hago donde se concentra más la gente.

Luego de eso vamos al menú Selección » Perfeccionar borde…

3_perfeccionar
Y lo configuramos al gusto, en este caso yo lo he hecho así:

4_borde
Si lo desean, pueden guardar la selección.

Luego de esto invertimos la selección (Ctrl+Shift+I)…

5_invertir

…y vamos a Filtros » Desenfoque » Desenfoque Gaussiano, lo aplicamos al gusto, yo en este caso lo aplico con un radio de 10-15px

6_desenocado

Ahora tenemos que cambiar las tonalidades y el contraste, por lo que damos click sobre el botón de un círculo mitad blanco y mitad negro, luego escogemos Tono/Saturación

7_tono

Y cambiamos la saturación a +50, por lo que la imagen estará así:

8_tonocambiado

Ahora aplicamos la capa de Brillo y Contraste y disminuimos el brillo a -10 y aumentamos el contraste a 50 (estos valores, asi como el de saturación los puedes cambiar a tu gusto)

Tendremos una imagen mas o menos así:

9_brillo

Y por último si lo deseas, puedes aplicar una sombra para que la imagen se enfoque al centro, solo debes de tomar la herramienta de degrado y configurarla de un negro (#000000) 0% alfa a un negro un poco más claro (#0e0e0e) con 100% de alfa.

El degrado lo haces de forma radial con modo de sobreposición normal, con esto tenemos el resultado final:

10_final

Recuerda que lo importante es que el punto de vista este elevado, cuenta mucho para el resultado final y es por eso que el mio no es muy bueno :P

Para ver la imagen en tamaño completo pueden verla en mi Flickr

Espero les haya gustado el tutorial, y me gustaría ver sus fotografías tilt-shift en L4C ó Flickr ;)

Descargar el archivo PSD (30mb – ZIP)

P.S. Estamos estrenando emoticones, wii!!! :D

Julio 21st, 2009 | Sin comentarios

Eliminar (filtrar) automáticamente cadenas de correos en Hotmail

En esta ocasión, luego de haber estado diseñando casi 2 semanas el nuevo theme y actualizar el blog a 2.8.1 para darme cuenta que no era compatible con esta versión y entonces actualizar a 2.8.2 para ver que el problema era la caché (es maldita cosa me a hecho cometer muchas, muchas estupideces ¬¬)…err…ya me desvié del tema, escribiré para que sepan que no descuido el blog, y como apenas es martes empezaré con un pequeño tip para aprender como eliminar ó filtrar (según lo prefieran) automáticamente las cadenas de correos en Hotmail ;)

First, a little FAQ

¿Por qué en Hotmail, usas esa cosa? No es que la use, simplemente muchos amigos no usan Gmail y por ello tengo una cuenta ahí. ¿Por qué no haces el tip para hacerlo en Gmail? Porque la gente que crea ó reenvía estas cosas no sabe que Gmail existe ¿o, te haz topado con cadenas del tipo “reenvialo a 10, 000 contactos ó un virus va a embarazar a tu hermana”, no.

Empecemos…

1administrar-carpetas Entramos a nuestro correo, y en la parte lateral izquierda veremos el enlace Administrar carpetas, hacemos click en él. Ahora en la parte de arriba, hacemos click sobre el enlace que dice Nueva carpeta, y creamos una carpeta con el nombre que queramos, para almacenar los correos. 2nueva-carpetaEn este caso yo creo una llamada “Cadenas” 3cadenasUna vez que creamos la carpeta, nos vamos a ir a la parte derecha, en el menú Opciones buscamos Más opciones. 4mas-opcionesVamos ahora al apartado Personaliza tu correo damos click sobre Ordenar automáticamente el correo electrónico en carpetas 5ordenar-mail-carpetasY de ahí, presionamos el botón de Nuevo filtro: 6nuevo-filtroAhora configuramos el filtro de esta forma (click para ampliar): 7editar-filtroExplicación: No hay nada fuera de lo normal en esto, lo que acabas de hacer se traduciría textualmente como “si el asunto de un correo empieza por FW, se mueve automáticamente a la carpeta Cadenas”, escribimos FW porque los correos que se re-envían se les añade esas siglas (ForWard), asi identificamos que un correo a sido reenviado. Claro que en ocasiones puede que alguien nos va a re-enviar un mail que no es spam, y por ello prefiero archivarlos todos y luego ver si alguno cayó por equivocación. Pero si lo prefieres, puedes configurar el filtro para eliminar los mensajes en vez de archivarlos, solo debes de cambiar el radio button a Eliminar estos mensajes y listo ;) 8fin

Julio 8th, 2009 | Sin comentarios

Excluir tu IP de tus estadísticas de Google Analytics

Pues hoy veremos un pequeño tutorial sobre como podemos excluir nuestra dirección IP del análisis de nuestros sitios web en Analytics de Google.

Google Analytics

Google Analytics

Esto es una de las cosas que todo el mundo debe de saber, pues es algo tan sencillo, pero a la vez necesario que debemos de llevar acabo al usar Analytics para estar analisando algún sitio web.

¿Para qué filtrar mi IP?

Bueno, esto te permitirá tener un análisis más detallado de tu sitio web, pues podrás evitar confundir tus visitantes con tus visitas hacia tu web.

Pues simplemente al estar usando por ejemplo un blog, el hecho de estar escribiendo un artículo desde el panel de WordPress, Analytics lo detecta como una visita y para evitar esto es necesario que excluyas tu IP.

Asi que veamos como lograrlo…

Averiguando cual es tu IP

Primero quenada, si no sabes cual es tu IP debes de averiguarlo, para ello puedes visitar What Is My IP Adress.

Ahí te aparecerá tu dirección IP.

Añadiendo un filtro

Una vez que sabemos cual es nuestra IP, debemos de entrar en la cuenta de Analytics.

Y en el perfil al que deseamos excluir nuestra IP, nos vamos en la sección Acciones y damos click en Editar (Haz click sobre la imagen para ampliarla)

Editar un perfil

Editar un perfil

Ahora nos situamos en el apartado Filtros y entonces damos click sobre Añadir nuevo filtro

Añadiendo un filtro

Añadiendo un filtro

Y es ahora cuando procedemos a configurar el filtro…

Configurando el filtro

Tendremos varios campos a llenar, así que empezemos:

Primero seleccionamos Añadir un filtro nuevo al perfil, luego, en Nombre del filtro escribimos algún nombre que nos permita identificarlo, en este caso lo llamo Excluir mi IP

Y ahora en Tipo de filtro escogemos Excluir todo el tráfico procedente de una dirección IP específica

En Dirección IP escribimos nuestra IP, recuerden colocar una barra invertida (\) antes de cada punto:

Crear un nuevo filtro

Crear un nuevo filtro

Y solo damos en Guardar cambios y podremos excluir nuestra IP

Más información sobre porque se añaden barras invertidas antes de los puntos

Mayo 30th, 2009 | 5 comentarios

Asesina clicks con el componente Accordion

Anteriormente expliqué como hacer uso del componente Accordion de Adobe Spry, ahora les explico como usarlo para asesinar clicks.

Esto luego de haber escuchado la conferencia de 20 consejos de usabilidad esenciales para proyectos web de F, y haber leído el artículo, en el que hablan del punto sobre “Asesina todos los clicks que puedas“, es por ello que con el fin de mejorar la usuabilidad de nuestro sitio para los usuarios podemos hecharle un vistaso al código JS (te recomiendo leas primero el tip anterior para que sepas de que archivo hablo).

En él veremos que se repite varias veces la palabra “click”, que corresponde al evento en el que el usuario clickeael panel para desplegarlo.

El truco es abrir nuestro editor de JS preferido, ya sea Dreamweaver, Notepad++ o el Bloc de notas (Windows) y luego presionar Ctrl+B si el programa esta en español ó Ctrl+F si esta en inglés; aunque en el caso del Bloc de notas es Ctrl+R.

Ahora vamos a buscar click y lo remplazaremos por MouseOver, presionamos Remplazar todos y listo, tenemos un Accordion que detecta el evento “MouseOver” en vez de “Click”.

Imagen 1

Imagen 1

Como ven es muy simple y fácil.

Mayo 30th, 2009 | Sin comentarios

Guardar tipografías de un documento de Word en si mismo para mantener el diseño

Seguro nos ha pasado que tal vez porque no tenemos impresora en casa, o la tinta ya se acabo vamos a algún cibercafé (café internet) a imprimir los documentos, pero por desgracia nos enteramos de que la tipografía con la que estaba escrito nuestro ensayo de 30 hojas sobre la botánica y el desarrollo de las plantas para la clase de biología del día que sigue no está instalada en la PC del ciber —Damn!—pensamos—¿Cómo puedo imprimir el maldito documento?—Bueno pues la respuesta es muy fácil: Incrustando la fuente en el documento para mantener su aspecto original.

Pero, ¿cómo logramos esto?, el truco sirve en Office 2007, no se si se puede en versiones anteriores pero aunque no lo dudo, no se donde se encuentre esta función.

Nos iremos al conocido botón de Office, en el borde inferior del menú desplegable, justo a la izquierda del botón “Salir de Word” (que por cierto jamás en mi vida le he dado click ¬¬) esta el botón “Opciones de Word”, le das click:

Imagen 1

Imagen 1

Y te vas a la sección “Guardar”, en el apartado “Mantener la fidelidad para este documento”, tendrás la opción de elegir si hacer lo mismo con todos los documentos o especificar alguno abierto, incrustar solo los caractéres usados para reducir el tamaño del documento y excluir las tipografías comunes:

Imagen 2

Imagen 2

Te recomiendo marques las 3 casillas, a excepción de que si vas a editar el documento en una PC que no tenga la fuente instalada desmarca la casilla de incrustar sólo los caractéres usados.

Esto va a aumentar el tamaño del documento, pero seguro que en algunos casos llega a ser muy útil ;)

Mayo 27th, 2009 | Sin comentarios

Cómo usar el componente Accordion de Adobe Spry

Ya hace un tiempo que empezé a interesarme por los widgets de Adobe Spry, y por ello escribí un pequeño tip en Cristalab sobre el uso del componente Accordion de Adobe Spry.

Lo comparto para un siguiente tip ;)

Introducción

Seguramente algunas vez visitamos el sitio web de Adobe, y una de las cosas que más nos llaman la atención es el efecto acordion que se usa para reducir el espacio necesario para mostrar alguna parte de nuestro sitio, y que en el caso de Adobe se usa para que en lugar de tener una tabla con 3 celdas en fila vertical, que corresponden a las secciones: Productos, Soluciones y Sectores; se pueda usar un acordion que al pasar el mouse sobre una sección, esta se expanda y al pasarlo sobre otra suceda lo mismo pero la anterior se vuelve a contraer.

Si no sabes a que me refiero puedes ver el efecto desde la web de Adobe.

¿Cómo es que nos ayuda este componente?

El componente Accordion (como se nombra en inglés) nos ayuda al momento de tener una gran cantidad de contenido que mostrar, como una lista de links recomendados o las categorías de nuestro blog o sitio, o simplemente para darle un aspecto más elegante a nuestro página web.

Acerca de

La versión de este componente usado en la página de Adobe es la 2007 (ó 2008 no recuerdo bien), la cual esta protegida por una licencia, por lo que sería un delito usarla sin permiso de Adobe.

Pero al menos se encuentra disponible la versión 2006 en estado libre, la cual usaremos para este tip, esta versión es posible descargarla desde Adobe Labs, pero para que te ahorres esta descarga, les dejo los códigos necesarios para su uso. La única desventaja es que se debe dar click sobre la sección para que se expanda.

Usar el componente

Pues luego de todo lo anterior procedamos a crear este efecto.
Primero que nada, al descargar el componente desde Adobe Labs tendríamos 3 archivos:

  • SpryAccordion.css
  • SpryAccordion.js
  • SpryAccordion.html

El primero es la hoja de estilos que define los colores entre otras cosas de cada panel.
El segundo es el que realiza prácticamente todo el trabajo sucio, es un código JavaScript.
El tercero es solo el documento HTML en el que se da el ejemplo para visualizarlo desde el navegador.

Antes de abrir el Dreamweaver debemos de crear una carpeta nueva dentro de cualquier lugar de nuestra PC, esta la llamaremos “Accordion”; solo para tener las cosas en un solo lugar.

Ahora si abrirmos el Dreamweaver (o incluso si no lo tienen basatará con usar el Bloc de notas) y creamos una nueva hoja de estilos en cascada (CSS)

Y agregamos el siguiente código:
@charset "UTF-8";
/* SpryAccordion.css - version 0.4 - Spry Pre-Release 1.6.1 */
/* Copyright (c) 2006. Adobe Systems Incorporated. All rights reserved. */
/* Aquí se define el estilo para el contenedor del Accordion. Como estilo
* predeterminado, se dibujan bordes por la izquierda, derecha y abajo. El borde
* de la parte de arriba se define por el primer panel en AccordionPanelTab, que
* es el de mero arriba, el que nunca se mueve.
*/
.Accordion {
border-left: solid 1px gray;
border-right: solid 1px black;
border-bottom: solid 1px gray;
overflow: hidden;
}
/* Aquí se define el AccordionPanel, es decir el panel que contiene todas
* las cosas que ponemos. Aunque no tiene ningún aspecto gráfico
* es necesario dejarlo en claro que debe de tener 0 en margin y padding.
*/
.AccordionPanel {
margin: 0px;
padding: 0px;
}
/* Aquí se define el AccordionPanelTab, la pestaña que lleva el título
* del panel y donde se detecta el click para abrir cualquier panel.
.AccordionPanelTab {
background-color: #333;
border-top: solid 1px black;
border-bottom: solid 1px gray;
margin: 0px;
padding: 2px;
cursor: pointer;
-moz-user-select: none;
-khtml-user-select: none;
font-size: 14px;
}
/* Aquí se define el AccordionPanelContent, donde se encuentra el contenido del panel.
* Es importante saber que no se debe de poner ningún padding nunca al area que
* del contenido del panel para usar las animaciones. Siempre se debe de poner 0px
* de padding, porque si no la altura de los paneles se cambian al animarse la expansión.
*
* Cualquiera que estilize un acordion, debe de establecer la altura en el
* contenedor con la clase "AccordionPanelContent"
*/
.AccordionPanelContent {
overflow: auto;
margin: 0px;
padding: 0px;
height: 200px;
color: #000;
}
/* Este es un ejemplo de como cambiar la apariencia de la pestaña de un panel abierto.
* La clase "AccordionPanelOpen" es agregada y removida a el panel según el usuario
* haga click sobre la pestaña del acordion.
*/
.AccordionPanelOpen .AccordionPanelTab {
background-color:#666;
font-size: 14px;
}
/* Este es un ejemplo de como cambiar la apariencia de la pestaña del panel cuando
* el mouse se coloca sobre ella. El nombre de clase "AccordionPanelTabHover" es
* agregada y removida de forma programada a las pestañas del panel en mientras el mouse
* haya abierto un panel. En este caso, yo configuré la CSS a mi gusto, y deje el mismo
* color (#CCC) para el panel abierto al hacerle over, que a los que quedan cerrados;
* pero si lo deseas puedes optar por cambiarlo.
*/
.AccordionPanelTabHover {
color: #CCC;
}
.AccordionPanelOpen .AccordionPanelTabHover {
color: #CCC;
}
/* Este es un ejemplo de como personalizar la apariencia de todas las pestañas del panel
/* mientras estemos enfocados en el Accordion. La clase "AccordionFocused" es agregada
/* y removida de forma programada al Accordion al detectarse que se use o no.
/* En esta ocasion también puse el mismo color (#333) al estar usandose o no el acordion.
/* pero si lo deseas puedes cambiarlo.
*/
.AccordionFocused .AccordionPanelTab {
background-color: #333;
}
/* Este es un ejemplo de como puede cambiarse la apariencia de la pestaña de panel que esta
/* abierto mientras el panel este en uso.
* Por cuestion de gustos también deje el color (#666) igual al estar en uso el acordion y
* al no estarlo
*/
.AccordionFocused .AccordionPanelOpen .AccordionPanelTab {
background-color: #666;
}

Iba a explicar cada función de las clases que se especifican, pero me di cuenta de que eran muchas y resultaría muy confuso buscarlas entre el código, así que la explicación la puse junto al código.
Nota: Es importante que leas los comentarios añadidos al código para que veas algunas reglas básicas en el diseño del componente, y su correcta función.

Con respecto a las siguientes clases:

  • .Accordion
  • .AccordionPanel
  • .AccordionPanelTab
  • .AccordionPanelContent

No es importante su nombre de clase para que el efecto funcione de forma correcta, puedes usar cualquier otro nombre de clase para darle estilo.

Y en todas las partes donde menciono que son solo ejemplos de personalizar el componente Accordion, son solo si queremos definir o personalizar mas el componente. Pero no es necesario que se haga uso de ellos.

En la definición de la clase .AccordionPanelTab se usan las propiedades “-moz-user-select” y “-khtml-user-select” para evitar que el usuario pueda seleccionar el texto en AccordionPanelTab (las pestañas del acordion). Esas propiedades de los navegadores solo funcionan en navegadores basados en Mozilla (como Firefox) y tambien en los que se basan en KHTML (como Safari), pero no pasan la validación de W3C. Si quieres usarlo y que sea válido el código, y no te importa si se puede seleccionar el texto que esta en las pestañas del acordion puedes remover esas 2 líneas, y no se dañará el componente ni sus funciones.

Dejando en claro todo lo anterior, y con nuestro código bien definido y/o corregido procedemos a guardar nuestro documento con el nombre: SpryAccordion y su respectiva extensión (.css)

Ahora procedamos al código JavaScript (JS), el cual posee una declaración sobre derechos de autor etcétera, etcétera, etcétera… en los comentarios. Por lo que les aviso que na vayan a usarlo sin cumplir sus condiciones, las cuales removí para el tip, pero que si desean modificarlo considero que deberán leer el código original desde aquí.

Con respecto al código JavaScript les tengo una mala noticia:

Por desgracia no se JavaScript T____T
Y me había propuesto darle un breve analisis al código a ver si entendía algo, pero con solo ver la extensión del código me dió miedo XD
Así que aquí se los dejo tal cual es (omitiendo lo de la declaración de derechos de autor).
Creamos un nuevo documento de JavaScript y pegamos el siguiente código:

// SpryAccordion.js - version 0.15 - Spry Pre-Release 1.6.1
//
// Copyright (c) 2006. Adobe Systems Incorporated.
// All rights reserved.

var Spry;
if (!Spry) Spry = {};
if (!Spry.Widget) Spry.Widget = {};

Spry.Widget.Accordion = function(element, opts)
{
this.element = this.getElement(element);
this.defaultPanel = 0;
this.hoverClass = "AccordionPanelTabHover";
this.openClass = "AccordionPanelOpen";
this.closedClass = "AccordionPanelClosed";
this.focusedClass = "AccordionFocused";
this.enableAnimation = true;
this.enableKeyboardNavigation = true;
this.currentPanel = null;
this.animator = null;
this.hasFocus = null;

this.previousPanelKeyCode = Spry.Widget.Accordion.KEY_UP;
this.nextPanelKeyCode = Spry.Widget.Accordion.KEY_DOWN;

this.useFixedPanelHeights = true;
this.fixedPanelHeight = 0;

Spry.Widget.Accordion.setOptions(this, opts, true);

this.attachBehaviors();
};

Spry.Widget.Accordion.prototype.getElement = function(ele)
{
if (ele && typeof ele == "string")
return document.getElementById(ele);
return ele;
};

Spry.Widget.Accordion.prototype.addClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) != -1))
return;
ele.className += (ele.className ? " " : "") + className;
};

Spry.Widget.Accordion.prototype.removeClassName = function(ele, className)
{
if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) == -1))
return;
ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), "");
};

Spry.Widget.Accordion.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
if (!optionsObj)
return;
for (var optionName in optionsObj)
{
if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
continue;
obj[optionName] = optionsObj[optionName];
}
};

Spry.Widget.Accordion.prototype.onPanelTabMouseOver = function(e, panel)
{
if (panel)
this.addClassName(this.getPanelTab(panel), this.hoverClass);
return false;
};

Spry.Widget.Accordion.prototype.onPanelTabMouseOut = function(e, panel)
{
if (panel)
this.removeClassName(this.getPanelTab(panel), this.hoverClass);
return false;
};

Spry.Widget.Accordion.prototype.openPanel = function(elementOrIndex)
{
var panelA = this.currentPanel;
var panelB;

if (typeof elementOrIndex == "number")
panelB = this.getPanels()[elementOrIndex];
else
panelB = this.getElement(elementOrIndex);

if (!panelB || panelA == panelB)
return null;

var contentA = panelA ? this.getPanelContent(panelA) : null;
var contentB = this.getPanelContent(panelB);

if (!contentB)
return null;

if (this.useFixedPanelHeights && !this.fixedPanelHeight)
this.fixedPanelHeight = (contentA.offsetHeight) ? contentA.offsetHeight : contentA.scrollHeight;

if (this.enableAnimation)
{
if (this.animator)
this.animator.stop();
this.animator = new Spry.Widget.Accordion.PanelAnimator(this, panelB, { duration: this.duration, fps: this.fps, transition: this.transition });
this.animator.start();
}
else
{
if(contentA)
{
contentA.style.display = "none";
contentA.style.height = "0px";
}
contentB.style.display = "block";
contentB.style.height = this.useFixedPanelHeights ? this.fixedPanelHeight + "px" : "auto";
}

if(panelA)
{
this.removeClassName(panelA, this.openClass);
this.addClassName(panelA, this.closedClass);
}

this.removeClassName(panelB, this.closedClass);
this.addClassName(panelB, this.openClass);

this.currentPanel = panelB;

return panelB;
};

Spry.Widget.Accordion.prototype.closePanel = function()
{
// The accordion can only ever have one panel open at any
// give time, so this method only closes the current panel.
// If the accordion is in fixed panel heights mode, this
// method does nothing.

if (!this.useFixedPanelHeights && this.currentPanel)
{
var panel = this.currentPanel;
var content = this.getPanelContent(panel);
if (content)
{
if (this.enableAnimation)
{
if (this.animator)
this.animator.stop();
this.animator = new Spry.Widget.Accordion.PanelAnimator(this, null, { duration: this.duration, fps: this.fps, transition: this.transition });
this.animator.start();
}
else
{
content.style.display = "none";
content.style.height = "0px";
}
}
this.removeClassName(panel, this.openClass);
this.addClassName(panel, this.closedClass);
this.currentPanel = null;
}
};

Spry.Widget.Accordion.prototype.openNextPanel = function()
{
return this.openPanel(this.getCurrentPanelIndex() + 1);
};

Spry.Widget.Accordion.prototype.openPreviousPanel = function()
{
return this.openPanel(this.getCurrentPanelIndex() - 1);
};

Spry.Widget.Accordion.prototype.openFirstPanel = function()
{
return this.openPanel(0);
};

Spry.Widget.Accordion.prototype.openLastPanel = function()
{
var panels = this.getPanels();
return this.openPanel(panels[panels.length - 1]);
};

Spry.Widget.Accordion.prototype.onPanelTabClick = function(e, panel)
{
if (panel != this.currentPanel)
this.openPanel(panel);
else
this.closePanel();

if (this.enableKeyboardNavigation)
this.focus();

if (e.preventDefault) e.preventDefault();
else e.returnValue = false;
if (e.stopPropagation) e.stopPropagation();
else e.cancelBubble = true;

return false;
};

Spry.Widget.Accordion.prototype.onFocus = function(e)
{
this.hasFocus = true;
this.addClassName(this.element, this.focusedClass);
return false;
};

Spry.Widget.Accordion.prototype.onBlur = function(e)
{
this.hasFocus = false;
this.removeClassName(this.element, this.focusedClass);
return false;
};

Spry.Widget.Accordion.KEY_UP = 38;
Spry.Widget.Accordion.KEY_DOWN = 40;

Spry.Widget.Accordion.prototype.onKeyDown = function(e)
{
var key = e.keyCode;
if (!this.hasFocus || (key != this.previousPanelKeyCode && key != this.nextPanelKeyCode))
return true;

var panels = this.getPanels();
if (!panels || panels.length < 1)
return false;
var currentPanel = this.currentPanel ? this.currentPanel : panels[0];
var nextPanel = (key == this.nextPanelKeyCode) ? currentPanel.nextSibling : currentPanel.previousSibling;

while (nextPanel)
{
if (nextPanel.nodeType == 1 /* Node.ELEMENT_NODE */)
break;
nextPanel = (key == this.nextPanelKeyCode) ? nextPanel.nextSibling : nextPanel.previousSibling;
}

if (nextPanel && currentPanel != nextPanel)
this.openPanel(nextPanel);

if (e.preventDefault) e.preventDefault();
else e.returnValue = false;
if (e.stopPropagation) e.stopPropagation();
else e.cancelBubble = true;

return false;
};

Spry.Widget.Accordion.prototype.attachPanelHandlers = function(panel)
{
if (!panel)
return;

var tab = this.getPanelTab(panel);

if (tab)
{
var self = this;
Spry.Widget.Accordion.addEventListener(tab, "click", function(e) { return self.onPanelTabClick(e, panel); }, false);
Spry.Widget.Accordion.addEventListener(tab, "mouseover", function(e) { return self.onPanelTabMouseOver(e, panel); }, false);
Spry.Widget.Accordion.addEventListener(tab, "mouseout", function(e) { return self.onPanelTabMouseOut(e, panel); }, false);
}
};

Spry.Widget.Accordion.addEventListener = function(element, eventType, handler, capture)
{
try
{
if (element.addEventListener)
element.addEventListener(eventType, handler, capture);
else if (element.attachEvent)
element.attachEvent("on" + eventType, handler);
}
catch (e) {}
};

Spry.Widget.Accordion.prototype.initPanel = function(panel, isDefault)
{
var content = this.getPanelContent(panel);
if (isDefault)
{
this.currentPanel = panel;
this.removeClassName(panel, this.closedClass);
this.addClassName(panel, this.openClass);

// Attempt to set up the height of the default panel. We don't want to
// do any dynamic panel height calculations here because our accordion
// or one of its parent containers may be display:none.

if (content)
{
if (this.useFixedPanelHeights)
{
// We are in fixed panel height mode and the user passed in
// a panel height for us to use.

if (this.fixedPanelHeight)
content.style.height = this.fixedPanelHeight + "px";
}
else
{
// We are in variable panel height mode, but since we can't
// calculate the panel height here, we just set the height to
// auto so that it expands to show all of its content.

content.style.height = "auto";
}
}
}
else
{
this.removeClassName(panel, this.openClass);
this.addClassName(panel, this.closedClass);

if (content)
{
content.style.height = "0px";
content.style.display = "none";
}
}

this.attachPanelHandlers(panel);
};

Spry.Widget.Accordion.prototype.attachBehaviors = function()
{
var panels = this.getPanels();
for (var i = 0; i < panels.length; i++)
this.initPanel(panels[i], i == this.defaultPanel);

// Advanced keyboard navigation requires the tabindex attribute
// on the top-level element.

this.enableKeyboardNavigation = (this.enableKeyboardNavigation && this.element.attributes.getNamedItem("tabindex"));
if (this.enableKeyboardNavigation)
{
var self = this;
Spry.Widget.Accordion.addEventListener(this.element, "focus", function(e) { return self.onFocus(e); }, false);
Spry.Widget.Accordion.addEventListener(this.element, "blur", function(e) { return self.onBlur(e); }, false);
Spry.Widget.Accordion.addEventListener(this.element, "keydown", function(e) { return self.onKeyDown(e); }, false);
}
};

Spry.Widget.Accordion.prototype.getPanels = function()
{
return this.getElementChildren(this.element);
};

Spry.Widget.Accordion.prototype.getCurrentPanel = function()
{
return this.currentPanel;
};

Spry.Widget.Accordion.prototype.getPanelIndex = function(panel)
{
var panels = this.getPanels();
for( var i = 0 ; i < panels.length; i++ )
{
if( panel == panels[i] )
return i;
}
return -1;
};

Spry.Widget.Accordion.prototype.getCurrentPanelIndex = function()
{
return this.getPanelIndex(this.currentPanel);
};

Spry.Widget.Accordion.prototype.getPanelTab = function(panel)
{
if (!panel)
return null;
return this.getElementChildren(panel)[0];
};

Spry.Widget.Accordion.prototype.getPanelContent = function(panel)
{
if (!panel)
return null;
return this.getElementChildren(panel)[1];
};

Spry.Widget.Accordion.prototype.getElementChildren = function(element)
{
var children = [];
var child = element.firstChild;
while (child)
{
if (child.nodeType == 1 /* Node.ELEMENT_NODE */)
children.push(child);
child = child.nextSibling;
}
return children;
};

Spry.Widget.Accordion.prototype.focus = function()
{
if (this.element && this.element.focus)
this.element.focus();
};

Spry.Widget.Accordion.prototype.blur = function()
{
if (this.element && this.element.blur)
this.element.blur();
};

/////////////////////////////////////////////////////

Spry.Widget.Accordion.PanelAnimator = function(accordion, panel, opts)
{
this.timer = null;
this.interval = 0;

this.fps = 60;
this.duration = 500;
this.startTime = 0;

this.transition = Spry.Widget.Accordion.PanelAnimator.defaultTransition;

this.onComplete = null;

this.panel = panel;
this.panelToOpen = accordion.getElement(panel);
this.panelData = [];
this.useFixedPanelHeights = accordion.useFixedPanelHeights;

Spry.Widget.Accordion.setOptions(this, opts, true);

this.interval = Math.floor(1000 / this.fps);

// Set up the array of panels we want to animate.

var panels = accordion.getPanels();
for (var i = 0; i < panels.length; i++)
{
var p = panels[i];
var c = accordion.getPanelContent(p);
if (c)
{
var h = c.offsetHeight;
if (h == undefined)
h = 0;

if (p == panel && h == 0)
c.style.display = "block";

if (p == panel || h > 0)
{
var obj = new Object;
obj.panel = p;
obj.content = c;
obj.fromHeight = h;
obj.toHeight = (p == panel) ? (accordion.useFixedPanelHeights ? accordion.fixedPanelHeight : c.scrollHeight) : 0;
obj.distance = obj.toHeight - obj.fromHeight;
obj.overflow = c.style.overflow;
this.panelData.push(obj);

c.style.overflow = "hidden";
c.style.height = h + "px";
}
}
}
};

Spry.Widget.Accordion.PanelAnimator.defaultTransition = function(time, begin, finish, duration) { time /= duration; return begin + ((2 - time) * time * finish); };

Spry.Widget.Accordion.PanelAnimator.prototype.start = function()
{
var self = this;
this.startTime = (new Date).getTime();
this.timer = setTimeout(function() { self.stepAnimation(); }, this.interval);
};

Spry.Widget.Accordion.PanelAnimator.prototype.stop = function()
{
if (this.timer)
{
clearTimeout(this.timer);

// If we're killing the timer, restore the overflow
// properties on the panels we were animating!

for (i = 0; i < this.panelData.length; i++)
{
obj = this.panelData[i];
obj.content.style.overflow = obj.overflow;
}
}

this.timer = null;
};

Spry.Widget.Accordion.PanelAnimator.prototype.stepAnimation = function()
{
var curTime = (new Date).getTime();
var elapsedTime = curTime - this.startTime;

var i, obj;

if (elapsedTime >= this.duration)
{
for (i = 0; i < this.panelData.length; i++)
{
obj = this.panelData[i];
if (obj.panel != this.panel)
{
obj.content.style.display = "none";
obj.content.style.height = "0px";
}
obj.content.style.overflow = obj.overflow;
obj.content.style.height = (this.useFixedPanelHeights || obj.toHeight == 0) ? obj.toHeight + "px" : "auto";
}
if (this.onComplete)
this.onComplete();
return;
}

for (i = 0; i < this.panelData.length; i++)
{
obj = this.panelData[i];
var ht = this.transition(elapsedTime, obj.fromHeight, obj.distance, this.duration);
obj.content.style.height = ((ht < 0) ? 0 : ht) + "px";
}

var self = this;
this.timer = setTimeout(function() { self.stepAnimation(); }, this.interval);
};

Lo guardamos como SpryAccordion con la extensión de un código JavaScript (.js)

Pues ahora pasemos al documento HTML.
Creamos un nuevo documento HTML, y pegamos el siguiente código:

<!-- Copyright (c) 2006. Adobe Systems Incorporated. All rights reserved. -->

<!-- inicia referencia al código JavaScript del componente Accordion -->
<script src="SpryAccordion.js" type="text/javascript"><!--mce:0--></script>
<!-- termina referencia al código JavaScript del componente Accordion -->
<!-- inicia referencia a la hoja de estilos en cascada -->

<!-- termina referencia a la hoja de estilos en cascada -->
<!-- inicia definición de estilos de la tipografía del documento HTML -->
<!--
body,td,th {
font-family: Trebuchet MS, Arial, Helvetica, sans-serif;
font-size: 12px;
color: #FFF;
}
-->

<!-- termina definición de estilos de la tipografía del documento HTML -->

<!-- inicia el acordeon -->
<div id="sampleAccordion" class="Accordion">
<!-- empieza el panel 1 -->
<div class="AccordionPanel">
<!-- empieza la pestaña -->
<div class="AccordionPanelTab">Panel 1</div>
<!-- termina la pestaña -->
<!-- empieza el contenido del panel -->
<div class="AccordionPanelContent">
Aquí va el contenido del panel 1</div>
<!-- termina el contenido del panel --></div>
<!-- termina el panel 1 -->
<!-- Así como fue el panel 1, se definen todos los demás -->
<div class="AccordionPanel">
<div class="AccordionPanelTab">Panel 2</div>
<div class="AccordionPanelContent">
Aquí va el contenido del panel 2</div>
</div>
<div class="AccordionPanel">
<div class="AccordionPanelTab">Panel 3</div>
<div class="AccordionPanelContent">
Aquí va el contenido del panel 3</div>
</div>
<div class="AccordionPanel">
<div class="AccordionPanelTab">Panel 4</div>
<div class="AccordionPanelContent">
Aquí va el contenido del panel 4</div>
</div>
<!-- por último se cierra el acordeon --></div>
<!-- como ya dije no se JS,así que no explico nada -->
<script type="text/javascript"><!--mce:1--></script>

Guardamos el archivo como SpryAccordion con la extensión (.html)
El código también lo explico en él.
Puedes ver el resultado final
Para más información puedes entrar a Adobe Labs > Accordion Widget

Descargar archivos (.RAR)
Descargar archivos (.ZIP)

Mayo 21st, 2009 | Sin comentarios

Vaciar un textField al enfocarse en él

Un textField ó campo de texto no es mas que un elemente más de los demás que se pueden aplicar a un formulario en HTML, estos elementos suelen tener un valor inicial, el cual solo se puede borrar al entrar ó enfocarse (focus) en el elemento, seleccionar el texto y luego borrarlo como cualquier otro texto.

Vaciar un textField al enfocarse en el

Vaciar un textField al enfocarse en el

Lo que trato de enseñar en este tip de HTML, es como usar el parámetro “onFocus” para aplicarlo a un campo de texto de tal forma que el enfocarse sobre él, éste se vacíe.

Esto puede parecer muy insignificante, pero sin duda es otro pequeño detalle que podría hacer más usable nuestro sitio, puesto que supongo que todos prefirieramos que el campo de texto se vaciara al hacer click sobre el, en lugar de tener que seleccionar el texto y luego borrarlo para por fin poder escribir.

Como ejemplo tomaré un formulario de motor de búsqueda de mi blog de WordPress; el código sería este:
<form id="buscar" action="http://www.ray-page.site40.net/" method="get">
<input id="t" name="s" type="text" value="Buscar" />
<input id="b" type="submit" value=" " />
</form>

Para evitar tanto código solo puse el de el formulario, ignoremos todas las etiquetas, con excepción de esta:
<input id="t" name="s" type="text" value="Buscar" />
Como ven el valor predeterminado del campo de búsqueda es “Buscar”, y para que al enfocarnos en el textField éste se vacíe solo agregamos este parámetro a su etiqueta:
onfocus="if (this.value == 'Buscar') {this.value = '';}"
Muy fácil de comprender ¿cierto?
Literalmente lo leemos así, “Al enfocarse, si el valor de esto es Buscar, el valor será *nada*”

Con esto bastará para que el campo se vacíe sin necesidad de usar scripts externos no nada de eso.

Pero si ahora buscamos que al desenfocarse ó salirse del elemento, éste se vuelva a rellenar con el texto “Buscar”, en el mismo elemento agregamos esta línea:
onblur="if (this.value == '') {this.value = 'Buscar';}"
Y lo leemos así, “Al desenfocarse, si el valor de esto es *nada*, el valor será Buscar”

Con esto tenemos una caja de búsqueda más usable ^_____^
<input id="t" name="s" type="text" value="Buscar" />
Como ven es algo muy pequeño, pero que sin duda vuelve ligeramente más usable tu sitio.