Design Maturity Model
July 23rd, 2008
La noción de aplicar diseño a los desarrollos de software cada día es más importante, pero como todo, requiere un proceso de adaptación, capacitación y descubrimiento.
El Design Maturity Model propuesto por Jess McMullin describe cinco niveles y sus respectivos comportamientos ante el diseño para poder guiarnos en el camino de una correcta incorporación del mismo en nuestros procesos de desarrollo y detectar en que estadio de madurez nos encontramos.
Nivel 1 – No somos conscientes del diseño
- El diseño no se reconoce como algo de valor
- Se “diseña” sin ningún fundamento
- El diseño se deja de lado por cosas más “importantes”
Nivel 2 – Style
- El diseño es añadido solamente para ser “cool” o para seguir alguna tendencia
- El diseño es algo que se agrega a último minuto para añadir funciones meramente estéticas
Nivel 3 - Forma y Función
- Se implementa el diseño para mejorar ciertas funcionalidades
- Se utiliza de forma limitada para agregar pequeños incrementos de funcionalidad en aplicaciones en desarrollo o existentes
Nivel 4 – Diseño como una forma de resolver problemas
- El diseño nos permite encontrar nuevas oportunidades para resolver problemas existentes
- El diseño nos permite acotar las opciones para atacar un problema específico
Nivel 5 – Totalmente orientados al diseño
- El diseño redefine los desafíos que enfrenta la organización
- El diseño establece el orden del día
- El diseño forma parte de toda estrategia
- La innovación está inmersa en la cultura
Esta es mi interpretación del DMM, espero les sirva para saber en cual nivel están parados en la actualidad y si no están aplicando el diseño los ayude a tomar conciencia.
Integrando YUI con ASP.NET MVC
July 14th, 2008
Si han estado trabajando o al menos le han dado una mirada al ASP.NET MVC framework, sabrán que a diferencia del ASP.NET tradicional, no se encuentran disponibles al menos de momento controles como por ejemplo el GridView, este vacío lo podemos llenar con una gran cantidad de controles de terceros que fueron creados para trabajar sobre alguna de las diversas librerías JavaScript que hay en este momento dando vueltas, una de las mejores y más completas librerías a mi entender es YUI (The Yahoo! User Interface Library) , la misma viene repleta de controles y una excelente documentación, que hacen que su implementación sea algo relativamente sencillo.
Para mostrar lo fácil que es integrar YUI a nuestras soluciones ASP.NET MVC, vamos a crear una aplicación de ejemplo en el que utilizaremos los controles DataSource y DataTable de YUI para consumir un feed Json creado con el nuevo JsonResult.
Para comenzar empezaremos con el código del Controller.
public JsonResult GetPlayersList()
{
OranjeDataContext ctx = new OranjeDataContext();
var data = (from player in ctx.Players
select player).ToList<Player>();
return this.Json(new {players = data.ToArray() }, “text/html”);
}
En el podrán observar que estoy utilizando el nuevo JsonResult que es un nuevo tipo de ActionResult que nos permite serializar la salida en formato Json, lo demás es solo una query LinqToSql y un poco de formateo en la forma de exponer el código Json, ya que la DataTable de YUI espera recibir la data de la siguiente manera.
Notaran que antes de la data propiamente dicha la DataTable de YUI espera obtener el nombre de la entidad expuesta.
Bien, el siguiente paso es consumir la data en la View, para ello lo primero que haremos será crear las referencias a los archivos JavaScript necesarios, para ello pueden utilizar el YUI Dependency Configurator, el cual indicándole los controles a implementar nos indicara los archivos que debemos utilizar.
Lo siguiente es consumir la data, para ello deberemos de incluir el siguiente código en la vista.
<script type=”text/javascript” language=”javascript”>
YAHOO.util.Event.addListener(window,“load”, function()
{
YAHOO.example.PopulateGrid = new function() {
var myColumnDefs = [{key:"PlayerId",label:"Id"}, {key:"Name"},{key:"Number"},{key:"Age"},{key:"Caps"},];
this.myDataSource= new YAHOO.util.DataSource(“Home/GetPlayersList?”);
this.myDataSource.responseType= YAHOO.util.DataSource.TYPE_JSON;
this.myDataSource.responseSchema= {resultsList: “players”,fields:["PlayerId","Name","Number","Age","Caps"]};
this.myDataTable= new YAHOO.widget.DataTable(“myGrid”, myColumnDefs, this.myDataSource);
};
});
</script>
<div id=”myGrid”></div>
En el podrán observar que creamos un evento que se dispara cuando se carga la vista, luego hay una función en la cual definimos las columnas a utilizar por nuestro DataTable, configuramos el DataSource el cual referencia al método que devuelve el Json serializado desde el Controller, a continuacion seleccionamos los campos de la entidad que utilizaremos y por ultimo creamos el DataTable al cual le pasamos los valores antes asignados mas el Id del elemento HTML en el cual queremos que se cree.
Si todo sale bien, deberían de ver en el browser algo parecido a lo que se aprecia en la imagen siguiente, en la misma también podrán notar la salida del JsonResult.
Aquí concluye este ejemplo, si desean seguir investigando la gran cantidad de características que se incluyen en el control DataTable, como así también los demás controles que forman parte de YUI lo pueden hacer en los siguientes links.
Buenas prácticas y recursos para la creación de formularios
July 8th, 2008
La creación de formularios es una tarea rutinaria tanto si estamos trabajando en desarrollos para la web como para el desktop, este post trata de aportar algunas buenas prácticas y recursos para la creación de formularios altamente usables y efectivos.
Muchos de los lineamientos descriptos a continuación se basan en estudios de usabilidad, estos estudios hacen uso intensivo de técnicas de eye-tracking para recolectar información acerca de cómo el usuario interactúa con la aplicación.
El eye-tracking es una técnica que mediante equipos especializados permite seguir los movimientos de los ojos de los usuarios para determinar las aéreas en las que fija su atención, cuánto tiempo pasa en ellas y como “navegan” la aplicación.
En esta imagen pueden apreciar a un usuario probando una aplicación web mientras es monitoreado.
Una vez recolectada la data del eye-tracking es posible crear los llamados “heat maps” o “mapas de calor“donde es posible apreciar como el usuario interactuó con la aplicación, normalmente esto se hace coloreando las aéreas de la aplicación con una paleta que va del rojo para las zonas donde más atención se prestó hasta el verde pasando por el amarillo que son las zonas menos observadas por el usuario.
Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. http://www.rosenfeldmedia.com/books/webforms/
El uso de estas herramientas y técnicas aplicadas a la creación de formularios llevo a ciertas conclusiones, que permiten mejorar la usabilidad de los mismos dependiendo de la alineación y disposición de los elementos que conforman el formulario.
Top Aligned Labels
El uso de labels ubicadas por sobre el textbox es recomendable cuando las data a ingresar por el usuario es familiar, esta práctica acelera los tiempos en los cuales se completa el formulario, pero tiene como contra que necesita más espacio vertical, algo a tener en cuenta es el espacio y el contraste entre los diferentes elementos para así lograr una navegación fluida por parte del usuario.
En esta imagen pueden ver el comportamiento del usuario frente a este tipo de disposición.

Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. http://www.rosenfeldmedia.com/books/webforms/
Right Aligned Labels
Alinear a la derecha los labels en los formularios es recomendable cuando se quiere mostrar una clara asociacion entre el label y su correspondiente textbox, esta técnica requiere menos espacio vertical, pero tiene la contra de que cuando los largos de los labels son muy dispares pueden hacer un poco dificultoso el escaneo de los elementos, en la siguiente imagen pueden ver un ejemplo de esta disposición y como el usuario reacciona al utilizarla.
Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. http://www.rosenfeldmedia.com/books/webforms/
Left Aligned Labels
Situar los labels alineados a la izquierda de los texboxs se recomienda cuando los datos a ingresar no son familiares por el usuario, esto es porque el moviente entre el label y el textbox es mayor y es posible utilizar esta desventaja a nuestro favor para que el usuario preste más atención, esto se puede apreciar mucho mejor en la siguiente imagen, en la cual notaran que la cantidad de pasos es mayor, como así también el diámetro de los puntos lo cual indica que se paso más tiempo posicionado en esa área, esta técnica también es más eficiente en el uso del espacio vertical.
Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. http://www.rosenfeldmedia.com/books/webforms/
Para seguir ahondando en estos temas les recomiendo la lectura del libro Web Form Design
Filling in the Blanks de Luke Wroblewski publicado por Rosenfeld Media, o de los siguientes enlaces.
La aportación del eyetracking en el sector de usabilidad
Eye-Tracking en Interacción Persona-Ordenador
Label Placement in Forms
Web Application Form Design





