Bienvenido a Klr20mg

Cronicas de un desarrollador

Actualmente soy Jefe de Desarrollo del area Flash en Sapotek de México en la cual trabajo desde hace mas de 4 años. Desarrollando aplicaciones en Flash para Web mas comúnmente llamadas (RIAs)

Estas en : Blog
  • Decrease font size
  • Default font size
  • Increase font size
  • color default
  • color verde
  • color azul
February 15th, 2007

Los chicos de Riactive con el propósito de apoyar el proyecto AWI han lanzado oficialmente un concurso patrocinado por Adobe EU y Latam, tal y como lo comenta Edgar.

Dicho concurso consta de crear un cliente para AWI [AMFPHP-WordPress Integration], ya sea para reproducir una interfaz en Flex/Flash para wordPress como blog o como un CMS para sitios web.

Como comenta Edgar el primer lugar ganara una licencia de Flex con Charting y el segundo lugar ganara una licencia de Flash 8.

Esto es para ponerse las pilas por su parte lectores para crear el cliente y para mi para trabajar a marchas forzadas para terminar al 100% AWI.

Como saben, AWI tiene un par de semanas vivo y aun esta en un estado alpha, pero cuenta con 16 métodos funcionales de lectura de información con los cuales se puede trabajar un cliente sin problema.

Junto con los desarrollos que ustedes vayan creando por supuesto que comenzaran a existir peticiones, comentarios etc que al final del día dará como resultado un “producto†espero yo robusto y estable creado a partir de las opiniones de cada uno de ustedes.

Por mi parte daré, de ahora en adelante, prioridad uno a este proyecto tratando de satisfacer todas aquellas peticiones que surjan.

Por ahora pueden usar mi servidor como conejillo de indias ya que aquí esta montado AMFPHP 1.9 y la ultima versión de AWI.

La url del Gateway es :

http://klr20mg.com/amfphp/gateway.php

el browser de los servicios lo encuentran en:

http://klr20mg.com/amfphp/browser/

Una vez que los métodos de escritura estén listo montare un wordpress exclusivo para el proyecto en el cual podrán hacer o deshacer lo que quieran ;)

Para peticiones, sugerencias, reclamos, etc. Por favor háganlo directamente en la lista de correo del proyecto para subscribirse a la lista basta con enviar un email vació a la dirección

awi-dev-subscribe@googlegroups.com

Ahora por ultimo y no por ello menos importante no me queda mas que agradecer a todos los miembros del equipo de Riactive por el apoyo, principalmente a Edgar Parada, estoy realmente agradecido por el apoyo en este proyecto.

No queda mas que… a ponchar código. :p

No sean tímidos y envíen sus clientes

Saludos!! 8)

Archivado bajo : AMFPHP, Awi, Eventos, Flex - Este post tiene : 1 Comentario »
 
February 10th, 2007

La primer fase del proyecto esta terminada, con primer fase me refiero a que, los métodos mas comunes de lectura de la información de posts en wordPress están listos.

Toda la información la pueden encontrar el blog de AWI http://klr20mg.com/awi/primera-fase-terminada/

Nos estamos leyendo 8)

Archivado bajo : AMFPHP, Awi, Flex - Este post tiene : 0 Comentarios
 
February 1st, 2007

Bueno gente, Esto va en serio, he creado un sitio especial para el proyecto en el cual estarán las ultimas noticias sobre el proyecto, los links relacionados, Mailing-list, descargas, SVN, Blog etc.

De verdad les agradecería sus comentarios sobre el proyecto, que al fin del día es un proyecto para la comunidad o sea todos nosotros :P

La url del sitio es : http://klr20mg.com/awi/

Nos estamos viendo.

Archivado bajo : AMFPHP, Awi, Flex - Este post tiene : 5 Comentarios »
 
January 29th, 2007

English translation, at the bottom

Hace un par de días comencé a trabajar sobre un nuevo proyecto. Su nombre oficial es AWI (Amfphp WordPress Integration).

El propósito de AWI es hacer servicios para Amfphp, los cuales servirán de “gateway†entre Flex/Flash y WordPress, para así poder hacer GUI’s sobre estas 2 plataformas de desarrollo.

