<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	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:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>ensandecer de um computólogo &#187; Tech</title>
	<atom:link href="http://danielmartins.eti.br/blog/category/tech/feed/" rel="self" type="application/rss+xml" />
	<link>http://danielmartins.eti.br/blog</link>
	<description>return 1;</description>
	<lastBuildDate>Thu, 15 Dec 2011 05:05:07 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3</generator>
		<item>
		<title>Estudando python EFL &#8211; edição especial :-P</title>
		<link>http://danielmartins.eti.br/blog/2008/12/16/estudando-python-efl-edicao-especial-p/</link>
		<comments>http://danielmartins.eti.br/blog/2008/12/16/estudando-python-efl-edicao-especial-p/#comments</comments>
		<pubDate>Tue, 16 Dec 2008 05:06:38 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Computação]]></category>
		<category><![CDATA[Dicas & How To]]></category>
		<category><![CDATA[efl]]></category>
		<category><![CDATA[maemo]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[python efl enlightenment]]></category>
		<category><![CDATA[python efl treinamento]]></category>

		<guid isPermaLink="false">http://danielmartins.eti.br/blog/?p=333</guid>
		<description><![CDATA[Bom, irei participar de um treinamento de python EFL onde o instrutor será o Gustavo Barbiery, tentarei fazer um resumo do curso até mesmo para que me sirva de referência futura e postarei aqui no blog, tenho conhecidos que trabalham e estudam também EFL e python e que ficaram tristes por não poderem participar do [...]]]></description>
			<content:encoded><![CDATA[<p>Bom, irei participar de um treinamento de python EFL onde o instrutor será o <a href="http://blog.gustavobarbieri.com.br/" target="_blank">Gustavo Barbiery</a>, tentarei fazer um resumo do curso até mesmo para que me sirva de referência futura e postarei aqui no blog, tenho conhecidos que trabalham e estudam também EFL e python e que ficaram tristes por não poderem participar do treinamento, infelizmente não é possível que todos participem. Mas como sou um cara legal e sempre gostei de compartilhar conhecimento <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' />  , além de fazer o resumo do curso que conterá muito código de exemplo. Irei também reportar a evolução do curso pelo <a href="http://twitter.com/daniel_martins" target="_blank">meu Twitter</a> em tempo real. Para isso instalei um widget no sidebar do wordpress, o qual vocês podem acompanhar ao seu lado direito da tela.</p>
<p>Para quem tem twitter, pode me seguir e fazer perguntas sobre a tecnologia em tempo real, para quem não tiver, pode deixar comentário no blog pois ficarei o tempo todo on line. Não atenderei todas as perguntas, irei filtrar as mais interessantes, portanto caprichem nas perguntas (se houver) que na primeira oportunidade que surgir perguntarei ao Gustavo e postarei no resumo do blog a resposta, sei que muitas das minhas dúvidas são as dúvidas de outros que começaram a trabalhar com EFL a pouco tempo, portanto muita coisa será respondida no resumo que farei do curso e não de forma imediata.</p>
<p>Qualquer coisa, seja sugestão ou crítica comenta ai. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p><strong>Update</strong>: Posts só sairão, no final de semana. Tá cruel, muita coisa pra fazer/estudar. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_neutral.gif' alt=':-|' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2008/12/16/estudando-python-efl-edicao-especial-p/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Estudando python EFL &#8211; parte 2</title>
		<link>http://danielmartins.eti.br/blog/2008/12/13/estudando-python-efl-parte-2/</link>
		<comments>http://danielmartins.eti.br/blog/2008/12/13/estudando-python-efl-parte-2/#comments</comments>
		<pubDate>Sat, 13 Dec 2008 19:37:03 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[canola2]]></category>
		<category><![CDATA[Comunidades]]></category>
		<category><![CDATA[Dicas & How To]]></category>
		<category><![CDATA[efl]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://danielmartins.eti.br/blog/?p=303</guid>
		<description><![CDATA[Continuando a série de post sobre a tecnologia EFL , a qual estou estudando e trabalhando. Este post visa ser uma visão geral do que é e como funciona esta tecnologia e está respectivamente divido em duas seções: O que é ? e Como Funciona ?. O que é ? EFL é um conjunto de [...]]]></description>
			<content:encoded><![CDATA[<p>Continuando a série de <a title="Categoria EFL" href="http://danielmartins.eti.br/blog/category/efl/" target="_blank">post sobre a tecnologia EFL</a> , a qual estou estudando e trabalhando.</p>
<p>Este post visa ser uma visão geral do que é e como funciona esta tecnologia e está respectivamente divido em duas seções: O que é ? e Como Funciona ?.</p>
<p><strong>O que é ?</strong></p>
<p>EFL é um conjunto de bibliotecas escrita em C para facilitar o desenvolvimento de um gerenciador de janelas baseado no X, o famoso <a title="Enlightenement" href="http://www.enlightenment.org/" target="_blank">Enlightenment</a>, o qual possui muitos recursos <strong>eye candy</strong> sem precisar de gerenciadores de janela com suporte a aceleração através de OpenGL, ex: <a href="http://pt.wikipedia.org/wiki/Compiz" target="_blank">compiz</a>. E sempre fez um ótimo trabalho sem esse tipo de recurso.</p>
<p>Segui alguns vídeos coletados no youtube do Enlightenment em ação.</p>
<p><object width="425" height="344" data="http://www.youtube.com/v/2yDB60wqgN4&amp;hl=en&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="src" value="http://www.youtube.com/v/2yDB60wqgN4&amp;hl=en&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p><object width="425" height="344" data="http://www.youtube.com/v/nmlmMM42C30&amp;hl=en&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="src" value="http://www.youtube.com/v/nmlmMM42C30&amp;hl=en&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p>E existem <a href="http://www.youtube.com/results?search_query=Enlightenment+e17&amp;search_type=&amp;aq=f" target="_blank">outros mais</a>. É possível implementar funcionalidades muito parecidas com as do iphone, por exemplo:</p>
<p><object width="425" height="344" data="http://www.youtube.com/v/3UsPer9c5bg&amp;hl=en&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="src" value="http://www.youtube.com/v/3UsPer9c5bg&amp;hl=en&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p>E olha um teclado virtual feito com EFL baseado no teclado do iPhone, feito pelo <a href="http://blog.gustavobarbieri.com.br/2007/07/24/iphone-like-virtual-keyboard-for-n800/" target="_blank">Gustavo Barbiery</a>, um dos geeks que trabalha com EFL aqui no Brasil e que por sinal próxima semana estará em Manaus para dar um treinamento de EFL na <a href="http://fpf.br" target="_blank">FPF</a>¸após eu ter tido muitas conversas com o <a href="http://www.gavinho.eti.br/wiki/index.php?title=P%C3%A1gina_principal" target="_blank">chefinho</a>. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p><object width="425" height="344" data="http://www.youtube.com/v/TrWpUBTDDr0&amp;color1=0xb1b1b1&amp;color2=0xcfcfcf&amp;feature=player_embedded&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="src" value="http://www.youtube.com/v/TrWpUBTDDr0&amp;color1=0xb1b1b1&amp;color2=0xcfcfcf&amp;feature=player_embedded&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p>E como o EFL faz muito com pouco processamento, foi portado para outras arquiteturas como ARM, onde roda em dispositivos como o Internet <a href="http://danielmartins.eti.br/blog/2008/10/17/ubuntu-theme-para-o-canola2/" target="_blank">Tablet N810 da Nokia</a> e existem algumas aplicações rodando com EFL, mas a aplicação de referência de uso do EFL no <a href="http://www.maemo.org" target="_blank">Maemo</a> é o <a href="http://openbossa.indt.org.br/canola/" target="_blank">Canola</a>, que é um player para o maemo. Alguns vídeos do canola em ação:</p>
<p><object width="425" height="344" data="http://www.youtube.com/v/bH5zTtHIy2c&amp;hl=en&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="src" value="http://www.youtube.com/v/bH5zTtHIy2c&amp;hl=en&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p><object width="425" height="344" data="http://www.youtube.com/v/FEn_NNkaJ7A&amp;hl=en&amp;fs=1" type="application/x-shockwave-flash"><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="src" value="http://www.youtube.com/v/FEn_NNkaJ7A&amp;hl=en&amp;fs=1" /><param name="allowfullscreen" value="true" /></object></p>
<p>E roda também em celulares, e já está sendo feito uma plataforma completa para dispositivos móveis, o Illumine, e um dos geeks é um dos criadores do EFL, o Rasterman (Carsten Haitzler)<span> e olhem só sua gang que já roda illumine:</span></p>
<div class="wp-caption alignnone" style="width: 494px"><img title="Rasterman Gangs" src="http://www.rasterman.com/files/the-gang-03.jpg" alt="Rasterman Gangs" width="484" height="480" /><p class="wp-caption-text">Rasterman Gang&#39;s</p></div>
<p>E tudo isso e muito mais foi desenvolvido primariamente com EFL, Ficou afim de entender melhor e começar a desenvolver ? Bom&#8230;. posso guiá-lo pelo caminho que percorri no estudo. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p><strong>Como funciona ?</strong></p>
<p>Já que na <a title="Estudando python EFL  - parte 1" href="http://danielmartins.eti.br/blog/2008/08/23/estudando-python-efl-parte-1/" target="_blank">primeira parte</a> instalamos as técnologias básicas(ecore, evas, edje), vamos dá uma olhada em seu funcionamento.</p>
<p>Bem, vamos começar pelo começo. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p>Arquitetura completa do EFL.</p>
<p><img class="alignnone" title="Arquitetura EFL." src="http://www.enlightenment.org/p/about/efl/d/efl.png" alt="" width="512" height="306" /></p>
<p>Concentre-se na parte azul da arquitetura, o core EFL.</p>
<p><strong>Evas</strong> é o canvas onde tudo é renderizado e também gera sinais para aplicação.</p>
<p><strong>Ecore</strong> é o responsável por capturar todos os eventos de uma janela originados do <a href="http://pt.wikipedia.org/wiki/X11" target="_blank">X11</a> e direcionar esses eventos para os devidos callbacks, possui também um mecanismo de MainLoop e uma série de ferramentas que auxiliam o trabalho com EFL e tarefas comuns de programação.</p>
<p>Alguns componentes do Ecore:</p>
<ul>
<li>Ecore_Con &#8211; Comunicação em rede</li>
<li>Ecore_IPC &#8211; Comunicação entre processos</li>
<li>Ecore_Config &#8211; Sistema de configuração</li>
<li>e outros.</li>
</ul>
<p><strong>Edje </strong>é um meio de separar o código da aplicação do código da interface, basicamente é o responsável por te prover o mecanismo de manipulação de objetos da interface, ou seja, manipular o canvas(evas) de forma descritiva e orientada a estados. Apartir do momento que você faz essa separação ou dividi a aplicação em camadas, você imediatamente ganha vantagens, como por exemplo no Enlightenment e no canola a interface é feita com Edje e por isso possui um mecanismo de Temas(Themes) avançado e flexível de temas, ou seja, você pode mudar toda a interface sem mexer no código da aplicação.</p>
<p>Fazendo uma analogia a arquitetura de desenvolvimento web, seria mais ou menos assim, olhe a figura do MVC abaixo</p>
<p><img class="size-full wp-image-320 alignleft" title="modelviewcontrollerdiagram" src="http://danielmartins.eti.br/blog/wp-content/uploads/2008/12/modelviewcontrollerdiagram.png" alt="modelviewcontrollerdiagram" width="321" height="151" />Sabemos que no desenvolvimento web, o <strong>Model </strong>é responsável pela lógica de negócio da aplicação, o <strong>Controller</strong> é responsável por capturar as requisições que vem da <strong>View</strong> e processa-lás junto a <strong>Model</strong> e então devolver a resposta a <strong>View</strong>, a <strong>View</strong> é a camada de apresentação que no contexto web é o html/css/javascript.</p>
<p>Olhando essa arquitetura MVC podemos fazer a seguinte analogia, que o <strong>View</strong> é o <strong>Edje</strong>, o <strong>Controller</strong> é o <strong>Ecore</strong>. E o <strong>Evas </strong> é o browser onde tudo é renderizado. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p>Consegui explicar alguma coisa ? Se não,  deixe um comentário.</p>
<p>Falei alguma besteira ? Se sim, deixe um comentário corrigindo e colocarei os devidos créditos.</p>
<p>Próximos posts (Aguardem):</p>
<p>Estudando python EFL &#8211; parte 3 (Ecore-Evas)</p>
<p>Estudando python EFL &#8211; parte 4 (Edje)</p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2008/12/13/estudando-python-efl-parte-2/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Lançamento do grupo Web2.0 Manaus com Harald Kirschner</title>
		<link>http://danielmartins.eti.br/blog/2008/09/15/lancamento-do-grupo-web20-manaus-com-harald-kirschner/</link>
		<comments>http://danielmartins.eti.br/blog/2008/09/15/lancamento-do-grupo-web20-manaus-com-harald-kirschner/#comments</comments>
		<pubDate>Mon, 15 Sep 2008 15:21:38 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[amazonas]]></category>
		<category><![CDATA[Computação]]></category>
		<category><![CDATA[Comunidade]]></category>
		<category><![CDATA[Comunidades]]></category>
		<category><![CDATA[Dicas & How To]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[manaus]]></category>
		<category><![CDATA[mootools]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[YUI]]></category>
		<category><![CDATA[javascript mootools web2.0 manaus amazonas]]></category>

		<guid isPermaLink="false">http://danielmartins.eti.br/blog/?p=208</guid>
		<description><![CDATA[Na sexta (12/09/08) foi o lançamento do grupo Web2.0 Manaus com o apoio do INdT e contou com um desenvolvedor do core do mootools falando sobre web2.0 e mostrando casos de uso do mootools. O Evento ocorreu no auditório da UniLasalle de manaus e contou com auditório cheio, eu inclusive que cheguei 15 minutos atrasado [...]]]></description>
			<content:encoded><![CDATA[<p>Na sexta (12/09/08) foi o lançamento do grupo <a title="Web2.0 Manaus" href="http://groups.google.com.br/group/web20_manaus" target="_blank">Web2.0 Manaus</a> com o apoio do <a title="INdT" href="http://www.indt.org.br/institutional/index.php" target="_blank">INdT</a> e contou com um desenvolvedor do core do <a href="http://mootools.net/" target="_blank">mootools</a> falando sobre web2.0 e mostrando casos de uso do mootools.</p>
<p>O Evento ocorreu no auditório da <a href="http://www.lasalle.edu.br/unilasalle-am/" target="_blank">UniLasalle de manaus</a> e contou com auditório cheio, eu inclusive que cheguei 15 minutos atrasado tive que sentar no chão <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> .</p>
<p>Bom, o evento foi composto por 2 palestras:</p>
<ul>
<li><span>Palestra 1:</span>
<ul>
<li><span> WEB 2.0  Oportunidades, e novas tendências.</span><span> <strong>Álvaro Mota Gonçalves</strong>, INdT</span><span> </span></li>
<li><span>Open-WEB</span><span>.  Harald Kirschner, WEB 2.0 developer and co-developer Mootools project</span></li>
</ul>
</li>
</ul>
<ul>
<li><span> </span><span>Palestra 2</span><span> </span>
<ul>
<li><span>WEB 2.0 v Overview de Tecnologias WEB   2.0. </span><span><a title="Harald Kirschner Journal and Project Repository" href="http://digitarald.de/" target="_blank"><strong>Harald  Kirschner</strong></a>, front-end web  developer specialist, core developer of  MooTools project </span></li>
</ul>
</li>
</ul>
<p>O Álvaro Mota Gonçalves começou falando da estratégia da Nokia que mudou, e agora tem um foco mais aberto para o provimento de serviços web e levar a mesma experiência encontrada no uso de serviços web no pc com browser só que através do celular de forma móvel(<strong>mobile</strong>), o que é uma tendência hoje em dia de <strong>fato</strong>. Uma tecnologia que corresponde a este incentivo da Nokia para com a melhor experiencia de serviços web no celular é o <a title="WebRunTime" href="http://www.forum.nokia.com/main/resources/technologies/browsing/widgets.html" target="_blank"><strong>WebRunTime</strong>(<strong>WRT</strong>)</a>. No quesito <strong>provimento de serviços</strong> a gente pode ver a investida da Nokia com o lançamento do <a title="Ovi Services por Nokia" href="http://www.ovi.com/services/" target="_self">Ovi.</a></p>
<p>Foi dito também que o mercado de trabalho estão a procura por profissionais de desenvolvimento web2.0, não lembro qual foi o site que o Álvaro mostrou onde ele fez uma pesquisa e retornou mais de 2000 empregos em aberto para se trabalhar com web2.0, ou seja, <strong>oportunidade</strong>.</p>
<p>A palestra mais esperada(pelo menos por mim), era a do Harald a qual pode ser encontrada <a href="http://digitarald.de/box/harald-web-20.zip" target="_blank">aqui</a> , achei que  ele iria se aprofundar mais na explicação de web2.0 falando sobre microformats, WRT e outros conceitos e tecnologias que ainda não parei para estudar, mais o foco da palestra dele era falar de web2.0 para pessoas que não sabiam ou sabiam pouco o que é web2.0.</p>
<p>O Harald falou um pouco desse &#8220;compra-compra&#8221; que vemos hoje em dia de grandes empresas comprando as menores que oferecem algum serviço interessante, e ele até comentou &#8220;<strong>Quer ficar milhionário ? É só fazer um serviço inovador e publicar na web..</strong>&#8221; e logo depois complementou &#8220;<strong>só não é tão fácil fazer um..</strong>&#8221; <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> . Um fato que me chamou atenção foi a compra do <a title="GrandCentral" href="http://www.grandcentral.com/home" target="_blank"><strong>GrandCentral</strong></a> pelo google, o qual eu nem fazia idéia que existia, trata-se de um serviço de gerenciamento de ligações, tem muitas funcionalidades interessantes, vale a pena dá uma olhada, é uma pena que o serviço ainda não está disponí­vel para o Brasil, mas vocé pode solicitar uma notificação quando o serviço estiver disponí­vel.</p>
<p>Além disso ele mostrou uma tabela de serviços comparativos, de 1.0 para 2.0</p>
<p>Como por exemplo:</p>
<table style="height: 116px;" border="0" width="313">
<tbody>
<tr>
<td style="text-align: center;"><strong>1.0</strong></td>
<td style="text-align: center;"><strong>2.0</strong></td>
</tr>
<tr>
<td style="text-align: center;">DoubleClick</td>
<td>
<p style="text-align: center;">Google AdSense</p>
</td>
</tr>
<tr>
<td style="text-align: center;">Ofoto</td>
<td>
<p style="text-align: center;">Flickr</p>
</td>
</tr>
<tr>
<td style="text-align: center;">Mp3.com</td>
<td>
<p style="text-align: center;">last.fm</p>
</td>
</tr>
<tr>
<td style="text-align: center;">Britannica On line</td>
<td>
<p style="text-align: center;">Wikipedia</p>
</td>
</tr>
<tr>
<td style="text-align: center;">Personal Websites</td>
<td>
<p style="text-align: center;">Blogging</p>
</td>
</tr>
</tbody>
</table>
<p>E outros como pode ser visto na <a href="http://digitarald.de/box/harald-web-20.zip" target="_blank">apresentação dele</a>.</p>
<p>Falou que os princípios da Web2.0 são:</p>
<p><strong> Open Source &#8211; Liberação das informações</strong><br />
<strong> Communication &#8211; Usuários</strong><br />
<strong> Design &#8211; Nova arquitetura de interfaces com o usuário</strong></p>
<p>Pra mim ficou meio misturado a afirmação de que o relacionamento do OpenSource com a web2.0 seja a liberação de informações no sentido de <strong>Content Syndication</strong>, <strong>Web Feed</strong>(RDF, Atom e etc), <strong>WebServices</strong> e <strong>APIs</strong> na minha opnião isso tem haver com OpenData e não com OpenSource, de fato há muita semelhança no modelo colaborativo de projetos OpenSource de código aberto para com serviços OpenData de compartilhamento de informações e não dúvido que a web2.0 com a semântica de <strong>OpenData</strong> tenha se baseado no modelo colaborativo do OpenSource. Eu acredito que um termo melhor seria <strong>OpenData</strong>.</p>
<p>Mostrou 1 exemplo de como ganhar dinheiro com a web2.0, usando o <a title="Amazon Web Services" href="http://www.amazon.com/AWS-home-page-Money/b?ie=UTF8&amp;node=3435361" target="_blank"><strong>Amazon Web Service</strong></a>, o qual a cada livro vendido que você indicou em seu site/blog você ganha dinheiro.(O qual estarei botando em breve no meu blog <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_razz.gif' alt=':-P' class='wp-smiley' /> ).</p>
<p>Dando continuidade no quesito <strong>oportunidades,</strong> segundo Harald o que você precisa saber para arrumar um bom emprego no mercado de web2.0:</p>
<ul>
<li><strong>Content Syndication</strong></li>
<li><strong>Web feeds</strong></li>
<li><strong>RDF</strong></li>
<li><strong>Atom</strong></li>
<li><strong>Web services and APIs</strong></li>
<li><strong>Communication with XML or JSON</strong></li>
<li><strong>REST</strong></li>
<li><strong>SOAP(WSDL)</strong></li>
</ul>
<p>Algumas passagens me chamaram atenção como a do <strong>Tim O&#8217;Reilly</strong> sobre web2.0, resumindo significa que a inteligência coletiva é a base da web2.0, concordo em gênero e grau, você não ?</p>
<p>Houve também slides sobre <a title="Folksonomia" href="http://pt.wikipedia.org/wiki/Folksonomia" target="_blank">Folksonomia</a>[1], Comunicação, melhoramento de Design de interfaces com os novos conceitos RIA(Rich Internet Application) e RUE(Rich User Experience). Essa questão de trazer a experiência de uso de softwares desktop para web entre outras coisas.</p>
<p>Não deixou de falar dos padrões e a acessibilidade o que geralmente é ignorada em detrimento a funcionalidades &#8220;<strong>eye-candy</strong>&#8221; o que julgo muito importante e que nunca deve ser esquecida, ou seja, sua palestra também incluiu Web standards, W3C, leitores de tela, SEO e o funcionamento de softwares web, como estrutura(xhtml), apresentação(css) e etc.</p>
<p>Casos de uso do uso de JavaScript .</p>
<ul>
<li><strong>Melhorias na interação com os forms;</strong></li>
<li><strong>Melhorias na colaboração entre os usuários;</strong></li>
<li><strong>Filtros e manipulação de dados</strong></li>
<li><strong>Autocomplete </strong>(Como o google suggests)</li>
</ul>
<p>Entrando mais na parte técnica, falou sobre o desenvolvimento, que com essa onda de informações e novos conceitos, por onde se basear , citou padrões utilizados e criados pelo yahoo, o <a href="http://developer.yahoo.com/ypatterns/" target="_blank">YPatterns</a> e das alternativas como o <a href="http://ajaxpatterns.org/" target="_blank">Ajax Pattern</a>.</p>
<p>Não deixou de falar também para as pessoas com perfil empreendedor, falou sobre modelo de negócios:</p>
<ul>
<li><strong>Vender <a href="http://pt.wikipedia.org/wiki/API" target="_blank">API</a></strong></li>
<li><strong>Vender serviços</strong></li>
<li><strong>Vender informações</strong></li>
</ul>
<p>Estratégias de expansão para quem já possui serviços:</p>
<ul>
<li><strong>Criar API</strong></li>
<li><strong>Distribuir como OpenSource (Citou também meios de o fazer, através do <a href="http://code.google.com/" target="_blank">google code</a>)</strong></li>
</ul>
<p>Vendeu um pouco de jabá falando sobre o  MooTools e falou um pouco sobre o porque de frameworks.</p>
<p>Nessa hora tomei a liberdade de lhe fazer uma pergunta tendo em vista que o que ele mostrou de exemplo nada foram diferente dos exemplos encontrados utilizando <a href="http://www.jquery.com" target="_blank">JQuery</a> , <a href="http://developer.yahoo.com/yui" target="_blank">YUI</a> e <a href="http://extjs.com/" target="_blank">Ext-js</a> os quais são os que eu uso nos meus projetos.</p>
<p><strong>P:</strong> Perguntei quais eram as principais diferenças entre MooTools e Jquery/YUI  ?<br />
<strong>R: </strong>Ele disse que Mootools é melhor para projetos grandes. Disse também JQuery tem mais classes prontas e que o YUI tem uma estrutura menor do que a MooTools. Na opnião dele YUI é para projetos que precisem de namespaces.</p>
<p>O Evento foi de importância para região, quase não se ver eventos desse tipo por aqui em Manaus. Com certeza desenvolvedores web(como eu) sentem falta.</p>
<p>À coordenação, meus parabéns.</p>
<p>[1] Recomendo a leitura deste post sobre Folksonomia pelo <a href="http://revolucao.etc.br/archives/folksonomia-e-a-maneira-com-que-nos-colocamos-ordem-nas-coisas/" target="_blank">Revolução Etc</a></p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2008/09/15/lancamento-do-grupo-web20-manaus-com-harald-kirschner/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Estudando python EFL &#8211; parte 1</title>
		<link>http://danielmartins.eti.br/blog/2008/08/23/estudando-python-efl-parte-1/</link>
		<comments>http://danielmartins.eti.br/blog/2008/08/23/estudando-python-efl-parte-1/#comments</comments>
		<pubDate>Sun, 24 Aug 2008 01:45:53 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Computação]]></category>
		<category><![CDATA[Dicas & How To]]></category>
		<category><![CDATA[efl]]></category>
		<category><![CDATA[maemo]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[python efl enlightenment]]></category>

		<guid isPermaLink="false">http://danielmartins.eti.br/blog/?p=180</guid>
		<description><![CDATA[Bom, nos últimos tempos tenho estudado o Maemo, que utiliza o GTK como base dos widgets e de expansão da plataforma, mas vendo aplicações como canola que usa EFL, acredito que para uma aplicação mais interativa e eye-candy realmente vale a pena considerar o EFL como tecnologia para o desenvolvimento de aplicações para maemo, imaginei [...]]]></description>
			<content:encoded><![CDATA[<p>Bom, nos últimos tempos tenho estudado o <a title="Maemo" href="http://www.maemo.org" target="_blank">Maemo</a>, que utiliza o GTK como base dos widgets e de expansão da plataforma, mas vendo aplicações como canola que usa <a href="http://www.enlightenment.org/p.php?p=about/efl&amp;l=en" target="_blank">EFL</a>, acredito que para uma aplicação mais interativa e <strong>eye-candy</strong> realmente vale a pena considerar o <a href="http://www.enlightenment.org/p.php?p=about/efl&amp;l=en" target="_blank">EFL</a> como tecnologia para o desenvolvimento de aplicações para maemo, imaginei que a instalação do ambiente fosse algo mais trivial (e é depois que aprendi),  com a ajuda do <a href="http://blog.gustavobarbieri.com.br/" target="_blank">Gustavo Barbiery</a> consegui finalizar a configuração do ambiente. E agora estou escrevendo um how-to para complementar o aprendizado.</p>
<p>A idéia é escrever um conjunto de posts para compartilhar os conhecimentos adquiridos, ajudando os mais novos (assim como eu) entrar no desenvolvimento de aplicações para maemo ou desktop utilizando esta tecnologia. Pretendo nos posts ter 2 seções uma com resumo e outra explicando com mais detalhes para os que não possuem muita experiência com linux possam entender e aprender.</p>
<p>Para constar, estou usando o Ubuntu 8.10.</p>
<p><strong>Resumido:</strong></p>
<ol>
<li>Instalar os pacotes <strong>build-essential libpng12-dev libjpeg62-dev python-setuptools librsvg2-dev python2.5-dev subversion autoconf automake autotools-dev m4 libtool cvs git-core libdbus-1-dev<br />
</strong></li>
<li>Fazer o checkout do código do trunk do svn do enlightenment dos seguintes pacotes: <strong>eina</strong> <strong>eet evas ecore </strong><strong> embryo </strong><strong>edje etk edje_editor.</strong></li>
<li>Compilar os códigos na seguinte ordem: <strong>eina</strong> <strong>eet evas ecore </strong><strong>embryo</strong><strong> edje etk edje_editor.<br />
</strong></li>
<li>Fazer checkout dos bindings do efl para python do SVN: <strong>cython python-efl-utils python-evas python-ecore python-edje</strong> <strong>python-etk</strong>.</li>
<li>Instalar os pacotes na seguinte ordem: <strong>python-efl-utils python-evas.</strong></li>
<blockquote>
<li>Após instalar o <strong>python-evas</strong>, você precisa instalar os headers para compilar o <strong>python-ecore</strong>, então: <strong><em>python setup.py install_headers</em></strong></li>
</blockquote>
<li>Continuar a instalação dos pacotes dos bindings: <strong>python-ecore</strong>, <strong>python-edje e python-etk<br />
</strong></li>
</ol>
<p><strong>Detalhado:</strong></p>
<p>Instalar os pacotes essenciais para compilar os códigos, usando apt-get ou aptitude:</p>
<blockquote><p>$ apt-get install <strong>build-essential libpng12-dev libjpeg62-dev python-setuptools librsvg2-dev python2.5-dev subversion autoconf automake autotools-dev m4 libtool cvs </strong><strong>git-core libdbus-1-dev<br />
</strong></p></blockquote>
<p>Após instalar esses pacotes é preciso fazer o checkout do repositório do enlightenment, você pode criar uma pasta no seu home e entre no diretório:</p>
<blockquote><p>$ mkdir $HOME/e_src</p>
<p>$ cd $HOME/e_src</p></blockquote>
<p>entrar na pasta e fazer o checkout dos códigos <strong>eina</strong> <strong>eet </strong><strong>evas ecore </strong><strong>embryo edje etk edje_editor</strong>:</p>
<blockquote><p>$ svn co https://svn.enlightenment.org/svn/e/trunk/eina eina</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/eet eet</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/evas evas</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/ecore ecore</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/embryo embryo</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/edje edje</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/etk etk</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/edje_editor edje_editor</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/e_dbus e_dbus</p></blockquote>
<p>após ter feito o checkout do código, você precisar exportar os códigos para não mexer no código que veio pelo svn assim você pode aproveitar sempre as alterações do código, para atualizar sua cópia do svn basta:</p>
<blockquote><p>$ svn up</p></blockquote>
<p>crie uma pasta onde conterá o código exportado para compilação e entre na diretório:</p>
<blockquote><p>$ mkdir $HOME/e_src_exported</p>
<p>$ cd $HOME/e_src_exported</p></blockquote>
<p>exportando:</p>
<blockquote><p>$ svn export $HOME/e_src/eina eina</p>
<p>$ svn export $HOME/e_src/eet eet</p>
<p>$ svn export $HOME/e_src/evas evas</p>
<p>$ svn export $HOME/e_src/ecore ecore</p>
<p>$ svn export $HOME/e_src/embryo embryo</p>
<p>$ svn export $HOME/e_src/edje edje</p>
<p>$ svn export $HOME/e_src/e_dbus e_dbus</p></blockquote>
<p>após exportar, precisamos compilar, começaremos pelo <strong>eina </strong>e estes comandos devem ser repetidos para cada diretório:</p>
<blockquote><p>$ cd eina</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>eet</strong>:</p>
<blockquote><p>$ cd eet</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois <strong>evas</strong>:</p>
<blockquote><p>$ cd evas</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois <strong>ecore</strong>:</p>
<blockquote><p>$ cd ecore</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>embryo</strong>:</p>
<blockquote><p>$ cd embryo</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois e por último o <strong>edje</strong>:</p>
<blockquote><p>$ cd edje</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>etk</strong>:</p>
<blockquote><p>$ cd etk</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ sudo ldconfig</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>edje_editor:</strong></p>
<blockquote><p>$ cd edje_editor</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>e_dbus:</strong></p>
<blockquote><p>$ cd e_dbus</p>
<p>$ sh autogen.sh</p>
<p>$ make</p>
<p>$ sudo make install</p>
<p>$ cd ..</p></blockquote>
<p>Antes de instalar os bindings é preciso instalar algumas dependências:</p>
<blockquote><p>$ wget -c http://www.cython.org/Cython-0.10.3.tar.gz</p>
<p>$ git clone git://git.profusion.mobi/users/ulisses/python-dispatcher.git</p></blockquote>
<p>E após, instale o <strong>Cython</strong>:</p>
<blockquote><p>$ tar -zxvf Cython-0.10.3.tar.gz</p>
<p>$ cd Cython-0.10.3</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>e o <strong>Python-Dispather</strong>:</p>
<blockquote><p>$ cd python-dispatcher</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>Após ter compilado e instalado os componentes essenciais do EFL, você precisa compilar e instalar os bindings para python, baixando os pacotes dentro do mesmo diretório pra onde exportou o código do svn:</p>
<blockquote><p>$  svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-evas</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-ecore</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-edje</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-etk</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-e_dbus</p></blockquote>
<p>Exportando:</p>
<blockquote><p>$ cd $HOME/e_src_exported</p>
<p>$ svn export $HOME/e_src/python-evas python-evas</p>
<p>$ svn export $HOME/e_src/python-ecore python-ecore</p>
<p>$ svn export $HOME/e_src/python-edje python-edje</p>
<p>$ svn export $HOME/e_src/python-etk python-etk</p></blockquote>
<p>depois o <strong>python-evas</strong>:</p>
<blockquote><p>$ cd python-evas</p>
<p>$ sudo python setup.py install</p>
<p>$ sudo python setup.py install_headers</p>
<p>$ cd ..</p></blockquote>
<p>depois o  <strong>python-ecore</strong>:</p>
<blockquote><p>$ cd python-ecore</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>python-edje</strong>:</p>
<blockquote><p>$ cd python-edje</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>python-etk</strong>:</p>
<blockquote><p>$ cd python-etk</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>depois o <strong>python-e_dbus</strong>:</p>
<blockquote><p>$ cd python-e_dbus</p>
<p>$ sudo python setup.py install</p>
<p>$ cd ..</p></blockquote>
<p>Pronto! você possui uma instalação funcional.</p>
<p>Para testar, você pode o exemplo que o <a href="http://blog.gustavobarbieri.com.br/2007/06/23/edje-demo-on-n800-application-launcher-mockup/" target="_blank"><strong>Gustavo Barbiery</strong></a> fez, você precisa fazer o checkout:</p>
<blockquote><p>$ mkdir $HOME/efl_demo</p>
<p>$ cd $HOME/efl_demo</p>
<p>$ svn co https://svn.enlightenment.org/svn/e/trunk/BINDINGS/python/python-edje/examples/evas-demo/01-app_launcher 01-app_launcher</p>
<p>$ cd 01-app_launcher</p>
<p>$ edje_cc 01-app_launcher.edc</p>
<p>$ python 01-app_launcher.py</p></blockquote>
<p>Se tudo funcionar,  pronto você realmente tem uma instalação funcional do python efl. <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p>Fontes:</p>
<p><a href="http://wiki.enlightenment.org/index.php/Creating_Edje_User_Interfaces" target="_blank">http://wiki.enlightenment.org/</a></p>
<p>Basicamente, não tem muita referência de instalação do <a href="http://www.enlightenment.org/p.php?p=about/efl&amp;l=en" target="_blank">efl</a> e esse é um dos motivos de eu estar escrevendo o post.</p>
<p>Qualquer coisa comenta ai! <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p><strong>Update 24/01/09</strong>: Adicionado compilação do <strong>e_dbus</strong> e <strong>python-e_dbus</strong>.</p>
<p><strong>Update 01/09/08</strong>: Considerando uma instalação inicial inclui mais alguns pacotes para instalar antes de iniciar a compilação: <strong>autoconf automake autotools-dev m4 libtool</strong></p>
<p><strong>Update 14/10/08</strong>: Houve mudanças nos repositórios do EFL, e agora é preciso compilar também o pacote EINA. Incluído Eina e correções na hora de instalar os bindings</p>
<p><strong>Update 22/12/08</strong>: Esse modo de instalação que fiz funcionava bem com a versão antiga do efl, antes do eina. Atualizei para a versão do SVN e inclui a instalação de mais 2 pacotes do EFL, 1 binding e um utilitário(python-dispatcher) e a remoção do python-efl-utils. E tudo feito no ubuntu 8.10.</p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2008/08/23/estudando-python-efl-parte-1/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>Novo Endereço !</title>
		<link>http://danielmartins.eti.br/blog/2008/05/31/novo-endereco/</link>
		<comments>http://danielmartins.eti.br/blog/2008/05/31/novo-endereco/#comments</comments>
		<pubDate>Sat, 31 May 2008 03:48:32 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Pessoal]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[change url]]></category>

		<guid isPermaLink="false">http://danielmartins.eti.br/blog/?p=170</guid>
		<description><![CDATA[Pois é, mudei o endereço e não fiz nenhum post comentando. Antes era: http://daniel.jb0.org e agora é http://danielmartins.eti.br/blog. Sempre gosto de esta mudando a cara do blog pois acho enjoativo passar muito tempo com o mesmo template. Mudei de endereço e a idéia também é mudar outras coisas, por exemplo, postar no mínimo 4 post/mês, [...]]]></description>
			<content:encoded><![CDATA[<p>Pois é, mudei o endereço e não fiz nenhum post comentando.</p>
<p>Antes era: <span style="text-decoration: line-through;">http://daniel.jb0.org</span> e agora é http://danielmartins.eti.br/blog.</p>
<p>Sempre gosto de esta mudando a cara do blog pois acho enjoativo passar muito tempo com o mesmo template.</p>
<p>Mudei de endereço e a idéia também é mudar outras coisas, por exemplo, postar no mínimo 4 post/mês, ou seja, em média 1 por semana.</p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2008/05/31/novo-endereco/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>YUI + widget DataTable + Ordenação Customizada</title>
		<link>http://danielmartins.eti.br/blog/2007/07/03/yui-widget-datatable-ordenacao-customizada/</link>
		<comments>http://danielmartins.eti.br/blog/2007/07/03/yui-widget-datatable-ordenacao-customizada/#comments</comments>
		<pubDate>Tue, 03 Jul 2007 21:27:57 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Computação]]></category>
		<category><![CDATA[Dicas & How To]]></category>
		<category><![CDATA[FOSS]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[YUI]]></category>

		<guid isPermaLink="false">http://daniel.jb0.org/2007/07/03/yui-widget-datatable-ordenacao-customizada/</guid>
		<description><![CDATA[Eu tenho utilizado exaustivamente a biblioteca de componentes YUI (Yahoo User Interface) para re-redesenhar a interface dos sistemas web que desenvolvo no meu atual local de trabalho. Acredito que há muitas opniões sobre esta nova abordagem de web2.0, desenvolvedores nacionais renomados ja se expressaram sobre esta questão, a web2.0 é boa para diversas situações, mas [...]]]></description>
			<content:encoded><![CDATA[<p>Eu tenho utilizado exaustivamente a biblioteca de componentes <a HREF="http://developer.yahoo.com/yui" TARGET="_blank" TITLE="YUI !">YUI (Yahoo User Interface) </a>para re-redesenhar a interface dos sistemas web que desenvolvo no meu atual local de trabalho.</p>
<p>Acredito que há muitas opniões sobre esta nova abordagem de web2.0, desenvolvedores nacionais renomados ja se expressaram sobre esta questão, a web2.0 é boa para diversas situações, mas não tudo. Um exemplo é o Yahoo Mail Beta, é legal e bonito mas é lento demais, sem falar que no firefox qualquer ação o processamento vai para 100% e isso é caos!. É tudo uma questão de bom senso, usar web2.0 para dá um turbinada na aplicação com validações e chamadas assíncronas, melhorar a usabilidade ou ainda aplicar um comportamento para um determinado componente na tela é uma boa opção. Mas usar web2.0 para emular sistemas que rodam no desktop é complicado, por que são muitos eventos, muitos widgets, muitas regras de css(posicionamento, imagens e etc) e acaba que a aplicação fica extremamente lenta e de difícil manutenção, com certeza não é o que queremos.</p>
<p><span id="more-154"></span></p>
<p>Para quem não conhece, a YUI é uma biblioteca de componentes reutilizaveis feitos em javascript, dhtml e css para facilitar a construção de <a HREF="http://en.wikipedia.org/wiki/Rich_Internet_application" TARGET="_blank">RIA (Rich Internet Applications) </a> , a YUI é produzida primariamente pelos yahoo hackers e também pela comunidade.  É utilizada extensivamente no portal do Yahoo.com[.br] para os softwares web do Yahoo!, com isso podemos entender que é um projeto amplamente suportado. A YUI! é software livre, cuja a licença é uma variação da licença BSD e pode ser encontrada <a TARGET="_blank" HREF="http://developer.yahoo.com/yui/license.txt">aqui.</a></p>
<p>Como eu ainda não postei nada sobre a YUI, neste artigo estarei descrevendo sua utilização básica com um exemplo utilizando o <a TARGET="_blank" HREF="http://www.google.com.br/search?hl=pt-BR&amp;q=define%3Awidget&amp;btnG=Pesquisa+Google&amp;meta=">widget</a> DataTable, para o exemplo ficar ainda mais interessante irei também descrever como customizar a ordenação crescente e decrescente. As informações de exemplo que vamos utilizar são informações referentes a veículos, vamos customizar a ordenação por Placa, a YUI já possui funções de ordenação padrões e que trabalham com alguns tipos definidos.</p>
<p>No inicío de cada bloco de código estarei usando a sigla [COD_[1-9]{2}] para identificar o bloco de código quando o estiver referenciando em outros trechos do artigo, para facilitar a localização.</p>
<p>Pré-requisitos:</p>
<ol>
<li> Conhecimentos básicos em JavaScript.</li>
<li> Você precisa <a HREF="http://developer.yahoo.com/yui/download/" TARGET="_blank">baixar a YUI</a> e carregar os componentes na sua página html ou carregá-las apartir do próprio site do yahoo, para saber mais sobre este serviço entre no <a HREF="http://developer.yahoo.com/yui/articles/hosting/" TARGET="_blank">site.</a>. No desenrolar deste artigo usarei o serviço de hosting da YUI provido pelo Yahoo.</li>
</ol>
<p>Primeiramente é preciso incluir os scripts e os estilos no header do html:</p>
<ul>
<li>Estilos: <strong> [COD_01]</strong><br />
<coolcode lang="html"></p>
<link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.2.2/build/reset/reset-min.css">
<link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.2.2/build/fonts/fonts-min.css">
<link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/2.2.2/build/datatable/assets/datatable.css">
</coolcode>
</li>
<li>Mais estilo(Sobrecarrega algumas regras css, para fins de personalização): <strong>[COD_02]</strong><br />
<coolcode lang="html"></p>
<style type="text/css">
#exemplo {margin:1em;}
#exemplo table {border-collapse:collapse;}
#exemplo th, #exemplo td {border:1px solid #000;padding:.25em;}
#exemplo th {background-color:#696969;color:#fff;} 
#exemplo .yui-dt-odd {background-color:#eee;}
#exemplo em {font-style:italic;}
#exemplo strong {font-weight:bold;}
#exemplo .big {font-size:136%;}
#exemplo .small {font-size:77%}
</style>
<p></coolcode>
</li>
<li>YUI Scripts: <strong>[COD_03]</strong><br />
<coolcode lang="html"><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/yahoo/yahoo-min.js"></script><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/dom/dom-min.js"></script><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/event/event-min.js"></script><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/dragdrop/dragdrop-min.js"></script><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/datasource/datasource-beta-min.js"></script><br />
<script type="text/javascript" src="http://yui.yahooapis.com/2.2.2/build/datatable/datatable-beta-min.js"></script><br />
</coolcode>
</li>
<li>JavaScript para criação do DataTable:<strong>[COD_04]</strong><br />
<coolcode lang="javascript"><br />
	function init()<br />
	{<br />
		/**<br />
		 * Configura namespace para não haver conflitos referentes a nomes<br />
		 * e para facilitar a organização de objetos e etc.<br />
		 */</p>
<p>		 YAHOO.namespace(&#8220;exemplo&#8221;);</p>
<p>		 /**<br />
		  * Dados que serão usados no DataTable<br />
		  */<br />
		  YAHOO.exemplo.dados = {<br />
		  	veiculos: [<br />
		  		{placa:"JTX-0506", vistoria:new Date(2004, 2, 21), km:110000},<br />
		  		{placa:"JYZ-0469", vistoria:new Date(2001, 8, 10), km:65000},<br />
		  		{placa:"JTA-4591", vistoria:new Date(2000, 9, 5), km:45036},<br />
		  		{placa:"XYZ-4587", vistoria:new Date(2000, 5, 8), km:456978}<br />
		  	]<br />
		  };</p>
<p>		/**<br />
 		* Informações do cabeçalho para o widget.ColumnSet possa retornar<br />
 		* um objeto adapter(adaptador) para a renderização do DataTable.<br />
 		*/<br />
    	var Cabecalhos = [<br />
	    	{key:"placa", title:"Placa", sortable:true},<br />
    		{key:"vistoria", type:"date", sortable:true, resizeable:true},<br />
    		{key:"km", type:"number", sortable:true, resizeable:true}<br />
		];</p>
<p>		/**<br />
	 	* Objeto &#8220;configurador&#8221; do cabecalho<br />
	 	*/<br />
		var ConfiguraColunas = new YAHOO.widget.ColumnSet(Cabecalhos);</p>
<p>		/**<br />
	 	* Objeto DataSource é responsável por pegar, tratar e adaptar<br />
	 	* as informações para que o objeto DataTable possa renderizá-las<br />
	 	*/<br />
		var CapturaInformacoes = new YAHOO.util.DataSource(YAHOO.exemplo.dados.veiculos);<br />
			CapturaInformacoes.responseType = YAHOO.util.DataSource.TYPE_JSARRAY;<br />
			CapturaInformacoes.responseSchema = {<br />
				fields: ["placa","vistoria","km"]<br />
		};</p>
<p>		/**<br />
	 	* Enfim cria o table<br />
                * O primeiro parametros é onde(div) será renderizado o seu DataTable<br />
	 	*/<br />
		var DataTable = new YAHOO.widget.DataTable(&#8220;exemplo&#8221;,<br />
		ConfiguraColunas, CapturaInformacoes, {caption:&#8221;Exemplo básico de DataTable&#8221;});<br />
	}</p>
<p>	/**<br />
	 * Quando a arvore DOM estiver carregada executa a função!<br />
	 * o YAHOO.util.Event é um utilitário do YUI para trabalhar com eventos<br />
	 */<br />
	YAHOO.util.Event.onDOMReady(init);<br />
</coolcode>
</li>
<li>Você pode fechar o header do html e então no corpo(body) colocar aonde o DataTable será renderizado, no caso: (Sem isso o DataTable não irá ser renderizado)<br />
<coolcode lang="html"></p>
<div id="exemplo"></div>
<p></coolcode>
</li>
</ul>
<p>Resultado:</p>
<p><iframe align="center" src="http://danielmartins.eti.br/blog/exemplos/datatable.html"></iframe></p>
<p>Como podemos constatar no resultado acima as duas ordenações que realmente funcionam são as colunas por data e por quilometragem, pois o YUI reconhece os tipos informados nas linhas 28 e 29 do JavaScript , os tipos reconhecidos pela YUI são <strong>&#8220;string&#8221;, &#8220;number&#8221;, &#8220;date&#8221;, &#8220;currency&#8221;, &#8220;email&#8221; e &#8220;link&#8221;</strong>. Você pode clickar no cabeçalho da coluna <strong>&#8220;Placa&#8221;</strong> e você verá que a lógica de ordenação aplicada é a do tipo string, ou seja, pelas letras iniciais, mas precisamos que essa coluna seja ordenada pelo numero final da placa, pois sabemos que o pagamento do ipva de um veículo vence no mês do último número da placa, por exemplo final de placa 1 vence em Janeiro, 2 em Fevereiro e assim sucessivamente e as placas com final 0 vence em outubro.</p>
<p>Precisamos customizar a ordenação, vamos criar primeiramente as funções para ordenação crescente e decrescente, a YUI possui duas funções utilitárias para ajudar-nos nesta tarefa, são a <strong>YAHOO.util.Sort.compareAsc</strong> e a <strong>YAHOO.util.Sort.compareDesc<br />
</strong>, a primeira para comparação crescente e a segunda para comparação decrescente, vejamos sua utilização já aplicando ao problema que nós temos de ordenar os dados pelo final da placa, a seguir: <strong>[COD_05]</strong></p>
<p><coolcode lang="javascript"><br />
/**<br />
 * Ordenação Crescente<br />
 *<br />
 */<br />
var ordByPlacaAsc = function(a,b){<br />
        // Pega o final da primeira placa<br />
	var finalPlaca1 = a.placa.charAt(a.placa.length &#8211; 1);<br />
         // Pega o final da segunda placa<br />
	var finalPlaca2 = b.placa.charAt(b.placa.length &#8211; 1);</p>
<p>	var compFnc = YAHOO.util.Sort.compareAsc<br />
	// transforma em inteiro multiplicando por 1 e joga para<br />
	// a função utilitária de comparação<br />
	var resultado = compFnc(finalPlaca1*1,finalPlaca2*1);<br />
	return resultado;<br />
}</p>
<p>/**<br />
 * Ordenação Decrescente<br />
 *<br />
 */<br />
var ordByPlacaDesc = function(a,b){<br />
       // Pega o final da primeira placa<br />
       var finalPlaca1 = a.placa.charAt(a.placa.length &#8211; 1);<br />
	// Pega o final da segunda placa<br />
	var finalPlaca2 = b.placa.charAt(b.placa.length &#8211; 1);</p>
<p>	var compFnc = YAHOO.util.Sort.compareDesc</p>
<p>	// transforma em inteiro multiplicando por 1 e joga para<br />
	// a função utilitária de comparação<br />
	var resultado = compFnc(finalPlaca1*1,finalPlaca2*1);<br />
	return resultado;<br />
}<br />
</coolcode></p>
<p>Como podemos ver, basicamente temos o mesmo procedimento só que com funções utilitárias diferentes, você pode fazer a comparação nas linhas <strong>11 e 28</strong>, as funções utilitárias fazem a comparação e para a <strong>YAHOO.util.sort.compareAsc</strong> retornam <strong>-1</strong> se o primeiro argumento for < (menor que) o segundo argumento, 0 se o primeiro argumento é igual( == ) ao segundo argumento e 1 se o primeiro argumento é >(maior que) o segundo argumento e o inverso para a <strong>YAHOO.util.sort.compareDesc</strong>, ou seja, <strong>-1</strong> se o primeiro argumento for > (maior que) o segundo argumento, 0 se o primeiro argumento é igual( == ) ao segundo argumento e 1 se o primeiro argumento é < (menor que) o segundo argumento e assim a YUI vai ordenando os dados no <strong>DataTable</strong>, mas você está sentindo falta de algo ?! sim!, aonde parametrizamos para que o YUI utilize estas funções customizadas de ordenação ?!</p>
<p><strong>R:</strong> No bloco de código <strong>[COD_04]</strong> na linha <strong>27</strong> é possível passar um argumento chamado <strong>sortOptions</strong> contendo as informações referentes a customização da ordenação, veja um exemplo de como fica a <strong>linha 27</strong> inserindo as funções de ordenação:</p>
<p><coolcode lang="javascript"><br />
{key:&#8221;placa&#8221;, title:&#8221;Placa&#8221;, sortable:true, sortOptions:{ascFunction:ordByPlacaAsc,descFunction:ordByPlacaDesc}},<br />
</coolcode></p>
<p>Como resultado podemos ver a ordenação sendo feita pelo último número da Placa do veículo:</p>
<p>Resultado:</p>
<p><iframe align="center" src="http://danielmartins.eti.br/blog/exemplos/datatable1.html"></iframe></p>
<p>Já me estendi demais, espero que eu tenha conseguido exemplificar o uso básico do widget DataTable da YUI e de como customizar a ordenação, qualquer sugestão, correção ou crítica construtiva é bem vinda. Ajude-me a melhorar a qualidade dos artigos que escrevo.</p>
<p>Links essenciais que me serviram de consulta e para quem deseja exemplos mais ricos:<br />
<a href="http://developer.yahoo.com/yui">http://developer.yahoo.com/yui</a><br />
<a href="http://developer.yahoo.com/yui/examples/datatable/">http://developer.yahoo.com/yui/examples/datatable/</a><br />
<a href="http://developer.yahoo.com/yui/datatable/">http://developer.yahoo.com/yui/datatable/</a><br />
<a href="http://developer.yahoo.com/yui/docs/module_datatable.html">http://developer.yahoo.com/yui/docs/module_datatable.html</a><br />
<a href="http://www.quirksmode.org/js/strings.html">http://www.quirksmode.org/js/strings.html</a></p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2007/07/03/yui-widget-datatable-ordenacao-customizada/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Seeduca + GCompris Brasil</title>
		<link>http://danielmartins.eti.br/blog/2007/05/10/seeduca-gcompris-brasil/</link>
		<comments>http://danielmartins.eti.br/blog/2007/05/10/seeduca-gcompris-brasil/#comments</comments>
		<pubDate>Thu, 10 May 2007 15:03:25 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Comunidade]]></category>
		<category><![CDATA[Comunidades]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[Traduções]]></category>

		<guid isPermaLink="false">http://daniel.jb0.org/2007/05/10/seeduca-gcompris-brasil/</guid>
		<description><![CDATA[+ O projeto Seeduca e GCompris Brasil decidiram em reunião compartilhar recursos e conhecimento para que haja uma melhor e maior colaboração entre os projetos, como segue a notícia no site do GCompris Brasil escrita pelo Frederico, mantenedor do projeto GCompris Brasil. Eu como um dos membro do projeto Seeduca.org me sinto muito feliz com [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.seeduca.org"><img src="http://danielmartins.eti.br/blog/wp-content/uploads/2007/05/seeduca303x120.png" /></a> + <a href="http://gcompris.teia.bio.br"><img src="http://danielmartins.eti.br/blog/wp-content/uploads/2007/05/logo.png" /></a></p>
<p>O projeto Seeduca e GCompris Brasil <a href="http://listas.seeduca.org/pipermail/seeduca-seeduca.org/2007-May/000009.html">decidiram em reunião</a> compartilhar recursos e conhecimento para que haja uma melhor e maior colaboração entre os projetos, como segue a <a href="http://gcompris.teia.bio.br/drupal/node/16">notícia</a> no site do GCompris Brasil escrita pelo <a href="http://teia.bio.br">Frederico</a>, mantenedor do projeto GCompris Brasil.</p>
<p><span id="more-114"></span><br />
Eu como um dos membro do projeto <a href="http://www.seeduca.org">Seeduca.org</a> me sinto muito feliz com esta notícia, pois é algo que só tende a fomentar a cultura de software livre nos ambientes educacionais que se utilizam da informática e também nos chamados Edutretenimentos (Não sei se existe essa palavra!), mas seria softwares de entretenimento com foco educacional, ou seja, enquanto a criança brinca e se diverte&nbsp; ela está aprendendo e se desenvolvendo.</p>
<p>Para os que ainda não estão por dentro:</p>
<p>O projeto <a href="http://www.seeduca.org">Seeduca.org</a> é <i>&#8220;O projeto Seeduca é um projeto que visa disseminar e incentivar o uso do Software Livre na educação, pois acreditamos que o conhecimento e a inclusão digital nos meios educacionais não podem ser obtidos e plenamente compartilhados por meio de softwares não livres.&#8221;.<br /></i><br />O projeto <a href="http://gcompris.teia.bio.br">Gcompris Brasil</a> é <i>&#8220;O objetivo desse site é reunir os trabalhos de tradução, documentação e divulgação do software educacional GCompris aqui no Brasil. Todos estão convidados para colaborar com o projeto, que é aberto a qualquer pessoa.&#8221;</i>.</p>
<p>Você que de alguma forma está envolvida na educação de crianças, jovens e adultos e gostaria de conhecer o projeto Seeduca e/ou GCompris entre na lista de discussão <a href="http://listas.seeduca.org/listinfo.cgi/seeduca-seeduca.org">neste link</a> e participe. </p>
<p>Vale ressaltar que as contribuições podem vir de quase qualquer área do conhecimento. Seja você programador,tradutor, pedagogo, educador, pai/mãe que se preocupa o desenvolvimento/criação de seu filho(a), entusiastas e etc.</p>
<p>Participem:</p>
<p>http://www.seeduca.org<br /><s>http://gcompris.teia.bio.br em breve</s> www.gcompris-br.org</p>
<p>:wq!</p>
<p>
<p class="poweredbyperformancing">Powered by <a href="http://scribefire.com/">ScribeFire</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2007/05/10/seeduca-gcompris-brasil/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Mais uma vitória do PHP!</title>
		<link>http://danielmartins.eti.br/blog/2007/02/10/mais-uma-vitoria-do-php/</link>
		<comments>http://danielmartins.eti.br/blog/2007/02/10/mais-uma-vitoria-do-php/#comments</comments>
		<pubDate>Sat, 10 Feb 2007 18:19:49 +0000</pubDate>
		<dc:creator>Daniel Elias</dc:creator>
				<category><![CDATA[Bancos de dados]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Programação]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://daniel.jb0.org/?p=53</guid>
		<description><![CDATA[Notícia não está quente mas está morna! rs&#8230; É hora de criar seu espaço também nos mainframes da IBM! A Equipe da IBM que desenvolve z/OS acabou de portar o PHP. A versão portada é a 5.1.2 e foi portada para utilização nos 2 ambientes suportados pelo PHP, o CLI (Command Line Interface) e para [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.php.net" rel="attachment wp-att-54" title="PHP Power !"><img src="http://daniel.jb0.org/wp-content/uploads/2007/02/php.gif" alt="PHP Power !" /></a></p>
<p>Notícia não está quente mas está morna! rs&#8230;</p>
<p>É hora de criar seu espaço também nos mainframes da IBM!</p>
<p>A Equipe da IBM que desenvolve z/OS acabou de portar o PHP. A versão portada é a 5.1.2  e foi portada para utilização nos 2 ambientes suportados pelo PHP, o CLI (Command Line Interface) e para o ambiente web através de CGI e claro já vem incluída a extensão PDO_ODBC para comunicação com o DB2, mas isso é claro ! <img src='http://danielmartins.eti.br/blog/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Fonte: <a href="http://info.abril.com.br/blog/sandra/20070208_listar.shtml">http://info.abril.com.br/blog/sandra/20070208_listar.shtml</a></p>
<p>Fonte: <a href="http://www.alphaworks.ibm.com/tech/php4zos">http://www.alphaworks.ibm.com/tech/php4zos</a></p>
]]></content:encoded>
			<wfw:commentRss>http://danielmartins.eti.br/blog/2007/02/10/mais-uma-vitoria-do-php/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

