<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet href="http://feeds.southworks.net/~d/styles/rss2full.xsl" type="text/xsl" media="screen"?><?xml-stylesheet href="http://feeds.southworks.net/~d/styles/itemcontent.css" type="text/css" media="screen"?><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" version="2.0">

<channel>
	<title>paulo.arancibia</title>
	
	<link>http://blogs.southworks.net/parancibia</link>
	<description>the unofficial user experience evangelist</description>
	<pubDate>Tue, 18 Nov 2008 18:10:28 +0000</pubDate>
	<generator>http://wordpress.org/?v=2.5.1</generator>
	<language>en</language>
			<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" href="http://feeds.southworks.net/parancibia" type="application/rss+xml" /><item>
		<title>PDC Essencials - Buenos Aires</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/457859643/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/11/18/pdc-essencials-buenos-aires/#comments</comments>
		<pubDate>Tue, 18 Nov 2008 17:54:13 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[UX]]></category>

		<category><![CDATA[WPF]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=27</guid>
		<description><![CDATA[Hoy junto a Julian Dominguez estuvimos presentando en la edición local de la PDC  los nuevos controles Ribbon y Data Grid para WPF, tal como prometimos a continuación podrán encontrar la solución de ejemplo que usamos en la charla como así también algunos links con recursos para que puedan seguir ahondando en el tema.

WPF Toolkit
patterns [...]]]></description>
			<content:encoded><![CDATA[<p>Hoy junto a <a class="alignleft" href="http://blogs.southworks.net/jdominguez/" target="_blank">Julian Dominguez</a> estuvimos presentando en la edición local de la PDC  los nuevos controles Ribbon y Data Grid para WPF, tal como prometimos a continuación podrán encontrar la solución de ejemplo que usamos en la charla como así también algunos links con recursos para que puedan seguir ahondando en el tema.</p>
<ul>
<li><a class="alignleft" href="http://www.codeplex.com/wpf" target="_blank">WPF Toolkit</a></li>
<li><a class="alignleft" href="http://www.codeplex.com/CompositeWPF" target="_blank">patterns &amp; practices: Composite WPF and Silverlight</a></li>
<li><a class="alignleft" href="http://msdn.microsoft.com/en-us/library/cc872782.aspx" target="_blank">Ribbons Guidance</a></li>
<li><a class="alignleft" href="http://windowsclient.net/downloads/folders/hands-on-labs/entry76491.aspx" target="_blank">Lab: What’s Coming in WPF: Datagrid, Ribbon, and VSM</a></li>
<li><a class="alignleft" href="http://blogs.msdn.com/jaimer/archive/2008/08/13/dabbling-around-the-new-wpf-datagrid-part-1.aspx" target="_blank">Dabbling around the new WPF Datagrid </a></li>
<li><a class="alignleft" href="http://cid-7cc9f2b7406f44d0.skydrive.live.com/self.aspx/Public/PDC.zip" target="_blank">Download Solucion de Ejemplo</a></li>
</ul>
<div><a href="http://blogs.southworks.net/parancibia/files/2008/11/p1060107.jpg"><img class="alignnone size-full wp-image-29" src="http://blogs.southworks.net/parancibia/files/2008/11/p1060107.jpg" border="0" alt="" width="500" height="370" /></a></div>
<img src="http://feeds.southworks.net/~r/parancibia/~4/457859643" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/11/18/pdc-essencials-buenos-aires/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F11%2F18%2Fpdc-essencials-buenos-aires%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/11/18/pdc-essencials-buenos-aires/</feedburner:origLink></item>
		<item>
		<title>Design Maturity Model</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/342717536/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/07/23/design-maturity-model/#comments</comments>
		<pubDate>Wed, 23 Jul 2008 12:12:57 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[UX]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=24</guid>
		<description><![CDATA[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 [...]]]></description>
			<content:encoded><![CDATA[<p>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.</p>
<p><a href="http://www.google.com/url?sa=t&amp;ct=res&amp;cd=1&amp;url=http%3A%2F%2Fwww.bplusd.org%2Fuploads%2Fdesignmaturitymodel.pdf&amp;ei=3A2GSJjuG5zOePKooeoF&amp;usg=AFQjCNF8TKQhGeitTWC4HKN-rn65N5qHFA&amp;sig2=BWSuvF_DMZJphNLwvs_jFA" target="_blank">El Design Maturity Model</a> propuesto por <a href="http://www.bplusd.org/about-jess-mcmullin/" target="_blank">Jess McMullin</a> 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.<br />
<strong></strong></p>
<p><strong>Nivel 1 – No somos conscientes del diseño</strong></p>
<ul>
<li>El diseño no se reconoce como algo de valor</li>
<li>Se  “diseña” sin ningún fundamento</li>
<li>El diseño se deja de lado por cosas más “importantes”</li>
</ul>
<p><strong>Nivel 2 – Style</strong></p>
<ul>
<li>El diseño es añadido solamente para ser “cool” o para seguir alguna tendencia</li>
<li>El diseño es algo que se agrega a último minuto para añadir funciones meramente estéticas</li>
</ul>
<p><strong>Nivel 3 -  Forma y Función</strong></p>
<ul>
<li>Se implementa el diseño para mejorar ciertas funcionalidades</li>
<li>Se utiliza de forma limitada para agregar pequeños incrementos de funcionalidad en aplicaciones en desarrollo o existentes</li>
</ul>
<p><strong>Nivel 4 – Diseño como una forma de resolver problemas</strong></p>
<ul>
<li>El diseño nos permite encontrar nuevas oportunidades para resolver problemas existentes</li>
<li>El diseño nos permite acotar las opciones para atacar un problema específico</li>
</ul>
<p><strong>Nivel 5 – Totalmente orientados al diseño</strong></p>
<ul>
<li>El diseño redefine los desafíos que enfrenta la organización</li>
<li>El diseño establece el orden del día</li>
<li>El diseño forma parte de toda estrategia</li>
<li>La innovación está inmersa en la cultura</li>
</ul>
<p>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.</p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/342717536" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/07/23/design-maturity-model/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F07%2F23%2Fdesign-maturity-model%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/07/23/design-maturity-model/</feedburner:origLink></item>
		<item>
		<title>Integrando YUI con ASP.NET MVC</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/334802145/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/07/14/integrando-yui-con-aspnet-mvc/#comments</comments>
		<pubDate>Mon, 14 Jul 2008 20:09:08 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[ASP.NET]]></category>

		<category><![CDATA[MVC]]></category>

		<category><![CDATA[YUI]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=23</guid>
		<description><![CDATA[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 [...]]]></description>
			<content:encoded><![CDATA[<p>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<a href="http://developer.yahoo.com/yui/" target="_blank"> YUI  (The Yahoo! User Interface Library) </a>, la misma viene repleta de controles y una excelente documentación,   que hacen que su implementación sea algo relativamente sencillo.</p>
<p>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.</p>
<p>Para comenzar empezaremos con el código del Controller.</p>
<p><span style="font-size: x-small"><span style="font-size: 10pt;color: blue">public</span><span style="font-size: 10pt"> <span style="color: #2b91af">JsonResult</span> GetPlayersList()</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span>{</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: #2b91af">OranjeDataContext </span>ctx = <span style="color: blue">new</span> <span style="color: #2b91af">OranjeDataContext</span>();</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">var</span> data = (<span style="color: blue">from</span> player <span style="color: blue">in </span>ctx.Players</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span> </span><span style="color: blue">select </span>player).ToList&lt;<span style="color: #2b91af">Player</span>&gt;();</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">return</span> <span style="color: blue">this</span>.Json(<span style="color: blue">new</span> {players = data.ToArray() }, <span style="color: #a31515">&#8220;text/html&#8221;</span>);</span><span style="font-size: 10pt"><span><br />
</span></span><span style="font-size: 10pt">}</span></span></p>
<p>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.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2666923764/"><img src="http://farm4.static.flickr.com/3241/2666923764_80df0487d4_o.png" border="0" alt="" width="599" height="306" /></a></p>
<p>Notaran que antes de la data propiamente dicha la DataTable de YUI espera obtener el nombre de la entidad expuesta.</p>
<p>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 <a href="http://developer.yahoo.com/yui/articles/hosting/" target="_blank">YUI Dependency Configurator</a>, el cual indicándole los controles a implementar nos indicara los archivos que debemos utilizar.</p>
<p>Lo siguiente es consumir la data, para ello deberemos de incluir el siguiente código en la vista.</p>
<p><span style="font-size: x-small"><span style="font-size: 10pt;color: blue">&lt;</span><span style="font-size: 10pt;color: #a31515">script</span><span style="font-size: 10pt"> <span style="color: red">type</span><span style="color: blue">=&#8221;text/javascript&#8221; </span><span style="color: red">language</span><span style="color: blue">=&#8221;javascript&#8221;&gt;</span></span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt">YAHOO.util.Event.addListener(window,<span style="color: #a31515">&#8220;load&#8221;</span>, <span style="color: blue">function</span>()<br />
{</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span>YAHOO.example.PopulateGrid = <span style="color: blue">new</span> <span style="color: blue">function</span>() {<span> </span></span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">var </span>myColumnDefs = [{key:<span style="color: #a31515">"PlayerId"</span>,label:<span style="color: #a31515">"Id"</span>},<span> </span>{key:<span style="color: #a31515">"Name"</span>},{key:<span style="color: #a31515">"Number"</span>},{key:<span style="color: #a31515">"Age"</span>},{key:<span style="color: #a31515">"Caps"</span>},];</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">this</span>.myDataSource= <span style="color: blue">new</span> YAHOO.util.DataSource(<span style="color: #a31515">&#8220;Home/GetPlayersList?&#8221;</span>);</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">this</span>.myDataSource.responseType= YAHOO.util.DataSource.TYPE_JSON;</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">this</span>.myDataSource.responseSchema= {resultsList: <span style="color: #a31515">&#8220;players&#8221;</span>,fields:[<span style="color: #a31515">"PlayerId"</span>,<span style="color: #a31515">"Name"</span>,<span style="color: #a31515">"Number"</span>,<span style="color: #a31515">"Age"</span>,<span style="color: #a31515">"Caps"</span>]};</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span><span style="color: blue">this</span>.myDataTable= <span style="color: blue">new</span> YAHOO.widget.DataTable(<span style="color: #a31515">&#8220;myGrid&#8221;</span>, myColumnDefs, <span style="color: blue">this</span>.myDataSource);<span> </span></span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt"><span> </span>};</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt">});</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt;color: blue">&lt;/</span><span style="font-size: 10pt;color: #a31515">script</span><span style="font-size: 10pt;color: blue">&gt;</span></span></p>
<p><span style="font-size: x-small"><span style="font-size: 10pt;color: blue">&lt;</span><span style="font-size: 10pt;color: #a31515">div</span><span style="font-size: 10pt"> <span style="color: red">id</span><span style="color: blue">=&#8221;myGrid&#8221;&gt;&lt;/</span><span style="color: #a31515">div</span><span style="color: blue">&gt;</span></span></span></p>
<p>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.</p>
<p>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.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2665904323/"><img src="http://farm4.static.flickr.com/3270/2665904323_26e944fbf0_o.png" border="0" alt="" width="600" height="563" /></a></p>
<p>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.</p>
<p><a href="http://developer.yahoo.com/yui/" target="_blank">The Yahoo! User Interface Library (YUI)</a></p>
<p><a href="http://yuiblog.com/">Yahoo! User Interface Blog</a></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/334802145" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/07/14/integrando-yui-con-aspnet-mvc/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F07%2F14%2Fintegrando-yui-con-aspnet-mvc%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/07/14/integrando-yui-con-aspnet-mvc/</feedburner:origLink></item>
		<item>
		<title>Buenas prácticas y recursos para la creación de formularios</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/329194199/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/07/08/buenas-practicas-y-recursos-para-la-creacion-de-formularios/#comments</comments>
		<pubDate>Tue, 08 Jul 2008 08:46:06 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[UX]]></category>

		<category><![CDATA[Usabilidad]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=22</guid>
		<description><![CDATA[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 [...]]]></description>
			<content:encoded><![CDATA[<p>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.</p>
<p>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.</p>
<p>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.</p>
<p>En esta imagen pueden apreciar a un usuario probando una aplicación web mientras es monitoreado.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2646235179/"><img src="http://farm4.static.flickr.com/3179/2646235179_53db10f82b_o.jpg" border="0" alt="Eye-tracking" width="600" height="337" /></a></p>
<p>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.</p>
<p>Ejemplo de heat map<br />
<a href="http://www.flickr.com/photos/8031636@N06/2647065318/"><img src="http://farm4.static.flickr.com/3120/2647065318_e601d0af86_o.jpg" border="0" alt="Heat Map" width="450" height="563" /></a></p>
<h5>Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. <a href="http://www.rosenfeldmedia.com/books/webforms/">http://www.rosenfeldmedia.com/books/webforms/</a></h5>
<p>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.</p>
<p><strong>Top Aligned Labels</strong></p>
<p>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.</p>
<p>En esta imagen pueden ver el comportamiento del usuario frente a este tipo de disposición.<br />
<a href="http://www.flickr.com/photos/8031636@N06/2646235581/"><img src="http://farm4.static.flickr.com/3175/2646235581_84ec369b13_o.jpg" border="0" alt="Top Aligned Labels" width="217" height="262" /></a></p>
<h5>Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. <a href="http://www.rosenfeldmedia.com/books/webforms/">http://www.rosenfeldmedia.com/books/webforms/</a></h5>
<p><strong>Right Aligned Labels</strong></p>
<p>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. </p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2647065562/"><img src="http://farm4.static.flickr.com/3124/2647065562_8417856dc7_o.jpg" border="0" alt="Right Aligned Labels" width="346" height="231" /></a></p>
<h5>Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. <a href="http://www.rosenfeldmedia.com/books/webforms/">http://www.rosenfeldmedia.com/books/webforms/</a></h5>
<p><strong>Left Aligned Labels</strong></p>
<p>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.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2647065718/"><img src="http://farm4.static.flickr.com/3258/2647065718_28cc6c1faa_o.jpg" border="0" alt="Left Aligned Labels" width="346" height="231" /></a></p>
<h5>Image from Web Form Design: Filling in the Blanks by Luke Wroblewski; Rosenfeld Media, 2008. <a href="http://www.rosenfeldmedia.com/books/webforms/">http://www.rosenfeldmedia.com/books/webforms/</a></h5>
<p>Para seguir ahondando en estos temas les recomiendo la lectura del libro <a href="http://www.rosenfeldmedia.com/books/webforms/">Web Form Design<br />
Filling in the Blanks</a> de Luke Wroblewski publicado por Rosenfeld Media, o de los siguientes enlaces.</p>
<p><a href="http://www.usolab.com/articulos/eyetracking-usabilidad-comunicacion.php">La aportación del eyetracking en el sector de usabilidad</a><br />
<a href="http://www.nosolousabilidad.com/articulos/eye-tracking.htm">Eye-Tracking en Interacción Persona-Ordenador</a><br />
<a href="http://www.uxmatters.com/MT/archives/000107.php">Label Placement in Forms</a><br />
<a href="http://www.lukew.com/resources/articles/web_forms.html">Web Application Form Design</a></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/329194199" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/07/08/buenas-practicas-y-recursos-para-la-creacion-de-formularios/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F07%2F08%2Fbuenas-practicas-y-recursos-para-la-creacion-de-formularios%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/07/08/buenas-practicas-y-recursos-para-la-creacion-de-formularios/</feedburner:origLink></item>
		<item>
		<title>Silverlight 2 Beta 2 y los archivos XAP</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025841/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/06/09/silverlight-2-beta-2-y-los-archivos-xap/#comments</comments>
		<pubDate>Mon, 09 Jun 2008 16:45:39 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[Silverlight]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=4</guid>
		<description><![CDATA[Leyendo el ultimo post de Scott Guthrie sobre las nuevas features de Silverlight, note que no se hablo del cambio en el modelo de “deployment” usado para las aplicaciones Silverlight, como sabrán cuando compilamos una solución Silverlight se crea un archivo .xap el cual no es más que un zip que contiene todas las DLLs [...]]]></description>
			<content:encoded><![CDATA[<p>Leyendo el ultimo <a href="/scottgu/archive/2008/06/06/silverlight-2-beta2-released.aspx" target="_blank">post de Scott Guthrie</a> sobre las nuevas features de Silverlight, note que no se hablo del cambio en el modelo de “deployment” usado para las aplicaciones Silverlight, como sabrán cuando compilamos una solución Silverlight se crea un archivo .xap el cual no es más que un zip que contiene todas las DLLs necesarias para correr nuestra aplicación, este .xap viaja hasta el browser y luego es manipulado por el engine de Silverlight el cual se encarga de correr nuestra solucion, en la siguiente imagen pueden observar el contenido de dicho archivo compilado con la Beta1.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2565176230/"><img src="http://farm4.static.flickr.com/3130/2565176230_6ea24fb299_o.png" alt=".xap Beta 1" border="0" height="413" width="600"></a></p>
<p>Notaran que además de la dll de nuestra aplicación, en este caso Anim.dll, también están incluidas un par de dlls con los controles usados por Silverlight.</p>
<p>En cambio en la siguiente imagen la cual corresponde a la misma solución pero ccompilada con la Beta2 solo se puede apreciar que se incluye en el .xap la dll correspondiente a nuestra solución y su correspondiente manifest.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2564351853/"><img src="http://farm4.static.flickr.com/3165/2564351853_e6c57e59b4_o.png" alt=".xap Beta 2" border="0" height="413" width="600"></a></p>
<p>Este approach hace que el runtime crezca un poco en tamaño, pero como contraparte tenemos que nuestras aplicaciones son más livianas, me parece un cambio inteligente, pero espero que el tamaño del runtime se mantenga controlado. </p>
<p>En próximos posts les iré mostrando algunas de las nuevas features que se incluyen en esta Beta de Silverlight 2.</p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025841" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/06/09/silverlight-2-beta-2-y-los-archivos-xap/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F06%2F09%2Fsilverlight-2-beta-2-y-los-archivos-xap%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/06/09/silverlight-2-beta-2-y-los-archivos-xap/</feedburner:origLink></item>
		<item>
		<title>TechNight: Desarrollo de aplicaciones RIA distribuidas con WCF y Silverlight</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025842/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/06/07/technight-desarrollo-de-aplicaciones-ria-distribuidas-con-wcf-y-silverlight/#comments</comments>
		<pubDate>Sun, 08 Jun 2008 02:22:57 +0000</pubDate>
		<dc:creator>parancibia</dc:creator>
		
		<category><![CDATA[Community]]></category>

		<category><![CDATA[Silverlight]]></category>

		<guid isPermaLink="false">http://blogs.southworks.net/parancibia/?p=3</guid>
		<description><![CDATA[
El pasado 6 de junio junto a Edgardo Rossetto estuvimos presentando en las oficinas de Microsoft Argentina sobre desarrollo de aplicaciones RIA utilizando Silverlight y WCF, tal como prometí les dejo el código de las demos que estuvimos presentando como así también algunos links que les pueden ser de interés.
Technight Demos
Silverlight Screencasts &#38; Quickstarts
Pictures Services
Microsoft [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.flickr.com/photos/8031636@N06/2560327792/"><img src="http://farm4.static.flickr.com/3051/2560327792_b0c9f8b490_o.png" border="0" alt="" width="600" height="120" /></a></p>
<p>El pasado 6 de junio junto a <a href="http://blogs.southworks.net/erossetto/" target="_blank">Edgardo Rossetto</a> estuvimos presentando en las oficinas de Microsoft Argentina sobre desarrollo de aplicaciones RIA utilizando Silverlight y WCF, tal como prometí les dejo el código de las demos que estuvimos presentando como así también algunos links que les pueden ser de interés.</p>
<p><strong><a href="http://cid-7cc9f2b7406f44d0.skydrive.live.com/self.aspx/Public/DemosTechNight.zip" target="_blank">Technight Demos</a><br />
<a href="http://silverlight.net/learn/" target="_blank">Silverlight Screencasts &amp; Quickstarts</a><br />
<a href="http://samples.netfx3.com/pictureservices/" target="_blank">Pictures Services</a><br />
<a href="http://expression.microsoft.com/" target="_blank">Microsoft Expression Community</a><br />
<a href="http://www.inkscape.org/" target="_blank">Inkscape</a><br />
<a href="http://kaxaml.com/" target="_blank">Kaxaml</a></strong></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025842" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/06/07/technight-desarrollo-de-aplicaciones-ria-distribuidas-con-wcf-y-silverlight/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F06%2F07%2Ftechnight-desarrollo-de-aplicaciones-ria-distribuidas-con-wcf-y-silverlight%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/06/07/technight-desarrollo-de-aplicaciones-ria-distribuidas-con-wcf-y-silverlight/</feedburner:origLink></item>
		<item>
		<title>Charts en Silverlight, fácil con Visifire</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025843/</link>
		<comments>http://blogs.southworks.net/parancibia/2008/04/15/charts-en-silverlight-fcil-con-visifire/#comments</comments>
		<pubDate>Tue, 15 Apr 2008 15:51:00 +0000</pubDate>
		<dc:creator>admin</dc:creator>
		
		<category><![CDATA[Silverlight]]></category>

		<guid isPermaLink="false">0bfedb5f-1518-4bf4-a7d2-0f90003e0ad2:94743</guid>
		<description><![CDATA[Visifire es una suite de componentes Silverlight para la visualización de datos, los mismos son muy fáciles de implementar y pueden ser utilizados en la mayoría de las plataformas para desarrollo Web.
La forma más fácil de comenzar a probar Visifire y comprobar el poder de esta suite es utilizando el Chart Designer, el cual es [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.visifire.com" target="_blank">Visifire</a> es una suite de componentes Silverlight para la visualización de datos, los mismos son muy fáciles de implementar y pueden ser utilizados en la mayoría de las plataformas para desarrollo Web.</p>
<p>La forma más fácil de comenzar a probar <a href="http://www.visifire.com" target="_blank">Visifire</a> y comprobar el poder de esta suite es utilizando el <a href="http://www.visifire.com/silverlight_chart_designer.php" target="_blank">Chart Designer</a>, el cual es una herramienta online que permite la creación de charts interactivamente y cuyo resultado podemos embeber en cualquier pagina.</p>
<p><a title="VisiFire Chart Designer" href="http://www.flickr.com/photos/8031636@N06/2416605914/"><img src="http://farm3.static.flickr.com/2236/2416605914_d6f69ce06d_o.png" border="0" alt="VisiFire Chart Designer" width="600" height="383" /></a></p>
<p>También como es de suponer, podemos programáticamente crear charts y configurar su apariencia, ya que contamos con una gran cantidad de elementos visuales para personalizar  y elegir el tipo de chart cuyo número también es muy amplio.</p>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: blue">public </span><span style="font-size: 10pt">Page()</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">{
 InitializeComponent();</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: blue">this</span><span style="font-size: 10pt">.Loaded += <span style="color: blue">new</span> <span style="color: #2b91af">RoutedEventHandler</span>(Page_Loaded); </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">}</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: blue">public</span><span style="font-size: 10pt"> <span style="color: blue">class</span> Vendor</span></pre>
<pre><span style="font-size: 10pt">{</span></pre>
<pre><span style="font-size: 10pt;color: blue">public string</span><span style="font-size: 10pt"> name;</span></pre>
<pre><span style="font-size: 10pt;color: blue">public int</span><span style="font-size: 10pt"> sales;</span></pre>
<pre><span style="font-size: 10pt;color: blue">public </span><span style="font-size: 10pt">Vendor(<span style="color: blue">string</span> name, <span style="color: blue">int </span>sales)
 {</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10ptcolor: blue">this</span><span style="font-size: 10pt">.name = name;
 <span style="color: blue">this</span>.sales = sales;
 }
 } </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: blue">void </span><span style="font-size: 10pt">Page_Loaded(<span style="color: blue">object</span> sender, <span style="color: #2b91af">RoutedEventArgs</span> e)</span></pre>
<pre><span style="font-size: 10pt">{ CreateChart();
 }
 <span style="color: blue">public</span> <span style="color: blue">void </span>CreateChart()
 { </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: green">//Inicializamos el chart y los elementos que lo componen</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">Visifire.Charts.<span style="color: #2b91af">Chart</span> chart = <span style="color: blue">new</span>
 Visifire.Charts.<span style="color: #2b91af">Chart</span>();</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">Visifire.Charts.<span style="color: #2b91af">DataSeries</span> dataSeries = <span style="color: blue">new</span>
 Visifire.Charts.<span style="color: #2b91af">DataSeries</span>();</span></pre>
<pre><span style="font-size: 10pt">Visifire.Charts.<span style="color: #2b91af">DataPoint</span> dataPoint;
 Visifire.Charts.<span style="color: #2b91af">Title</span> title = <span style="color: blue">new</span>
 Visifire.Charts.<span style="color: #2b91af">Title</span>();</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: green">//Configuración de las características visuales </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">title.Text = <span style="color: #a31515">“Sales in millions”</span>;
 chart.Children.Add(title);
 chart.Width = 600;
 chart.Height = 400;
 chart.AnimationEnabled = <span style="color: blue">true</span>;
 chart.Theme = <span style="color: #a31515">“Theme1</span></span><span style="font-size: 10pt">″</span><span style="font-size: 10pt">;
 chart.AnimationType = <span style="color: #a31515">“Type3</span></span><span style="font-size: 10pt">″</span><span style="font-size: 10pt">;
 chart.UniqueColors = <span style="color: blue">true</span>; </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">chart.View3D = <span style="color: blue">true</span>;</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: green">//DataSource</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: #2b91af">List</span><span style="font-size: 10pt">&lt;<span style="color: #2b91af">Vendor</span>&gt; people = <span style="color: blue">new </span><span style="color: #2b91af">List</span>&lt;<span style="color: #2b91af">Vendor</span>&gt;();</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">people.Add(<span style="color: blue">new</span> <span style="color: #2b91af">Vendor</span>(<span style="color: #a31515">“Paulo”</span>, 55));
 people.Add(<span style="color: blue">new</span> <span style="color: #2b91af">Vendor</span>(<span style="color: #a31515">“Chorch”</span>, 33));
 people.Add(<span style="color: blue">new</span> <span style="color: #2b91af">Vendor</span>(<span style="color: #a31515">“Lito”</span>, 66));
 people.Add(<span style="color: blue">new</span> <span style="color: #2b91af">Vendor</span>(<span style="color: #a31515">“Ed”</span>, 37)); </span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">people.Add(<span style="color: blue">new</span> <span style="color: #2b91af">Vendor</span>(<span style="color: #a31515">“Max”</span>, 21));</span></pre>
<pre><span style="font-size: 10pt;color: green">//Enlazamos los datos de la lista con los DataPoints</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt">people.ForEach(<span style="color: blue">delegate</span>(<span style="color: #2b91af">Vendor</span> v)
 {
 dataPoint = <span style="color: blue">new</span> Visifire.Charts.<span style="color: #2b91af">DataPoint</span>();
 dataPoint.AxisLabel = v.name;
 dataPoint.YValue = v.sales;
 dataSeries.Children.Add(dataPoint);
 });</span></pre>
<pre style="margin-bottom: 0.0001pt"><span style="font-size: 10pt;color: green">//Configuramos el tipo de chart a utilizar</span></pre>
<pre><span style="font-size: 10pt">dataSeries.RenderAs = <span style="color: #a31515">“Doughnut”</span>;
 chart.Children.Add(dataSeries);
 LayoutRoot.Children.Clear();
 LayoutRoot.Children.Add(chart);</span></pre>
<pre><span style="font-size: 10pt">}</span></pre>
<p>Las siguientes imágenes muestran algunos de los resultados que podemos obtener al utilizar el código arriba expuesto.</p>
<p><strong>Doughnut Charts</strong></p>
<p><a title="Visifire Sample" href="http://www.flickr.com/photos/8031636@N06/2416712906/"><img src="http://farm3.static.flickr.com/2230/2416712906_2601b11ae2_o.png" border="0" alt="Visifire Sample" width="595" height="395" /></a></p>
<p><strong>Pie Charts</strong></p>
<p><a title="Visifire Sample" href="http://www.flickr.com/photos/8031636@N06/2416712982/"><img src="http://farm3.static.flickr.com/2381/2416712982_49cef031ec_o.png" border="0" alt="Visifire Sample" width="596" height="395" /></a></p>
<p><strong>Bars &amp; Columns Charts</strong></p>
<p><a title="Visifire Sample" href="http://www.flickr.com/photos/8031636@N06/2416713020/"><img src="http://farm3.static.flickr.com/2391/2416713020_7b0f066cc6_o.png" border="0" alt="Visifire Sample" width="595" height="395" /></a></p>
<p>Para más información acerca de <a href="http://www.visifire.com" target="_blank">Visifire</a> visiten su sitio donde encontraran gran cantidad de ejemplos, el código de la solución para bajar y su documentación.</p>
<p><img src="http://staff.southworks.net/aggbug.aspx?PostID=94743" alt="" width="1" height="1" /></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025843" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2008/04/15/charts-en-silverlight-fcil-con-visifire/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2008%2F04%2F15%2Fcharts-en-silverlight-fcil-con-visifire%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2008/04/15/charts-en-silverlight-fcil-con-visifire/</feedburner:origLink></item>
		<item>
		<title>ADO.NET Data Services</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025844/</link>
		<comments>http://blogs.southworks.net/parancibia/2007/12/10/adonet-data-services/#comments</comments>
		<pubDate>Mon, 10 Dec 2007 06:43:00 +0000</pubDate>
		<dc:creator>admin</dc:creator>
		
		<category><![CDATA[Astoria]]></category>

		<guid isPermaLink="false">0bfedb5f-1518-4bf4-a7d2-0f90003e0ad2:54433</guid>
		<description><![CDATA[Ya se encuentra disponible la primera entrega de ASP.NET 3.5 Extensions Preview, la cual pueden descargar desde aquí, seguramente el centro de todas las miradas va a estar con ASP.NET MVC, por eso no voy a hablar de él en este post, ya que tanto en los QuickStarts como en el blog de Scott Guthrie [...]]]></description>
			<content:encoded><![CDATA[<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Ya se encuentra disponible la primera entrega de <span><a href="http://www.asp.net/downloads/3.5-extensions/">ASP.NET 3.5 Extensions Preview</a>, la cual pueden descargar desde <a href="http://www.microsoft.com/downloads/details.aspx?FamilyId=A9C6BC06-B894-4B11-8300-35BD2F8FC908&amp;displaylang=en">aquí</a>, seguramente el centro de todas las miradas va a estar con ASP.NET MVC, por eso no voy a hablar de él en este post, ya que tanto en los <a href="http://quickstarts.asp.net/3-5-extensions/">QuickStarts</a> como en el blog de <a href="http://weblogs.asp.net/scottgu/">Scott Guthrie</a> hay bastantes ejemplos e información sobre el mismo.</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">De lo que si les voy a hablar es de ADO.NET Data Services el cual es el nuevo nombre del antes conocido proyecto <a href="http://staff.southworks.net/blogs/parancibia/archive/2007/10/13/Un-vistazo-a-Astoria.aspx">Astoria</a>, el mismo cuenta con varios cambios desde la CTP anterior, pero para mostrárselos nada mejor que comenzar con un proyecto desde cero. Antes que nada debemos tener instalado además de <a href="http://www.asp.net/downloads/3.5-extensions/">ASP.NET 3.5 Extensions Preview</a></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">, <span><a href="http://www.microsoft.com/downloads/details.aspx?FamilyID=15DB9989-1621-444D-9B18-D1A04A21B519&amp;displaylang=en">ADO.NET Entity Framework Beta 3</a> y <a href="http://www.microsoft.com/downloads/details.aspx?FamilyID=D8AE4404-8E05-41FC-94C8-C73D9E238F82&amp;displaylang=en">ADO.NET Entity Framework Tools Dec 07 CTP</a>.</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Vamos a comenzar creando un nuevo proyecto Web como se ve en la siguiente imagen.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2239/2099938616_85a01a0a3c_o.jpg" alt="" width="600" height="425" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Luego crearemos nuestro modelo de datos</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2166/2099159333_680d3ddf55_o.jpg" alt="" width="600" height="360" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Seleccionamos la opción Generate from Database</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2253/2099938896_c001b3c097_o.jpg" alt="" width="544" height="505" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Elegimos la base de datos a utilizar</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2137/2099159577_4d6abcdeb9_o.jpg" alt="" width="544" height="505" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Seleccionamos las tablas que usaremos para el ejemplo y hacemos click en Finish.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2358/2099939248_a5b3c01923_o.jpg" alt="" width="544" height="505" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Concluido este paso ya tenemos listo nuestro modelo de datos</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2274/2099939378_dd2cbfacc8_o.jpg" alt="" width="600" height="400" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Luego seleccionamos la opción Add new ítem y creamos un nuevo ADO.NET Data Service</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2408/2099939516_98073e2ae6_o.jpg" alt="" width="600" height="360" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Si recuerdan <a href="http://staff.southworks.net/blogs/parancibia/archive/2007/10/13/Un-vistazo-a-Astoria.aspx">mi post anterior sobre Astoria</a>, al llegar a este punto solo debíamos indicar a nuestro WebDataService que utilice nuestro Entity Model y ya estaba todo listo para exponer nuestra data al mundo, pero en esta versión esto ha cambiado, ahora debemos autorizar explícitamente cuales tablas y qué tipo de permiso utilizara nuestro ADO.NET Data Service.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">En la siguiente imagen podrán ver como he referenciado a Microsoft.Data.Web y a mi modelo de datos, también pueden observar como inicializo el servicio, elijo las tablas a utilizar y el tipo de permiso que deseo asignarle.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2215/2099160115_17f804d378_o.jpg" alt="" width="600" height="370" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Para este ejemplo voy a dejar que todas las tablas puedan ser expuestas es por ellos que he puesto un asterisco en lugar del nombre de una tabla en particular.</span></p>
<p><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Web;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Collections.Generic;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.ServiceModel.Web;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Linq;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> Microsoft.Data.Web;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeModel;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> </span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">namespace</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeDataService</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">public</span> <span style="color: blue">class</span> <span style="color: #2b91af">Oranje</span> : <span style="color: #2b91af">WebDataService</span>&lt;<span style="color: #2b91af">OranjeEntities</span>&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">public</span> <span style="color: blue">static</span> <span style="color: blue">void</span> InitializeService(<span style="color: #2b91af">IWebDataServiceConfiguration</span> config)</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>config.SetResourceContainerAccessRule(<span style="color: #a31515">&#8220;*&#8221;</span>, <span style="color: #2b91af">ResourceContainerRights</span>.All);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Si presiono F5 para correr mi aplicación, podrán ver algo similar a lo expuesto en la siguiente imagen.</span></p>
<p></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2083/2099160273_894cefc94d_o.jpg" alt="" width="600" height="481" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Podrán apreciar que el formato en que se está mostrando la información es AtomPub (Atom Publishing Protocol), este es otro de los cambios con respecto a la anterior CTP, también podemos consumir nuestro servicio utilizando JSON.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Si desean investigar más sobre como exponer data a través de ADO.NET Data Services, podrán en encontrar más información <span> </span>y ejemplos en los <a href="http://quickstarts.asp.net/3-5-extensions/adonetdataservice/default.aspx">ASP.NET 3.5 Extensions Preview QuickStarts</a>.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Bien, ahora que ya tenemos nuestro servicio funcionando, vamos a consumirlo, el escenario más común para hacerlo, seria en una aplicación Web, pero para este ejemplo utilizare una aplicación de consola.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Vamos a crear la aplicación de consola para la demo</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2366/2099160615_243f77cac5_o.jpg" alt="" width="600" height="425" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Luego agregaremos una referencia a Microsoft.Data.WebClient en nuestro proyecto</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2113/2099160813_88aeb29045_o.jpg" alt="" width="600" height="340" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Como vamos a necesitar representar la entidades definidas por el Data Service, deberíamos crearlas a las mismas en nuestro proyecto, para ello utilizaremos la utilidad WebDataGen que se encuentra en la carpeta donde están instaladas las ASP.NET 3.5 Extensions Preview, ejecutaremos la utilidad y le pasaremos los siguientes parámetros.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2150/2099160355_bee02489de_o.jpg" alt="" width="600" height="373" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Entre los cuales se encuentran el nombre del archivo que generaremos con las entidades y la URI donde se encuentra nuestro servicio</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2219/2099160473_b2ba8abb65_o.jpg" alt="" width="600" height="373" /></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Finalizado el proceso ya tendremos listo nuestro modelo de datos para poder ser añadido a nuestra aplicación de ejemplo utilizando la opción Add existing item.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">En el archivo Program.cs de nuestra aplicación de ejemplo vamos a crear un referencia a nuestro entity model.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeModel;</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt">
<p class="MsoNormal" style="margin:0in 0in 10pt">
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Para consumir los datos de nuestro servicio utilizaremos la librería Microsoft.Data.WebClient, la misma cuenta con dos clases, WebDataContext y WebDataQuery, la primera representa el contexto en tiempo de ejecución de un web data service dado, la segunda permite hacer consulta contra un servicio utilizando la sintaxis basada en URIs de ADO.NET Data Service.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">En el siguiente código podemos ver un ejemplo de WebDataContext y WebDataQuery en funcionamiento.</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Collections.Generic;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> Microsoft.Data.WebClient;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Linq;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Text;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeModel;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">namespace</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeDataClient</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">class</span> <span style="color: #2b91af">Program</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">static</span> <span style="color: blue">void</span> Main(<span style="color: blue">string</span>[] args)</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: #2b91af">WebDataContext</span> ctx = <span style="color: blue">new</span> <span style="color: #2b91af">WebDataContext</span>(<span style="color: #a31515">&#8220;http://localhost:6239/Oranje.svc&#8221;</span>);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: #2b91af">WebDataQuery</span>&lt;<span style="color: #2b91af">Players</span>&gt; players = ctx.CreateQuery&lt;<span style="color: #2b91af">Players</span>&gt;(<span style="color: #a31515">&#8220;/Players&#8221;</span>);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">foreach</span> (<span style="color: #2b91af">Players</span> p <span style="color: blue">in</span> players)</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: #2b91af">Console</span>.WriteLine(<span style="color: #a31515">&#8220;Number:&#8221;</span> + p.Number + <span style="color: #a31515">&#8221; Name: &#8220;</span> + p.Name + <span style="color: #a31515">&#8221; Age: &#8220;</span> + p.Age);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt">
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Presionando Ctrl+F5 deberíamos de obtener un resultado similar al de la siguiente imagen.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2259/2100213940_7866cc22c0_o.jpg" alt="" width="500" height="311" /></span></p>
<p><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Además de utilizar WebDataContext y WebDataContext.CreateQuery para consultar un Data Service tambien es posible hacer consultas utilizando LINQ, como verán en el siguiente ejemplo la librería Microsoft.Data.WebClient se encarga de mapear las instrucciones LINQ contra la URI del Data Service y recuperar los recursos especificados como objetos .NET </span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Collections.Generic;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Linq;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> System.Text;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">using</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeModel;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">namespace</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> OranjeDataClient</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">class</span> <span style="color: #2b91af">Program</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">static</span> <span style="color: blue">void</span> Main(<span style="color: blue">string</span>[] args)</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: #2b91af">OranjeEntities</span> ctx = <span style="color: blue">new</span> <span style="color: #2b91af">OranjeEntities</span>(<span style="color: #a31515">&#8220;http://localhost:6239/Oranje.svc&#8221;</span>);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span style="color: blue"> var</span> q = <span style="color: blue">from</span> p <span style="color: blue">in</span> ctx.Players</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">orderby</span> p.Age</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">select</span> p;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: blue">foreach</span> (<span style="color: blue">var</span> player <span style="color: blue">in</span> q)</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>{</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: #2b91af">Console</span>.WriteLine(<span style="color: #a31515">&#8220;Number:&#8221;</span> + player.Number + <span style="color: #a31515">&#8221; Name: &#8220;</span> + player.Name + <span style="color: #a31515">&#8221; Age: &#8220;</span> + player.Age);</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span>}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">}</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Presionamos Ctrl+F5<span> </span>y deberíamos de ver los datos de las jugadoras ordenados por edad.</span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><img src="http://farm3.static.flickr.com/2240/2100213852_4e8154882b_o.jpg" alt="" width="600" height="373" /></span></p>
<p></span></p>
<p class="MsoNormal" style="margin:0in 0in 10pt">
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'">Nuevamente y para finalizar les dejo el enlace a los <a href="http://quickstarts.asp.net/3-5-extensions/adonetdataservice/default.aspx">QuickStarts</a> donde podrán encontrar información más detallada.</span></p>
<p><img src="http://staff.southworks.net/aggbug.aspx?PostID=54433" alt="" width="1" height="1" /></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025844" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2007/12/10/adonet-data-services/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2007%2F12%2F10%2Fadonet-data-services%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2007/12/10/adonet-data-services/</feedburner:origLink></item>
		<item>
		<title>Review: The Laws of Simplicity</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025845/</link>
		<comments>http://blogs.southworks.net/parancibia/2007/12/07/review-the-laws-of-simplicity/#comments</comments>
		<pubDate>Fri, 07 Dec 2007 18:05:00 +0000</pubDate>
		<dc:creator>admin</dc:creator>
		
		<category><![CDATA[Books]]></category>

		<guid isPermaLink="false">0bfedb5f-1518-4bf4-a7d2-0f90003e0ad2:54355</guid>
		<description><![CDATA[En la actualidad vemos como proveedores de servicios y fabricantes de productos tratan de lograr que los mismos sean simples de entender, simples de usar, esta tarea no es para nada simple y no quiere decir que los productos o servicios que se ofrezcan deban carecer de funciones o características, si tomamos como ejemplo al [...]]]></description>
			<content:encoded><![CDATA[<p>En la actualidad vemos como proveedores de servicios y fabricantes de productos tratan de lograr que los mismos sean simples de entender, simples de usar, esta tarea no es para nada simple y no quiere decir que los productos o servicios que se ofrezcan deban carecer de funciones o características, si tomamos como ejemplo al iPod el cual es el referente en lo que a simplicidad hablamos, podemos ver que de por sí es un aparato complejo, cargado de características, pero a sus vez no solo es simple de usar sino que también transmite la sensación de simplicidad.</p>
<p>Últimamente muchos escriben sobre el concepto de simplicidad, de todo ellos <a href="http://www.media.mit.edu/people/bio_maeda.html" target="_blank">John Maeda</a> se destaca y en su libro <a href="http://lawsofsimplicity.com/" target="_blank">The Laws of Simplicity</a> nos proporciona diez leyes y tres reglas las cuales nos guían en los conceptos que conforman se simples y algunos consejos para aplicarlos en nuestro trabajo diario, de todas las leyes la decima engloba a las demás y dice</p>
<p align="center"><span style="font-family: Tahoma;font-size: x-small"><strong>La simplicidad consiste en sustraer lo que es obvio y añadir lo específico</strong></span></p>
<p><a href="http://lawsofsimplicity.com/">The Laws of Simplicity</a> está traducido a muchos idiomas, incluido el español, se puede conseguir en <a href="http://www.amazon.com/Laws-Simplicity-Design-Technology-Business/dp/0262134721/ref=sr_1_2?ie=UTF8&amp;s=books&amp;qid=1197037223&amp;sr=1-2" target="_blank">Amazon</a> o en cualquier librería de primera línea, el libro es pequeño, cerca de cien páginas y es de una lectura muy fluida con ejemplos prácticos y de la vida real.</p>
<p>Para ir finalizando les dejo el link a la página oficial del libro donde encontraran notas y artículos relacionados con el mismo y un video con una presentación de <a href="http://www.media.mit.edu/people/bio_maeda.html" target="_blank">John Maeda</a> en TED.</p>
<p><a href="http://lawsofsimplicity.com/" target="_blank">The Laws of Simplicity Homepage</a></p>
<p><a href="http://www.ted.com/index.php/talks/view/id/172/" target="_blank">TED Talks John Maeda: Simplicity patterns</a></p>
<p><a href="http://www.flickr.com/photos/8031636@N06/2093454634/"><img src="http://farm3.static.flickr.com/2215/2093454634_27513a0ff0_o.jpg" border="0" alt="The Laws of Simplicity" width="600" height="450" /></a><img src="http://staff.southworks.net/aggbug.aspx?PostID=54355" alt="" width="1" height="1" /></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025845" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2007/12/07/review-the-laws-of-simplicity/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2007%2F12%2F07%2Freview-the-laws-of-simplicity%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2007/12/07/review-the-laws-of-simplicity/</feedburner:origLink></item>
		<item>
		<title>Novedades de WPF 3.5 - Viewport2DVisual3D</title>
		<link>http://feeds.southworks.net/~r/parancibia/~3/321025846/</link>
		<comments>http://blogs.southworks.net/parancibia/2007/10/29/novedades-de-wpf-35-viewport2dvisual3d/#comments</comments>
		<pubDate>Mon, 29 Oct 2007 06:43:00 +0000</pubDate>
		<dc:creator>admin</dc:creator>
		
		<category><![CDATA[WPF]]></category>

		<guid isPermaLink="false">0bfedb5f-1518-4bf4-a7d2-0f90003e0ad2:42067</guid>
		<description><![CDATA[Una de las nuevas características de WPF 3.5 es Viewport2DVisual3D, esta nos permite tomar un objeto 2D y visualizarlo en un espacio 3D, esto lo podíamos hacer anteriormente con 3D Tools for WPF pero ahora al menos algunas de estas características son parte del framework, para mostrarles su uso voy amigrar la demo que utilice en [...]]]></description>
			<content:encoded><![CDATA[<p>Una de las nuevas características de WPF 3.5 es Viewport2DVisual3D, esta nos permite tomar un objeto 2D y visualizarlo en un espacio 3D, esto lo podíamos hacer anteriormente con <a href="http://www.codeplex.com/3DTools">3D Tools for WPF</a> pero ahora al menos algunas de estas características son parte del framework, para mostrarles su uso voy amigrar la demo que utilice en el <a href="http://staff.southworks.net/blogs/parancibia/archive/2007/10/25/Code-Camp-Buenos-Aires-2007-_1320_-El-d_ED00_a-despu_E900_s_2E00_.aspx">Code Camp</a>, cuyo código pueden bajar desde <a href="http://cid-7cc9f2b7406f44d0.skydrive.live.com/self.aspx/Public/Scene3D.zip">aquí</a> o consultar mas en profundidad en este <a href="http://paulosay.spaces.live.com/blog/cns!7CC9F2B7406F44D0!691.entry">post</a>, para que pase de usar <a href="http://www.codeplex.com/3DTools">3D Tools for WPF</a> por Viewport2DVisual3D.</p>
<p>Pasemos a ver el código, verán que aun sigo usando 3D Tools for WPF, pero tan solo para utilizar el TrackBallDecorator, que es quien me permite mover el modelo utilizando el mouse, el resto del código es muy fácil de seguir, en el resource he creado un mesh, luego configuro la cámara, la luz y por ultimo pinto mi mesh con un MediaElement.</p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Window</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> x</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">:</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red">Class</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;DemoViewport2DVisual3D.Window1&#8243;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: red"><span> </span>xmlns</span><span style="color: blue">=&#8221;http://schemas.microsoft.com/winfx/2006/xaml/presentation&#8221;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: red"><span> </span>xmlns</span><span style="color: blue">:</span><span style="color: red">x</span><span style="color: blue">=&#8221;http://schemas.microsoft.com/winfx/2006/xaml&#8221;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: red"><span> </span>xmlns</span><span style="color: blue">:</span><span style="color: red">local</span><span style="color: blue">=&#8221;clr-namespace:_3DTools;assembly=3DTools&#8221;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: red"><span> </span>Title</span><span style="color: blue">=&#8221;Viewport2DVisual3D Demo&#8221;</span><span style="color: red"> Height</span><span style="color: blue">=&#8221;600&#8243;</span><span style="color: red"> Width</span><span style="color: blue">=&#8221;600&#8243;&gt;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Window.Resources</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">MeshGeometry3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> x</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">:</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red">Key</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;3dMesh&#8221;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Positions</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;-1,1,0 -1,-1,0 1,-1,0 1,1,0&#8243;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"><span> </span><span style="color: red"><span> </span>TextureCoordinates</span><span style="color: blue">=&#8221;0,0 0,1 1,1 1,0&#8243;</span><span style="color: red"> TriangleIndices</span><span style="color: blue">=&#8221;0 1 2 0 2 3&#8243;/&gt;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Window.Resources</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">local</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">:</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">TrackballDecorator</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> HorizontalAlignment</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;Stretch&#8221;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> VerticalAlignment</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;Stretch&#8221;&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport3D.Camera</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">PerspectiveCamera</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Position</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;0,0,4&#8243;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> <span style="color: red"><span> </span>FieldOfView</span><span style="color: blue">=&#8221;45&#8243; /&gt;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport3D.Camera</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">ModelVisual3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue"> &gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">ModelVisual3D.Content</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">AmbientLight</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Color</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;#FFFFFFFF&#8221;/&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">ModelVisual3D.Content</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">ModelVisual3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Geometry</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;{</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">StaticResource</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif'"> 3<span style="color: blue">dMesh}&#8221;&gt;</span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D.Visual</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">MediaElement</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Source</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;silverlight.wmv&#8221;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Stretch</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;Uniform&#8221;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Volume</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;0&#8243;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> LoadedBehavior</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;Play&#8221;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Width</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;448&#8243;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Height</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;256&#8243;/&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D.Visual</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D.Material</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">DiffuseMaterial</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: red"> Viewport2DVisual3D.IsVisualHostMaterial</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">=&#8221;true&#8221;/&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D.Material</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport2DVisual3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Viewport3D</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">local</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">:</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">TrackballDecorator</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515"><span> </span></span></p>
<p class="MsoNormal" style="margin:0in 0in 0pt">
<p class="MsoNormal" style="margin:0in 0in 10pt"><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&lt;/</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: #a31515">Window</span><span style="font-size: 10pt;font-family: 'Tahoma','sans-serif';color: blue">&gt;</span></p>
<p>Al ejecutar el ejemplo deberíamos de ver algo como lo siguiente.</p>
<p><a href="http://www.flickr.com/photos/8031636@N06/1795981843/"><img src="http://farm3.static.flickr.com/2073/1795981843_594f98387e_o.jpg" border="0" alt="Viewport2DVisual3D" width="600" height="600" /></a></p>
<p><img src="http://staff.southworks.net/aggbug.aspx?PostID=42067" alt="" width="1" height="1" /></p>
<img src="http://feeds.southworks.net/~r/parancibia/~4/321025846" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blogs.southworks.net/parancibia/2007/10/29/novedades-de-wpf-35-viewport2dvisual3d/feed/</wfw:commentRss>
		<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetItemData?uri=parancibia&amp;itemurl=http%3A%2F%2Fblogs.southworks.net%2Fparancibia%2F2007%2F10%2F29%2Fnovedades-de-wpf-35-viewport2dvisual3d%2F</feedburner:awareness><feedburner:origLink>http://blogs.southworks.net/parancibia/2007/10/29/novedades-de-wpf-35-viewport2dvisual3d/</feedburner:origLink></item>
	<feedburner:awareness>http://api.feedburner.com/awareness/1.0/GetFeedData?uri=parancibia</feedburner:awareness></channel>
</rss>