Como comente al inicio, este proyecto lo comencé apenas hace un par de días. Y espero dedicarle un par de horas al día, por lo menos ( O lo que el cuerpo aguante :) ), ademas de esto decidí hacer de este un proyecto abierto, se que es un proyecto pequeño, pero que mas da, veamos cual puede ser el resultado.

Por el momento el proyecto consta solo de 4 servicios y estan en estado alpha, por el momento, solo leen algunas propiedades de WordPress.

Ademas de contar con los métodos para tomar la información normal del blog, Post, Comentarios, Categorías, BlogRoll, etc. Tal vez también se integre todo lo referente a la administración del mismo aun no lo se.

Si alguien esta interesado en participar pueden encontrar el proyecto hospedado en GoogleCode

http://code.google.com/p/awi/

Los archivos los pueden descargar en

http://code.google.com/p/awi/downloads/list

Para ver los métodos hasta el momento puede entrar a

http://klr20mg.com/amfphp/browser/

bajo el apartado WordPress.

Si alguien tiene comentarios, ideas, etc son bienvenidas.

– English –

Two days ago i began working on a new project officially called AWI (Amfphp WordPress Integration).

The objective to reach is to make services for working on Amfphp, which will be like a “gateway” between Flex/Flash and Wordpress, and building GUIs on those two platforms.

like i said at the beginning, this project started two days ago, and i will spend at least a couple of hours a day, as well as beginning this project, it will be open source, i know it is a little project but doesn’t matter, we’ll see the impact and the results.

Currently it has just 4 services in alpha status, they access a few properties from WordPress.

As well as to have the methods for taking the normal data from the blog, posts, comments, categories, blogroll, etc, maybe i will add features about the management but i still dont know.

If anybody is interested and want to collaborate, the project is hosted in GoogleCode:

http://code.google.com/p/awi/

You can download the files from:

http://code.google.com/p/awi/downloads/list

The methods written currently could be reached at:

http://klr20mg.com/amfphp/browser/

under the WordPress section

Any help, ideas, comments would be appreciated.

cheers 8)

Archivado bajo : AMFPHP, Awi, Flex - Este post tiene : 4 Comentarios »
 
January 28th, 2007

Hace poco mas de un mes se anuncio el lanzamiento de la versión 1.9 alpha de amfphp, esta versión por fin soportaba AMF3 y con ello interactuar totalmente con Flex2. Y el pasado viernes se lanzo la versión beta 2, Así que es hora de que nos vayamos enterando de como funciona esta nueva versión =)

1.Descargar e Instalar Amfphp 1.9 beta 2.

Descarga el archivo zip de amfphp 1.9, descomprimelo y sube el folder amfphp a algún lugar de tu servidor, el mejor sitio seria el directorio principal de tu sitio. Para comprobar que todo esta correcto haremos la vieja pero siempre efectiva comprobación. En tu navegador escribe la dirección que apunte hacia el archivo gateway.php

Si el folder de amfphp se encuentra en el folder raíz de tu sitio entonces la dirección seria:

http://www.tusitio.com/amfphp/gateway.php

Si todo sale bien debes de ver un mensaje como este.

“amfphp and this gateway are installed correctly. You may now connect to this gateway from Flash.

Note: If you're reading an old tutorial, it will tell you that you should see a download window instead of this message. This confused people so this is the new behaviour starting from amfphp 1.2.

View the amfphp documentation

Load the service browserâ€

2. Crear nuestro primer servicio.

HelloWorld.php

PHP:
  1. <?php
  2.  class HelloWorld
  3.  {
  4.     public function SayHi()
  5.     {
  6.        return "Hi there. =)";
  7.     }
  8.  }
  9. ?>

Si ya habías trabajado con una versión vieja de amfphp te darás cuenta que $this->methodTable se ha eliminado de la estructura de la clase.

$this->methodTable era utilizado para asignar las propiedades de las funciones, sobre todo la descripción, y la forma de acceso, esto ultimo para saber si se podría acceder a la función de forma remota o solo local.

En esta nueva versión como dije antes $this->methodTable dejo de usarse. Ahora esta nueva versión de amfphp asume que todas las funciones pueden accederse remotamente a menos que el nombre de la función comience con guion-bajo “_†o la función sea declarada como privada, esta ultima opción solo esta disponible en php5.

