Lo que entendemos por diseño
Cuando escribí el artículo «Algunos apuntes sobre diseño», en agosto de 2000, recibí numerosos comentarios. Por un lado, los amigos y conocidos vinculados al diseño, que criticaron duramente el llamado a no utilizar a discreción las nuevas tecnologías, el llamado a un diseño casi Franciscano. Por otro lado, recibí algunos mensajes de aliento y algún comentario del estilo: «usted me ayudó a decir que no a esa introducción Flash que mi diseñador le quería poner al sitio. Realmente yo no me animaba a decirle que no, y su artículo me dio los argumentos y la fuerza».
Esa dicotomía en los comentarios, me llevó a tratar de encontrar más información y elaboración sobre el tema. Como todo en Internet, por cada hoja de información útil, existen mil hojas llenas de lugares comunes, frases hechas e información absolutamente descartable. Después de mucho buscar llegué a 2 libros que recomiendo leer, y que son la base del presente artículo: Presos de la Tecnología, de Alan Cooper y Usabilidad. Diseño de sitios Web, de Jakob Nielsen. El primero aborda el problema del proceso de diseño y el segundo el problema de como analizar el uso de un diseño. Ambos tienen una premisa en común: en el mundo informático en general y en la Web en particular, los diseños son en su mayoría pésimos. Y ambos coinciden al tratar de identificar las causas: el usuario es el principal olvidado.
Después de mucho buscar llegué a 2 libros que recomiendo leer, y que son la base del presente artículo: Presos de la Tecnología, de Alan Cooper y Usabilidad. Diseño de sitios Web, de Jakob Nielsen.
Diseñar es una actividad que nació mucho antes que la informática y que se ha dividido en numerosas ramas del saber y de la actividad profesional. El diseño en informática, no coincide con ninguna de ellas. No se trata de diseño artístico en ninguna de sus facetas. Tal vez en algún aspecto secundario el diseño artístico sea importante para el diseño informático, pero el tronco, el corazón del diseño en informática, no se trata de diseño artístico. Tampoco es diseño gráfico, ni es diseño industrial. El diseño informático es el proceso de análisis y creación de la interacción de los sistemas de computación con los seres humanos que los usan y la experiencia de éstos al utilizarlos. Es el diseño de la experiencia de la persona que usa el sistema, no es el diseño de la apariencia del sistema.
El diseño informático es el proceso de análisis y creación de la interacción de los sistemas de computación con los seres humanos que los usan y la experiencia de éstos al utilizarlos.
Cuando escribí el artículo anterior, no conocía esta definición, que me parece mucho más exacta y útil que la que utilicé anteriormente.
La experiencia de los usuarios
Es muy difícil negar que la experiencia de los usuarios con las computadoras es nefasta. A los programadores (y yo me cuento con gusto en las huestes de los programadores) nos duele asumir esta realidad.
Es muy difícil negar que la experiencia de los usuarios con las computadoras es nefasta.
Pero que en el mundo moderno muchas tareas los obliguen a utilizar computadoras, no quiere decir que la tarea sea gratificante. Las pantallas están llenas de decenas de botones que el 90% de los usuarios no sabe para que sirven, ni sabe porque están, ni sabe como sacarlos. Y a medida que los distintos equipos industriales y aparatos domésticos incorporan microprocesadores, comienzan a comportarse de la misma forma desagradable y arrogante que se comporta el software. Así el microondas, el video, el lavarropas, el despertador y otros aparatos otrora intuitivos y sencillos se han transformado en verdaderos desafíos. El 90% de los botones y funciones no se usan para nada. No solo el grupo de los capaces de dejar el video pronto para grabar un programa es muy pequeño con respecto a los usuarios de videograbadoras, dentro de ese grupo, los que jamás grabaron un programa equivocado, o un día equivocado, son casi un conjunto vacío.
El cajero automático
¿Conoce usted algún aparato más tosco y arrogante que el cajero automático?
Comencemos por el principio: si yo no tengo cuenta corriente, ¿porqué tengo que contestar cada vez que lo utilizo la opción entre caja de ahorro y cuenta corriente? Y sin embargo el muy maldito lo sabe: si yo me equivoco, él se da cuenta, porque conoce perfectamente que yo no tengo cuenta corriente y me castigará duramente: como en el Juego de la Oca, caí en la casilla roja, que me manda nuevamente al comienzo. ¿Y su caja de ahorro es en pesos o en dólares?
¿Cuanto dinero quiere retirar? Recuerde que tiene que ser múltiplos de cien. Primero, si tiene que ser múltiplos de cien, podría por ejemplo, adelantar los dos ceros y no obligarme a poner hasta los centésimos (y si me equivoco, otra vez casilla roja!!!). Segundo: ¿por qué no me indica cuanto puedo sacar? el maldito lo sabe, jamás me dejará sacar un centésimo más de lo que tengo, pero no me lo dice. No me lo dice ni siquiera cuando me informa: «Ha excedido el limite de retiro». Castigo!!! Casilla roja!!! Vuelva a empezar. El sabe cuanto es, pero se lo guarda.
Nadie pensó en la interacción del usuario con el cajero cuando diseñó el sistema. Nadie se preguntó por qué esa persona está allí, qué busca, cuáles son sus objetivos, y cómo se siente al interactuar con el cajero automático.
Tal vez esa sea la causa de que a pesar de la inversión y los años que han pasado, los cajeros sigan en la mayoría aplastante de los casos, desempeñando la misma y única función que el día que los introdujeron: retiros, sin haber cumplido la promesa de permitir que las personas realicen la mayoría de las transacciones fuera de las sucursales.
La alarma del auto
Debe haber pocas situaciones que lo hacen sentir a uno tan tonto como cuando abre la puerta de su propio auto y comienza a sonar la alarma. Una de estas situaciones que lo hacen sentir a uno aún más tonto es dejar las llaves dentro del auto y cerrarlo, y sin duda la situación culminante es la combinación de ambas: la alarma activada y las llaves con el control dentro del auto, y éste cerrado.
La combinación bloqueo automático+alarma con control remoto, en su funcionamiento básico podrían evitar prácticamente en su totalidad estas situaciones. Cuando se trancan las puertas se prende la alarma, cuando se destrancan las puertas se apaga la alarma y ambas operaciones se realizan solamente con las puertas cerradas y con el control remoto de la alarma. Lo desafío a encontrar una situación en la que la alarma suene por otro motivo que no sea su fin específico, detectar un robo. Es fácil prever un estacionamiento de supermercado donde no suenen permanentemente las alarmas.
Sin embargo la realidad es muy distinta. Los programadores, como tenemos un microprocesador disponible, nos empecinamos en agregar «inteligencia» que lo único que hace es comprender situaciones de borde, que se dan una de cada cien mil veces, y que tienen como consecuencia inmediata un estacionamiento lleno de alarmas sonando y una cantidad de conductores humillados.
Diseño y Funcionalidad
Está ampliamente difundida la idea de que cuanto más funciones tiene un sistema, más útil será para los usuarios. Esta afirmación es en esencia falsa y es fácil comprobarlo. Por ejemplo, la mayoría aplastante de las funciones disponibles en el software de productividad personal (procesadores de texto, planillas electrónicas, etc.) no solo no son utilizadas por la mayoría de los usuarios. Ni siquiera sabe que existen. ¿Cuántas personas conoce que sepan que son los estilos de su procesador de texto, o que alguna vez hayan creado una tabla de contenidos utilizando la función del menú y no a mano?
Otro problema de las funciones es que en muchos casos, agregar funcionalidad no mejora sino que empeora el problema. Si la interacción es oscura, dura, frustrante, agregar funcionalidad hará que en vez de ignorar el 75% de las funciones, ahora ignore el 85% de las funciones, pero además que el 15% que se usa, sea aún más oscuro, los botones más chiquitos, los menúes más largos, el área de la pantalla utilizable más pequeño.
La función Guardar
Analicemos por ejemplo la función «Guardar». Esta función responde a un problema de diseño interno de la mayoría de las computadoras. Existen dos tipos de memoria: la memoria RAM, de acceso rápido y volátil, y el almacenamiento en discos, de acceso lento pero persistente. Debido a ésto, desde el principio de los lenguajes de programación y sistemas operativos, éstos proveen funciones al programador para trasladar información de un sistema de memoria al otro de modo de poder hacer que los programas ejecuten eficientemente, y cumplan con la necesidad de guardar la información almacenada en memoria RAM para que se transforme en información persistente al apagado del equipo. El corazón de las funciones que manejan internamente esta problemática, tienen desde el comienzo los mismos nombres que hoy utilizan habitualmente los usuarios: Abrir, Guardar y Cerrar. (Open, Save or Flush, Close).
Sin embargo, desde el punto de vista del usuario, que internamente el equipo tenga memoria RAM, ROM, discos ópticos, magnéticos, o ranas y gatos, es exactamente lo mismo. Si bien fue aceptable que al grupo selectos de técnicos que comenzaron hace 50 años a utilizar computadoras, en el curso de capacitación se les instruyera sobre esta limitación interna de los equipos, no tiene ningún asidero cincuenta años después seguir obligando a los usuarios a entender esta diferencia para poder sobrevivir. Si alguna vez intentó explicar la noción de Guardar a un simple mortal, sabe de que hablo. El resultado es obvio, aunque pocos hablen de él y los que nos animamos lo hagamos con vergüenza: los usuarios se sienten humillados porque sistemáticamente pierden su trabajo. «Guardan» uno sobre otro, destruyendo inadvertidamente cosas que no querían o llenan sus discos de decenas de archivos sin después saber cual es cual.
La primera solución es llenar la interfaz de diálogos que preguntan ¿Está usted seguro? que en realidad quiere decir: Mire que si borra todo será su culpa.
La solución de los programadores tiene 2 lineas de trabajo. La primera es llenar de diálogos que preguntan ¿Está usted seguro? que en realidad quiere decir: Mire que si borra todo será su culpa. La segunda es agregar más funcionalidad. Ahora cuando utilizo la función guardar, puedo borrar otros archivos, crear otras carpetas, cambiar cosas de nombre, mover, y una cantidad de opciones que tal vez resuelvan otros problemas, pero no el específico: Guardar es un problema interno de la computadora y no un objetivo del usuario. El diseño se debería encargar de eliminarlo, no de perpetuarlo y agrandarlo.
Cuando menos es más
La competencia en el mercado está basada en la cantidad de funciones que un producto o sitio Web tiene para el usuario. Esto es consecuencia de la carencia de diseño de la interacción, orientado al usuario, pero además es causa de que este problema se profundice. Nadie se anima a lanzar un procesador de texto que desafíe el dominio de Word bajo el lema: Solo 15 funciones que usted adorará. Todos creemos que para desbancar a Word, necesitaremos incluir cientos de funciones más que las que Word incorpora, y en mi opinión esto no es correcto. Word no escapa a la carencia de diseño de la interacción orientado al usuario, tiene una interacción recargada, inconsistente, llena de funcionalidad impresionante pero inútil para la gran mayoría de los usuarios. Estoy convencido que un producto que este diseñado realmente desde los objetivos de quienes lo usan, tal vez con muchísima menos funcionalidad, pero la exacta, que no haga sentir inútil a quien lo usa, podría realmente ser exitoso en el mercado.
Veamos el ejemplo de los puestos de autoconsulta de los Shopping. No creo que haya nadie que sea capaz de encontrar un local determinado a partir del mapa con la flechita, que invariablemente utilizan para contestar la pregunta de la ubicación de locales. Técnicamente es una solución interesante, muy cercano al desarrollo de un Sistema de Información Geográfica. Cualquier programador lo mostraría con orgullo, y sin embargo, es absolutamente inútil desde el punto de vista de los usuarios: no cumple con sus objetivos. La realidad es que los dos proyectos de autoconsultas en centros comerciales que conozco, fueron condenados al olvido después de fracasar con todas y cada una de sus promesas. Para mí la razón es sencilla: tenían una enorme funcionalidad, pero carecían completamente de diseño de la experiencia del usuario. Si se hubieran invertido los términos, hubieran sido mucho más exitosos con muchísima menos funcionalidad.
Ese fantasma el usuario
Si quiere comenzar a desarrollar software o sitios Web realmente orientados al usuario, lo primero que debe hacer es eliminar la palabra «usuario» de su vocabulario y del de todo el equipo de trabajo. El usuario es un concepto «chicle», ambiguo, maleable, que no ayuda a identificar a quien va dirigido el trabajo, sino que ayuda a confundirlo todo. Se le puede atribuir en cada ocasión conocimientos distintos, atributos distintos e inclusive objetivos distintos, haciendo que en realidad el proyecto no esté destinado a nadie.
La consecuencia más inmediata es lo que se llama «diseño autorreferenciado». Es decir, el diseño hecho a la medida de uno mismo. El programador desarrolla con su propia imagen en la imagen del usuario. La universalidad y omnipresencia de los botoncitos «Abrir», «Salvar», «Guardar» son un ejemplo de esta práctica. Es muy fácil detectar el diseño autorreferenciado: le presentan a usted (¡que no es un usuario promedio!), un nuevo sitio. El programador se para al lado, y cada vez que usted se tranca, porque no descubre como seguir, él le explica con naturalidad la lógica. El fracaso está asegurado, salvo que usted sea capaz de enviar al programador a que se pare al lado de cada usuario.
Para eliminar completamente la palabra usuario, y evitar este tipo de problemas, póngale nombre y apellido a esos usuarios, e intente describirlos con detalle. Por ejemplo, supongamos que usted está haciendo un portal médico. En vez de decir el usuario, podríamos llamar a este individuo Mario del Buono.
Para eliminar completamente la palabra usuario, y evitar este tipo de problemas, póngale nombre y apellido a esos usuarios, e intente describirlos con detalle.
Mario del Buono es Gastroenterólogo. Es un profesional destacado, y es además docente grado 4 en la universidad. Tiene 54 años, es casado, tiene 3 hijos, dos nietos y uno en camino. Tiene un Nissan Sentra Super Saloon azul oscuro. Adora el silencio del auto, y que hay que llevarlo poco al mecánico. Mario es un estudioso, tiene una enorme biblioteca, y ha publicado 2 libros. Tiene una computadora en su casa, que ya casi no usa y un notebook, que lleva a todos lados. A pesar de que hace mucho que utiliza computadoras, el 70% del trabajo lo realiza en un procesador de texto, donde reconoce que usa solo las funciones elementales. El resto del tiempo lo ocupa el correo electrónico y una planilla de cálculo para manejar sus gastos, honorarios y ahorros.
Ahora es mucho más fácil imaginar lo que Mario quiere, lo que necesita, lo que no quiere y lo que no necesita. Mario es tangible, y si no lo es, cuelgue una foto de un médico en bata que diga «Mario del Buono, Gastroenterólogo»
El reparto
El resultado final de esta técnica es contar con un reparto, tal como en una obra de teatro o película de cine, antes de digitar la primera linea de código. Encontrar el reparto no será fácil. Debe limitarse a un personaje principal para cada área del sistema.
Por ejemplo, el portal tendría 3 personajes principales:
Además de Mario, podríamos incluir a Teresa Hernández, administradora del portal, con una larga experiencia como operadora de sistemas, pero en su primer proyecto Web. Es Analista de Sistemas, acostumbrada a manejar complejos sistemas de respaldo, controlar el desempeño de servidores y medir el tiempo de respuesta. Teresa tiene 24 años, y un novio que insiste en que se casen lo antes posible. Ella está esperando a recibirse de Ingeniera antes de la boda.
El tercer personaje es Fabio Daremberg, Web Master. Fabio tiene 32 años, es soltero y trasnochador, siempre con una compañía agradable y distinta. Se viste de negro, recita a Neruda de memoria y escribe solo con tinta verde, como él. Ama el PhotoShop, y es capaz de describir cada una de las cosas que se puede hacer con cada una de las versiones. Solo usa Mac, una cuestión de principios.
El reparto no puede tener más de 7 a 10 personajes y solo 1 a 3 principales. No intente diseñar para todo el mundo. El resultado es una de esas palas de campamento que son además martillo, hacha, remo y destornillador a la vez: no hacen ninguna de las tareas bien, ni siquiera son útiles como pala.
Tener un reparto permite darse cuenta con claridad que es lo que se debe hacer y que no. Está claro que Mario no quiere problemas, quiere ir directo al grano y poco le importa la técnica. Por más funciones que pongamos, usará solo algunas, tal como lo hace desde hace años con su procesador de texto.
La pregunta: ¿Necesitará el usuario una búsqueda con operadores lógicos? es completamente distinta si se plantea ¿Necesitará Mario una búsqueda con operadores lógicos?.
La pregunta: ¿Necesitará el usuario una búsqueda con operadores lógicos? es completamente distinta si se plantea ¿Necesitará Mario una búsqueda con operadores lógicos?. Un programador contestará probablemente a la primera con un si, dado que al final, la lógica es la base de su tarea, y el jamás utilizaría un sistema que no le permita programar funciones que no incluyan and, not, or, xor y si quiere realmente posar de nerd, exigirá un operador nand. Mario contestará que apenas entiende como funciona la búsqueda. Que en general pone una palabra y salen cientos de miles de documentos, y que no va a gastar un segundo de su tiempo en complicarse más la vida. Evidentemente lo que Mario necesita es que mejoren la interacción en la pagina de resultados y no que agreguen funcionalidad a la búsqueda.
Una razón imperativa para actuar
A pesar de que la publicidad insista en que los mortales debemos navegar por Internet, después de la experiencia de sentarse ante un navegador y preguntarse ¿Ahora qué?, todos nos damos cuenta de que navegar en Internet es una tarea, o una herramienta, no un objetivo.
Las personas hacemos cosas cuando tenemos una razón imperativa para actuar. Cuando existe un conjunto de causas que generan una razón imperativa, nuestro usuario, cliente, Mario, o como quiera que lo llame, actuará. El diseño debe entender el objetivo, de modo de analizar y crear una interacción que acerque al usuario a su objetivo. La funcionalidad crea herramientas. El diseño crea experiencias. Si usted busca un destornillador determinado, cuantas más herramientas tenga la caja de herramientas, más difícil será la búsqueda. Y si las herramientas son todas destornilladores, peor aún. Tener mucha funcionalidad, no tiene relación directa con los objetivos de los usuarios. Estos se sentirán más satisfechos cuando encuentren exactamente la cantidad necesaria, ni una más, ni una menos, de funciones que los ayuden a alcanzar sus objetivos.
Si bien para alcanzar los objetivos hay que desarrollar tareas, no hay que confundir uno con otro. Cuando el padre deja sin televisión a su hijo, su objetivo es educarlo para que pueda ser feliz en su edad adulta, su tarea es mostrarle que una determinada actitud tuvo consecuencias que tendrá que asumir. Los objetivos tienden a permanecer, a ser estables en el tiempo. Las tareas tienden a cambiar. El padre durante toda la niñez de su hijo, intentará educarlo para que sea feliz en el futuro. Las tareas que desarrollará para ello serán múltiples y variadas.
Focalizarse en el objetivo de sus personajes, entender este objetivo y concentrase en él, le permitirá abordar con creatividad y libertad el análisis de las tareas y la funcionalidad que las implementa. Podrá libremente eliminarlas, crear nuevas, o cambiarlas completamente.
Focalizarse en el objetivo de sus personajes, entender este objetivo y concentrase en él, le permitirá abordar con creatividad y libertad el análisis de las tareas y la funcionalidad que las implementa
En el ejemplo de la función «Guardar», el objetivo del usuario es crear, administrar y probablemente imprimir sus documentos. «Abrir», «Guardar» y «Cerrar» archivos no está dentro de su lista de objetivos. Podría por ejemplo eliminar completamente el menú de archivos y hablar de Versiones. Crear una vista de versiones por fecha, y una vista de versiones por documento, y almacenar automáticamente las versiones que se generan cada vez que se trabaja sobre un documento. Esta solución dista mucho de ser adecuada, pero está mucho más orientada a los objetivos del usuario, y seguro será mucho más apreciada por él.
En la Web el problema de encontrar la razón imperativa que el cliente tiene para actuar es aún más importante. El cliente tiene que decidir venir a nuestro sitio. Tiene que tener un motivo, y después que vino a mi sitio, yo tengo que darme cuenta de ese motivo, ese objetivo y ayudarlo lo más rápidamente a resolverlo. Todos los sitios que tienen una presentación al comienzo, en general desarrollada en Flash, violan este criterio. Ignoran los objetivos de sus clientes y los condenan a esperar 1 minuto a que se cargue y otro minuto a que se despliegue, una presentación siempre igual, que no dice absolutamente nada útil para los objetivos de sus clientes. Se arriesgan además a mensajes horrorosos como «Su sitio no soporta Flash 5», un enorme cuadrado negro o que la presentación cuelgue la maquina del cliente, lo que determinará automáticamente la condena del sitio al olvido. Un cartelito que diga «Saltear la presentación» es apenas una forma errónea de sacarse un poco de culpa. Flash es un producto fantástico, que genera herramientas poderosas, que ayudan a resolver algunos de los objetivos de los clientes. Eso no lo exime a usted de encontrar los objetivos de sus clientes, las razones imperativas que lo llevaron a su sitio, y hacer que su experiencia sea placentera, y que resuelvan lo mejor y más rápido posible sus problemas e inquietudes.
Todos los sitios que tienen una presentación al comienzo, en general desarrollada en Flash, violan el criterio de la razón imperativa para actuar. Ignoran los objetivos de sus clientes.
Los escenarios
Todo buen elenco necesita un escenario para actuar. Su reparto también. Para entender como hacen los personajes para cumplir con los objetivos, es necesario describir con detalle los escenarios en los que se está actuando. Una vez más esto ayuda a entender como es la experiencia del usuario y como se realiza la interacción hombre-sistema, a los efectos de desarrollar un diseño que haga exitoso su proyecto.
Por ejemplo, en el portal médico, un escenario posible es que Mario haya tenido un paciente con una dolencia poco común y esté buscando dos cosas: material para tratar de diagnosticar mejor la enfermedad, así como otros médicos que lo puedan ayudar.
Otro escenario posible es que Mario reciba como usuario registrado una consulta y entre al portal a contestarla, ya que sabe que la participación activa en la comunidad le traerá beneficios a la hora de pedir ayuda.
Escenarios de uso diario
En todo sistema existen 2 o 3 escenarios que representan las interacciones básicas que realizará el usuario con frecuencia. Se trata de apenas 2 o 3 escenarios. Inclusive muchas veces un solo escenario es suficiente. Nunca son 10.
Independientemente de la cantidad de funciones que su software o sitio Web incluya, el 80% del tiempo del usuario se desarrollará en esos 2 o 3 escenarios por lo que el 80% del tiempo debe destinarse a diseñar la interacción en ellos. La distribución homogénea del esfuerzo de diseño es un error tan frecuente como nocivo. Concéntrese en encontrar sus personajes principales, identificar sus objetivos y diseñar la interacción de los dos o tres escenarios de uso diario. También allí está escondido el 80% del éxito.
Escenarios de uso necesario
Los escenarios de uso necesario abarcan las interacciones imprescindibles, pero poco frecuentes. Si bien el diseño de esas interacciones debe ser cuidado, si usted enamoró al personaje de su sistema o sitio Web en los escenarios de uso diario, el usuario entenderá que es imprescindible desarrollar una determinada tarea una vez cada tanto, y estará dispuesto a una interacción no tan agradable. Sumado a ello, el hecho de que sean poco frecuentes, hará muy difícil que el usuario recuerde lo aprendido de una interacción a la siguiente. Como corolario, ya hemos gastado en los escenarios de uso diario el 80% del esfuerzo de diseño, por lo que nos queda solo un 20%.
Mientras que el objetivo de los escenarios de uso diario debe ser fascinar al cliente, los de uso necesario deben tener como objetivo que éste realice su tarea sin frustrase.
Escenario de caso límite
Quienes alguna vez programamos, sabemos que los buenos programadores son aquellos que son capaces de prever todos los casos límite, de modo que su software no falle jamás. Cuando el sistema operativo se cuelga, es porque se excedió alguna condición de borde que algún programador no previó y ésto habla muy mal de ese programador.
Su sistema o sitio no tendrá éxito o fracasará en función del mensaje de error cuando los resultados de la búsqueda exceden 216 ocurrencias.
Sin embargo a pesar de que los programadores tengan que seguir previendo el 100% de los casos límites, desde el punto de vista del usuario, es prácticamente innecesario el diseño de interacción en estos casos. Su sistema o sitio no tendrá éxito o fracasará en función del mensaje de error cuando los resultados de la búsqueda exceden 216 ocurrencias. Esto le sucederá a un usuario por año, y es prácticamente innecesario abarcar estos problemas desde el punto de vista del diseño de la interacción, a pesar de que consuma gran parte del tiempo de programación.
Diseño e Interfaz, el orden de los factores
El diseño de la interacción y la experiencia es al diseño de la interfaz, lo que la Arquitectura es al Diseño de Interiores. Mientras que la Arquitectura precede a la construcción de la vivienda, la decoración de interiores la sigue.
El diseño de la interfaz es efectivamente la parte del diseño cercana al diseño gráfico y al diseño artístico, pero ni reemplaza ni se opone al diseño de la interacción. La realizan personas distintas, con conocimiento distinto, con objetivos distintos y en momentos distintos.
El diseño de la interacción y la experiencia es al diseño de la interfaz, lo que la Arquitectura es al Diseño de Interiores. Mientras que la Arquitectura precede a la construcción de la vivienda, la decoración de interiores la sigue.
Cuando usted le habla a un programador experiente de diseño de la interacción, automáticamente contestará que se trata del diseño de la interfaz del usuario. Según Alan Cooper, es como llamar a los carpinteros para que den forma al encofrado, después que se vertió y fraguó el cemento. Una tarea tan inútil como improductiva.
El orden es vital: diseño de la interacción, codificación, diseño de la interfaz, testeo y depuración, entrega del producto. Este orden tiene una lógica y consecuencias favorables a su proyecto.
El orden es vital: diseño de la interacción, codificación, diseño de la interfaz, testeo y depuración, entrega del producto. Este orden tiene una lógica y consecuencias favorables a su proyecto.
El producto terminado
Si su mecanismo es definición de la lista de características de su aplicación, codificación, lanzamiento de un beta, vuelta al principio, usted carece al comenzar de una idea de cual es el producto terminado. Esto determina durante el proceso de desarrollo de su aplicativo o sitio Web de una negociación interminable entre el gerente de desarrollo, los programadores, el área de Marketing y el area financiera que paga las cuentas. Los usuarios no tienen representante en esa negociación. A medida que los plazos se acortan, los features se recortan, no en función de su importancia, o lo vital que son para el usuario y su experiencia con el producto, sino en función del tiempo que lleve implementarlos y del costo que tengan asociados, estos son los dos parámetros más importante bajo la presión de los plazos.
También se sustituirán determinadas formas de interactuar por otras más fáciles de codificar, pero no en función de la interacción del usuario. Por ejemplo, existen además de las API específicas de Windows para manejar la apertura, grabación y cierre de archivos, cientos o miles de objetos, código o controles para realizar esa tarea. Todos comparten la idea de hace 50 años de obligar al usuario a entender qué es un disco duro y qué es la memoria RAM, y entender las funciones open, save, close, etc. del lenguaje de programación. Tal vez no sea capaz de encontrar código reutilizable para manejar los documentos desde el punto de vista de las versiones, o del que usted definió como óptimo. El cambio acorta los plazos, pero frustrará una y otra vez a su usuario.
El diseño de la interacción y la experiencia del usuario, la documentación amplia y detallada de este diseño por escrito, utilizando texto, imágenes, storyboards, etc. Dará una idea acabada antes de empezar de como es el producto terminado. Esto es una herramienta invalorable para planificar la programación, para evaluar los tiempos y eliminar las disputas interminables sobre las características a incluir o eliminar.
El proyecto más barato
La parte más cara del proyecto es sin duda la programación. Probablemente con un equipo de dos diseñadores de la interacción, se diseñe una aplicación que involucre a una decena de programadores. Es mucho más económico planificar antes, que intentar modificar durante. No es solamente un problema de experiencia del usuario. Las idas y venidas, los cambios sobre la marcha, rehacer lo ya hecho, es mucho más caro.
El mecanismo de lanzar los productos sin terminar al mercado, para que los gritos pidiendo piedad de los usuarios indiquen el camino a seguir, es una estrategia descabellada. Recuerde que Microsoft tiene cifras de dinero casi ilimitadas, y una aparente inmunidad a las críticas de los usuarios, aún las mas duras. El resultado en una interacción pobre, una experiencia frustrante y un código de dudosa calidad, con productos como Windows 98 que conservan en su interior el código escrito 18 años antes para DOS. Recuerde que una vez que hay código en el proyecto, el concreto empieza a fraguar y es ya imposible cambiar su forma.
Interactuar dos, tres, cinco veces con los usuarios, desnudando la falta total de consideración de criterios de diseño de interacción no solo es malo, sino que además es muy caro.
El proyecto más exitoso
La guerra de features entre los productos y sitios del mercado solo es una demostración de lo que en Marketing se llama miopía. Si estoy en el negocio del software, estoy en el negocio de la programación. Cuanto más programe, cuanto más difícil sean esos programas, mejor estará posicionado mi programa. Dicho en otras palabras: cuanto más features tenga, cuantos más cuadros de dialogo tenga, mejor será el programa. Definitivamente falso.
El proyecto más exitoso será el que cumpla mejor con los objetivos de sus clientes. Todo lo demás es adjetivo. Esto no quiere decir que lo que hay que hacer es eliminar features. Esto quiere decir que es un error quedar atrapado en la guerra de los features. Esta forma de pensar va en contra de la concepción de casi todos los desarrolladores de productos de software y sitios Web. Pero está profundamente basada en la realidad, y en la práctica de los usuarios.
Los usuarios al poder
Si no nos guiamos por las declaraciones de intención y los folletos publicitarios, los usuarios no están representados en el proceso de desarrollo, salvo que se incluya una fase de diseño de la interacción y la experiencia del usuario antes de que se codifique la primera linea.
En un mercado tan competitivo, tan exigente, con procesos de desarrollo tan demandantes, quienes no están fuertemente representados, no cuentan. Y los usuarios son sin duda los parias de este proceso de desarrollo. Después que está todo terminado, los invitan a 2 o 3 focus groups, para analizar su comportamiento, y a partir de ello cambiar algunas cosas de la interfaz, que milagrosamente solucionará todas los problemas que surgen de haber obviado la fase de diseño de la interacción.
Centrar el proyecto en el cliente, partiendo del desarrollo de la interacción y la experiencia del usuario, a través de la creación de personajes y un reparto, la identificación de sus objetivos, así como de los escenarios en los que tendrán que actuar para cumplir esos objetivos, es una apuesta a un éxito más económico y más probable.
Más artículos de esta serie:
- Anterior: Los objetivos del diseño
- Siguiente: Diseño, los usuarios al poder (II)
11 replies on "Diseño: los usuarios al poder (I)"
http://web.archive.org/web/20011217200758/www.yahoo.com/
Hay que cambiar la parte final que trata sobre Yahoo… porque ya ha cambiado bastante desde que se escribió este artículo.
Muy buen artículo… mucho de «Designing the Obvious», por Robert Hoekman Jr., sin dudas.
Pero hablando de usuarios comunes, muchos no saben que un email publicado en una página como esta puede ser leido por un robot (o un ser humano poco escrupuloso) para enviar spam. Sugiero aplicar lo predicado y no hacer públicos los emails o adviertir debidamente a sus visitantes.
Agrego: la mecánica común y lógica de los comentarios es «el ultimo al final», como forma natural de seguir el hilo a la «conversación» virtual. Creo que es una falla en esta página.
Excelente articulo.
felicidades, este articulo esta buenisimo y aunque aun soy un estudiante de computacion me identifique con este articulo y creo que es hora de emplear una manera de pensar distinta a la con que se ha venido trabajando, creo que muchos de los que estamos en este rubro debemos leerlo y orientar nuestro objetivo a satisfacer las necesidades de los usuarios de una manera practica.
Creo que se podría haber comentado un poco más acerca de las funciones del color al momento de querer mantener la atención. Esta opinión se ha formado a partir de una lectura rápida
Muy interesante, y aunque desde luego hay que mantener la usabilidad por encima de todo como máxima de la web, tambien me gustaría resaltar el hecho de que hasta la página más practica del mundo pierde paulatinamente visitas si no usa periodicamente un impacto, renovación o fuerza visual propia de la publicidad como usted apunta, y como todo en el diseño depende del producto, el servicio y el cliente el que apuntemos a una dirección u otra.
Con esto unicamente quiero recordar la flexibilidad del diseño y que aunque existen leyes no siempre hay que usarlas rigidamente.
encuentro la pagina muy rasca y poco interesante, ahora que existe demasiada informacion en la web…ustedes la llenan con mas informacion ..y lo peor..inutil
Leyendo a Alan Cooper vuelvo a ratificar mi punto de vista con su artículo. Me parece que eso es lo que hace falta en la mayoría de los sitios y portales web, la última puesta a estudiar es la posición del usuario. Los programadores creen que lo saben todo y tratando de demostrar a sus homólogos sus capacidades sistemáticas terminan alejandose del todo de los objetivos del sus proyectos.
P.D. qué debo hacer para que los programadores sigan estos consejos.
Me parece que el artículo es excelente, no soy ninguna experta en la materia, pero si soy una internauta muy dinámica, que gusta mucho de la navegación. Muchas veces nos perdemos en determinadas páginas, en las que entramos por un motivo, estuvimos media hora en la página sin cumplir nuestro cometido.
Gracias por darme la oportunidad de expresar como alguien que habla desde el llano.