Un ejemplo HelloWorld2.php

PHP:
  1. <?php
  2.  class HelloWorld
  3.  {
  4.     public function SayHi()
  5.     {
  6.        return "Hi there. =)";
  7.     }
  8.     private function connectDB()
  9.     {
  10.        //PHP5
  11.        //Solo se puede ejecutar desde la misma clase
  12.     }
  13.     function _localMethod()
  14.     {
  15.        //PHP4
  16.        //Esta funcion tambien sera accesible desde la misma clase unicamente
  17.     }
  18.  }
  19. ?>

3. Configurar Flex2 para trabajar con amfphp

Debemos crear un proyecto básico en Flex.

project1

project2

Ahora necesitamos crear un archivo de configuración para que flex sepa donde buscar nuestros servicios de amfphp.

Para ello creamos el archivo services-config.xml con la siguiente estructura

XML:
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <services-config>
  3.     <services>
  4.         <service id="amfphp-service" class="flex.messaging.services.RemotingService" messageTypes="flex.messaging.messages.RemotingMessage">
  5.             <destination id="amfphp">
  6.                 <channels>
  7.                     <channel ref="amfphpId"/>
  8.                 </channels>
  9.                 <properties>
  10.                     <source>*</source>
  11.                 </properties>
  12.             </destination>
  13.         </service>
  14.     </services>
  15.     <channels>
  16.         <channel-definition id="amfphpId" class="mx.messaging.channels.AMFChannel">
  17.             <endpoint uri="http://www.klr20mg.com/amfphp/gateway.php" class="flex.messaging.endpoints.AMFEndpoint"/>
  18.         </channel-definition>
  19.     </channels>
  20. </services-config>

La única linea que nos interesa y que debemos modificar es la siguiente:

XML:
  1. <endpoint uri="http://www.klr20mg.com/amfphp/gateway.php" class="flex.messaging.endpoints.AMFEndpoint">

Modificando la ruta hacia donde esta nuestro archivo gateway y guardandolo en el folder raíz de nuestro proyecto.

Una vez que tenemos nuestro archivo, dar click derecho sobre el nombre del mismo e ir a propiedades. Se abrirá una ventana de propiedades, obviamente, seleccionamos del menú izquierdo la pestaña “Flex Compiler†y en la linea de “Argumentos adicionales de compilación†-s services “services-config.xml†y damos click en “Okâ€

project3

Ahora ya estamos listos para trabajar con amfphp 1.9 y Flex.

4. Probando la conexión

Lo primero es subir nuestro servicio “HelloWorld.php†el cual creamos en el paso 2.

Este servicio debe de estar dentro del folder amfphp/services, dentro, puedes crear folders anidados sin ningún problema en este caso lo colocare en la carpeta Tutorials/HelloWorld.

Creamos una pequeña interfaz la cual constara de un un par de LinkButtuns, un TextArea contenidos dentro de un panel cuyos botones ejecutaran los métodos remotos de amfphp.

Algo así

XML:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
  3.     <!-- Funciones que controlan los eventos del RemoteObject -->
  4.     <mx:Script>
  5.         <![CDATA[
  6.             import mx.rpc.events.FaultEvent;
  7.             import mx.rpc.events.ResultEvent;
  8.             public function onMethodResult(event:ResultEvent):void
  9.             {
  10.                 out_txt.text = "Result "+event.result
  11.                 out_txt.text += "\nDataType "+ typeof(event.result)
  12.             }
  13.             public function onServiceFault(event:FaultEvent):void
  14.             {
  15.                 out_txt.text = "Fault "+event.fault
  16.             }
  17.         ]]>
  18.     </mx:Script>
  19.     <!-- Declaracion del RemoteObject y sus metodos -->
  20.     <mx:RemoteObject
  21.         id="helloService"
  22.         source="Tutorials.HelloWorld.HelloWorld"
  23.         destination="amfphp"
  24.         fault="{onServiceFault(event)}"
  25.         showBusyCursor="true"
  26.     >
  27.        
  28.         <mx:method
  29.             name="SayHi"
  30.             result="{onMethodResult(event)}"
  31.         >
  32.         </mx:method>
  33.        
  34.        
  35.     </mx:RemoteObject> 
  36.     <!-- Layout general-->
  37.     <mx:Panel x="0" y="0" width="250" height="200" layout="absolute" title="Amfphp-RemoteObject">
  38.         <mx:LinkButton x="178" y="135" label="Fault" click="{helloService.invalidMethod.send()}"/>
  39.         <mx:LinkButton x="108" y="135" label="SayHi" click="{helloService.SayHi.send()}"/>
  40.         <mx:TextArea x="7" y="7" width="216" height="121" id="out_txt"/>
  41.     </mx:Panel>
  42. </mx:Application>

vamos a ver parte por parte.

XML:
  1. <mx:RemoteObject
  2.     id="helloService"
  3.     source="Tutorials.HelloWorld.HelloWorld"
  4.     destination="amfphp"
  5.     fault="{onServiceFault(event)}"
  6.     showBusyCursor="true"
  7. >
  8.    
  9.     <mx:method
  10.         name="SayHi"
  11.         result="{onMethodResult(event)}"
  12.     >
  13.     </mx:method>
  14. </mx:RemoteObject>

En este tag como se puede ver creamos nuestro RemoteObject los parámetros son:

id : El nombre con el cual haremos referencia
source: el path a partir del folder amfphp/services, donde se encuentra nuestro servicio en el servidor,
destination: el identificador seteado en el tag <destination> del archivo services-config.xml
fault: El método que sera ejecutado al momento de que ocurra un error.
showBusyCursor: Mientras dure la ejecución del método remoto flex mostrara el cursor de ocupado

Dentro del tag RemoteObject debemos agregar los métodos a los cuales vallamos a acceder desde Flex y definir la función que se ejecutara cuando el método se haya ejecutado con éxito.

Esto lo hacemos definiendo el tag <mx:method>

XML:
  1. <mx:method
  2.     name="SayHi"
  3.     result="{onMethodResult(event)}"
  4. >
  5. </mx:method>

los parámetros son:

name: El nombre del método que se ejecutara, que es el mismo que tenemos en nuestro servicio.
result : asignamos la función que se ejecutara cuando el método remoto se ejecute.

Por ultimo, debemos ejecutar dichos métodos desde nuestra interfaz, en este ejemplo se ejecutan mediante un LinkButton

XML:
  1. <mx:linkbutton x="108" y="135" label="SayHi" click="{helloService.SayHi.send()}">

Al momento de dar click enviamos la petición de ejecución del método SayHi que esta definido dentro del RemoteObject helloService, simple cierto? ;)

Este es el resultado final.

Aqui estan los archivos completos del proyecto. helloworld-amfphp19.zip

Con esto podemos comenzar a trabajar y a aprovechar todas la ventajas que amfphp nos ofrece.

Cheers. 8)

Archivado bajo : AMFPHP, Flex, Tutoriales - Este post tiene : 9 Comentarios »
 
October 2nd, 2006

Últimamente he estado probando Flex. Estoy realizando una vista en Flex de este blog que pronto podrán ver en linea entre otras cosas..

Bien, El tema de hoy va sobre la etiqueta esta etiqueta al momento de debuguear tu aplicación es de gran ayuda, por ejemplo, digamos que queremos consumir un webServices remoto, algo simple tomar la “Cita del díaâ€.

Cuando agregamos esta etiqueta a nuestro mxml regresa una secuencia detallada de los eventos que se están ejecutando en nuestra aplicación. Como es un tag para debuguear en nuestra aplicación final no se vera ningún cambio.

El ejemplo es sencillo

Actionscript:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="350" height="100" applicationComplete="init()">
  3.     <mx:Script>
  4.         <![CDATA[
  5.             import mx.events.*
  6.             import flash.xml.XMLDocument
  7.             public function init():void
  8.             {
  9.                 miConexion.GetQuote.send()
  10.             }
  11.             public function onResultOK(event:Event):void
  12.             {
  13.                 var data:XMLDocument = new XMLDocument();
  14.                 data.parseXML(miConexion.GetQuote.lastResult);
  15.                 var out:String = data.firstChild.firstChild.firstChild.firstChild.nodeValue
  16.                 outPut.text = out
  17.                
  18.             }
  19.             public function onResultFault(fault:Event):void
  20.             {
  21.                 trace(fault)
  22.             }
  23.         ]]>
  24.     </mx:Script>
  25.     <mx:TraceTarget />
  26.     <mx:WebService  wsdl="http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx?WSDL" id="miConexion">
  27.         <mx:operation name="GetQuote" result="onResultOK(event)" fault="onResultFault(event)" resultFormat="xml" makeObjectsBindable="true"/>
  28.     </mx:WebService>
  29.     <mx:Text x="10" y="10" width="330" height="80" id="outPut" text="Cargando Data Externa"/>
  30. </mx:Application>

así es como se ve nuestra ventana de debugeo si dicha etiqueta

Actionscript:
  1. [SWF] C:\Documents and Settings\Tmeist3r\Desktop\test\bin\test-debug.swf - 730,596 bytes after decompression

Ahora, así es como se ve nuestra ventana de debugueo cuando utilizamos TraceTarget

Actionscript:
  1. [SWF] C:\Documents and Settings\Tmeist3r\Desktop\test\bin\test-debug.swf - 717,747 bytes after decompression
  2. Registering schema namespace: http://www.w3.org/1999/XMLSchema
  3. Registering schema namespace: http://www.w3.org/2000/10/XMLSchema
  4. Registering schema namespace: http://www.w3.org/2001/XMLSchema
  5. Registering schema namespace: http://schemas.xmlsoap.org/soap/encoding/
  6. Registering schema namespace: http://xml.apache.org/xml-soap
  7. Registering schema namespace: http://rpc.xml.coldfusion
  8. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer set destination to 'DefaultHTTP'.
  9. '9828CAB5-C669-81AC-3299-0B47AA9F2817' producer set destination to 'DefaultHTTP'.
  10. 'direct_http_channel' channel endpoint set to http:
  11. Creating WSDL object for http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx?WSDL
  12. '127766B4-8379-1647-CADD-0B47AA9FB309' producer set destination to 'DefaultHTTP'.
  13. Loading document http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx?WSDL for destination 'DefaultHTTP'
  14. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer sending message '5604ADC7-4155-F995-8E77-0B47AA9F7C90'
  15. 'direct_http_channel' channel sending message:
  16. (mx.messaging.messages::HTTPRequestMessage)#0
  17.   body = (Object)#1
  18.   clientId = (null)
  19.   contentType = "application/x-www-form-urlencoded"
  20.   destination = "DefaultHTTP"
  21.   headers = (Object)#2
  22.   httpHeaders = (Object)#3
  23.   messageId = "5604ADC7-4155-F995-8E77-0B47AA9F7C90"
  24.   method = "GET"
  25.   recordHeaders = false
  26.   timestamp = 0
  27.   timeToLive = 0
  28.   url = "http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx?WSDL"
  29. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer connected.
  30. Queueing SOAP operation GetQuote
  31. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer acknowledge of '5604ADC7-4155-F995-8E77-0B47AA9F7C90'.
  32. Processing imports for location http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx?WSDL
  33. Parsing schemas
  34. Registering schema namespace: http://swanandmokashi.com
  35. Done parsing schemas: 3 ms
  36. Done processing imports: 581 ms
  37. Parsing services
  38. Parsing individual services
  39. Parsing service: QuoteofTheDay
  40. Parsing binding: http://swanandmokashi.com::QuoteofTheDaySoap
  41. Parsing portType: http://swanandmokashi.com::QuoteofTheDaySoap
  42. Parsed portType: 1 ms
  43. Parsed binding: 6 ms
  44. Parsed service: 11 ms
  45. Done parsing services: 12 ms
  46. WSDL parse took 594 ms
  47. WSDL loaded
  48. Made SOAP Operation for GetQuote
  49. Set active port in service stub: QuoteofTheDay:QuoteofTheDaySoap
  50. Invoking previously queued calls GetQuote
  51. Invoking SOAP operation GetQuote
  52. Initializing SOAP operation GetQuote
  53. Parsing message: http://swanandmokashi.com::GetQuoteSoapIn
  54. Message name is GetQuoteSoapIn
  55. Parsed message: 5 ms
  56. Parsing message: http://swanandmokashi.com::GetQuoteSoapOut
  57. Message name is GetQuoteSoapOut
  58. Parsed message: 5 ms
  59. Asynchronously invoking SOAP Operation: GetQuote
  60. Encoding SOAP request envelope
  61. Encoding SOAP request body
  62. Encoded SOAP Operation request: <?xml version="1.0" encoding="utf-8"?>
  63. <SOAP-ENV:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><SOAP-ENV:Body><GetQuote xmlns="http://swanandmokashi.com" /></SOAP-ENV:Body></SOAP-ENV:Envelope>
  64. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer sending message 'E5E1E227-8114-3417-14DB-0B47AD103D57'
  65. 'direct_http_channel' channel sending message:
  66. (mx.messaging.messages::SOAPMessage)#0
  67.   body = "<?xml version="1.0" encoding="utf-8"?>
  68. <SOAP-ENV:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><SOAP-ENV:Body><GetQuote xmlns="http://swanandmokashi.com" /></SOAP-ENV:Body></SOAP-ENV:Envelope>"
  69.   clientId = "DirectHTTPChannel0"
  70.   contentType = "text/xml; charset=utf-8"
  71.   destination = "DefaultHTTP"
  72.   headers = (Object)#1
  73.   httpHeaders = (Object)#2
  74.     SOAPAction = ""http://swanandmokashi.com/GetQuote""
  75.   messageId = "E5E1E227-8114-3417-14DB-0B47AD103D57"
  76.   method = "POST"
  77.   recordHeaders = false
  78.   timestamp = 0
  79.   timeToLive = 0
  80.   url = "http://www.swanandmokashi.com/HomePage/WebServices/QuoteOfTheDay.asmx"
  81. '0E6C71D7-0670-186D-74DB-0B47A9E33F2A' producer acknowledge of 'E5E1E227-8114-3417-14DB-0B47AD103D57'.
  82. Decoding SOAP response
  83. Encoded SOAP response: <?xml version="1.0" encoding="utf-8"?><soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soap:Body><GetQuoteResponse xmlns="http://swanandmokashi.com"><GetQuoteResult><QuoteOfTheDay>All I Really Need To Know I Learned In Kindergarten</QuoteOfTheDay><Author>Robert Fulghum</Author></GetQuoteResult></GetQuoteResponse></soap:Body></soap:Envelope>
  84. Decoding SOAP response envelope
  85. Decoded SOAP response into result [0 millis]

Sin duda esta es una etiqueta que nos puede ahorrar muchos dolores de cabeza al momento de Debugear.

Saludos!!

Archivado bajo : AS3, Flex - Este post tiene : 1 Comentario »
 
September 5th, 2006

A pocas horas de publicar el post Comunidades Flex en español, en donde comentaba que no existía ninguna comunidad en Español. Amanezco con la noticia de que Carlos Rovira junto con Xavi Beumala han lanzado un portal-comunidad sobre Flex y si, en español llamado MadeInFlex..

Bueno, era de esperarse era solo cuestión de tiempo para que apareciera algo, y la verdad para mi es mas que suficiente jeje. Estos 2 personajes si que saben de lo que hablan.

Acerca de MadeInFlex

"Made In Flex es un sitio web en español que pretende unificar aquellas necesidades creadas entorno a la plataforma Flex de Adobe. En definitiva, un punto de encuentro para desarrolladores, empresas y todo aquel interesado en esta nueva generación de RIAs(Rich Internet Applications).

Los recursos planteados son muy diversos: Noticias, Grupo de Usuarios de Adobe, Lista de Correo, Casos de Uso o Artículos por nombrar solo algunos. Es de esperar que se añadan más conforme desarrollemos la idea entre todos."

Bueno, por lo pronto ya estoy inscrito en la lista, ya verán mis dudas por ahí. :)

No me queda mas que desearles toda la suerte del mundo y espero poder colaborar con ustedes de alguna forma (Por lo menos haciendo preguntas :P)

Enhorabuena. 8)

Archivado bajo : Flex - Este post tiene : 1 Comentario »
 
Entradas Anteriores

 Blog editado por:

Enrique Chavez aka Tmeister
Si los codigos de este sitio te han ayudado y gustas ayudar de alguna forma:

 Compra Links

 Suscribete


AddThis Social Bookmark Button