José Carlos Fiel

  • Início
  • Portfólio
  • Flash Platform Architecture
  • Sobre

Palestra no Flexmania 2010 #soudev

10/07/10

Escrito por José Carlos Silveira Fiel em Adobe Flex

1 comentário

Primeiramente, obrigado a todos que participaram da minha palestra.

Deixo aqui neste post o link para os slides: http://www.slideshare.net/josecarlosfiel/debugando-flex-e-php

Espero que vocês tenham gostado e para maiores dúvidas a respeito da palestra ou sugestões de post (screencasts), sintam-se a vontade em enviar um comentário.

Atenderei aos pedidos assim que for possível.

Mais uma vez obrigado e convido a todos ao Mini Curso On-line de Flex e Zend Framework neste próximo sábado (17/07), lembrando que quem participou da palestra e enviou o código da promoção ganhou 30% de desconto!

Grande abraço!

Adobe Flex, flexmania, minizend, php, zend, zf

Minizend – Aplicação Demo

29/04/10

Escrito por José Carlos Silveira Fiel em Adobe AIR

Nenhum comentário

No video abaixo apresento a aplicação de Distribuição de Fornecedores que irei desenvolver durante o mini curso online de Flex e Zend Framework (#minizend).

O curso ocorrerá neste sábado, dia 05/06. Para quem não se matriculou ainda, não se preocupe, pois ainda há tempo! Acesse www.riacycle.com/zend e garanta sua vaga.

Adobe AIR, Adobe Flex, minizend, Zend Framework

[Fiel Cookbook] Manipulando Datas entre Flex e PHP

22/04/10

Escrito por José Carlos Silveira Fiel em Adobe Flex

4 comentários

Problema

Temos um DateField no Flex e queremos enviar a data selecionada para o PHP como um objeto Date e não somente uma simples string no fomato DD/MM/YYYY. Enviando o objeto Date, teremos o benefício de ter todas as informações de Timezone, GMT e etc para serem manipuladas futuramente via backend.

Solução

Para resolvermos nosso problema, devemos utilizar o Zend Amf para serialização/deserialização de objetos entre Flex e PHP. No Flex simplesmente usaremos a propriedade selectedDate do DateField para selecionarmos o objeto Date e após enviar ao PHP via RemoteObject. O Zend Amf terá o papel de converter este objeto para Zend Date e vice versa.

Explicação Detalhada

Obs.: O ViewSource está habilitado no exemplo abaixo para quem quiser acompanhar melhor esta explicação.

1º – Capturamos o objeto Date pela propriedade selectedDate do DateField e enviamos para o PHP.

FlexPHPDate.mxml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" viewSourceURL="srcview/index.html">
   
    <mx:Script>
       <![CDATA[
           import mx.controls.Alert;
           import mx.rpc.events.FaultEvent;
           import mx.rpc.events.ResultEvent;
           
           public function getTimezone():void
           {
               remote.getTimezone(dt.selectedDate);
           }

           public function getTimestamp():void
           {
               remote.getTimestamp(dt.selectedDate);
           }
           
           protected function remote_resultHandler(event:ResultEvent):void
           {
               Alert.show(event.result.toString());
           }

       ]]>
   </mx:Script>
   
    <mx:DateField id="dt" formatString="DD/MM/YYYY" />
   
    <mx:Button label="Get Timezone" click="getTimezone()" enabled="{ dt.selectedDate != null }" />
    <mx:Button label="Get UNIX timestamp" click="getTimestamp()" enabled="{ dt.selectedDate != null }" />
   
    <mx:RemoteObject id="remote" destination="zend" endpoint="../gateway.php"
                    source="DateService"
                    result="remote_resultHandler(event)"/>
   
</mx:Application>

2º – Recebemos o objeto Date no PHP já convertido para Zend_Date. Isso é feito automaticamente pelo Zend_Amf.

DateService.php (está localizando dentro da pasta /services/)

1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
class DateService
{
    public function getTimezone(Zend_Date $date)
    {
        return $date->getTimezone();
    }
   
    public function getTimestamp(Zend_Date $date)
    {
        return $date->getTimestamp();
    }
}

Exemplo da Solução: Ao selecionarmos a data e selecionando Get Timezone, mandaremos para o PHP o objeto Date e após o PHP enviará para nós um timestamp desta data atravéz do Zend_Date. Acontece o mesmo para Get UNIX Timestamp.

Baixe aqui o projeto Flex incluindo o PHP: FlexPHPDate.zip

Observações Finais

Esta prática é interessante para manipularmos o mesmo objeto Date de uma linguagem para outra, com várias informações de Timezone, GMT e etc, como citados acima.

Abraços a todos e até o próximo Fiel Cookbook.

Adobe Flex, Fiel Cookbook, Zend Amf, Zend Framework

Sou novo membro da comunidade O’Reilly

13/01/10

Escrito por José Carlos Silveira Fiel em Adobe Flex

6 comentários

Olá a todos! Vim aqui informar aos meus caros colegas e amigos que acompanham meu blog e twitter para falar mais sobre esta novidade, que eu mesmo nem esperava.

Como vocês podem ver no nome do post, eu sou o novo membro da comunidade da O’Reilly, mas calma eu não vou escrever nenhum livro até o momento e sim fui convidado para escrever artigos sobre Flex 4 e PHP no InsideRIA.com. Isso para mim foi sensacional, pois é meu primeiro contato profissional fora do Brasil.

Agora poderia explicar em uma simples palavra como eu consegui isso. Rapidamente diria: Twitter!

Mas explicando detalhadamente, poderia dizer que tudo isso não teria acontecido se eu não tivesse tomado iniciativa. Isso mesmo INICIATIVA!

Tudo começou com um simples tweet do @richtretola, oferecendo na rede uma oportunidade para escrever artigos sobre Flex e PHP no @insideria. Obviamente logo que li eu não dei muita atenção, pois minha mente pensou: é um contato externo, não sei falar inglês e ele não é tão bom; apesar de ler muitos artigos e livros em inglês sem muita dificuldade, sem falar na variedade de desenvolvedores Flex e PHP excelentes que tem por aí.

Passou 1 dia e pensei bem, voltei ao tweet que dizia sobre a oportunidade e resolvi mandar o e-mail para o Rich, falando pouco sobre mim e minhas dificuldades no inglês. Passou-se algumas horas e estava lá! Não é que ele respondeu o e-mail tranquilamente e já começamos a falar sobre quais artigos que se encaixariam no InsideRIA e tudo mais.

Depois dessa eu tirei uma lição: Não tenha medo do que você não conhece! Arrisque! Tente! E não desista!

Podia não dar certo o que eu fiz, mas pelo menos não iria me desanimar, teria ficado feliz por ter tentando.

Bom pessoal espero ter passado um pouco da minha lição para vocês e em breve meus artigos estarão no InsideRIA.com e claro, que postarei o post traduzido aqui.

Ah! Podem visitar meu perfil da comunidade O’Reilly aqui: http://www.oreillynet.com/pub/au/4444

Grande abraço a todos e até a próxima!

Adode Flex, InsideRIA, OReilly, RIA

Mini curso on-line Adobe AIR 2.0 Essencial

12/01/10

Escrito por José Carlos Silveira Fiel em Adobe AIR

1 comentário

Olá pessoal, para aqueles que trabalham com o Adobe Flex e deseja criar aplicações ricas para o Desktop, não pode perder o mini-curso on-line de Adobe AIR 2.0 ministrado pelo Igor Costa.

Eu já matriculei nele, quero ver de perto as novidades do Adobe AIR 2.0 e com certeza quero garantir desde cedo minha vaga.

Para maiores informações, entre no site:
http://www.igorcosta.com/air/

Quem quiser ajudar a divulgar pelo twitter, não esqueçam de colocar a hashtag #miniair.

Adobe AIR, RIA

[Fiel Cookbook] Resolvendo problema com Scroll em Apps Flex usando MacOSX

24/11/09

Escrito por José Carlos Silveira Fiel em Adobe Flex

1 comentário

Problema

Você está usando o sistema operacional MacOSX e deseja que o scroll do mouse (mousewheel) funcione em suas aplicacões Flex.

Exemplo do Problema: Tente fazer a rolagem no DataGrid. Não será possível.

Solução

Use o projeto MouseWheelEnabler para resolver o problema existente. Você pode obte-lo pelo site http://code.google.com/p/flex-wmode-mousewheel-handler-example/ ou visualizar a classe no view source do exemplo logo abaixo.

Explicação Detalhada

Obs.: O ViewSource está habilitado no exemplo abaixo para quem quiser acompanhar melhor esta explicação.

Seguindo o exemplo do site oficial, apenas adicionamos no evento addToStage de sua Application a função initMouseWheel que inicializará a classe MouseWheelEnabler. Feito isso sua aplicação funcionará perfeitamente como no exemplo abaixo:

Exemplo da Solução: Adicionando a classe MouseWheelEnabler resolvemos nosso problema de scroll em aplicações Flex no sistema operacional MacOSX.

Observações Finais

Esta solução resolve nossos problemas imediatamente, claro que não podemos dizer que ela seja definitiva, sendo assim que em breve poderemos ter uma correção por parte da Adobe.
Outro detalhe que devemos considerar, é que o Mouse Mighty possui scroll horizontal, sendo que nesta classe ela não resolve  o problema para este caso.

Abraços a todos e até o próximo Fiel Cookbook.

Adobe Flex, Fiel Cookbook, macosx, mousewheel, Scroll

Missão cumprida! Agora sou Adobe Certified Expert Flex with AIR

16/11/09

Escrito por José Carlos Silveira Fiel em Adobe AIR

6 comentários

Uma das minhas metas pessoais mais importantes do ano de 2009 era se tornar um Adobe Certified Expert Flex with AIR e finalmente consegui atingir o meu objetivo tão esperado.

Adobe Certified Expert Flex with AIR

Nesta última sexta-feira 13, isso mesmo sexta-feira 13, dia que muitos consideram “o dia do azar” ou outras supertições, fui lá e mostrei que é possivel sim obter um resultado positivo em dias superticiosos como este. Antes mesmo não estava tão confiante pois não tinha estudado o suficiente em uma prova que exige conhecimento de ambas plataformas Flex e AIR. Finalmente com apoio de algumas pessoas consegui ir confiante e fazer uma prova que no instante pensei que fosse complexa e complicada, mas vi que a minha experiência de 1 ano trabalhando no dia a dia com Adobe Flex me ajudou muito a resolver diversas questões.

Emocionante é terminar a prova e ver o “Congratulations”. Passei na prova com 74%, aonde o exigido mínimo para passar é 67%. A questões que mais me pegaram foram as de AIR, pois ainda não trabalho 100% nesta plataforma.

Os materiais de estudo que utilizei para o exame foram os seguintes:

- Livro: Flex 3 Cookbook
- Attest (Software que simula a certificação)
- Adobe Flex Video Training
- Adobe Flex Learn Path

Sabendo que não tive muito tempo para me dedicar nos estudos e contei muito com a experiência que eu tenho com a ferramenta.

Mais uma vez agradeço as pessoas que me apoiaram, e agora aqueles que almejam o mesmo objetivo deixo meu recado: Estudem bastante e explorem bem as ferramentas Flex e AIR, só assim vocês conseguiram passar numa prova que é bem direta no assunto e nada de pegadinhas para poder desafiar o seu conhecimento.

Abraços pessoal e até a próxima.

Adobe AIR, Adobe Certified Expert, Adobe Flex

ZamfBrowser – O browser do Zend Amf

13/11/09

Escrito por José Carlos Silveira Fiel em Adobe Flex

Nenhum comentário

Olá pessoal. Para aqueles que acompanham meu blog, deve ter visto que eu sumi por um bom tempo, mas estou de volta e com novidades.

Primeiro o motivo de estar desaparecido pelo blog, é que estava estudando para a certificação Adobe Flex/AIR e consegui passar na prova hoje. Isso hoje, em plena sexta-feira 13.

A outra novidade trago no assunto do post mesmo, que é a melhor novidade para os PHPzeiros de plantão. O ZamfBrowser (Figura 1).

ZamfBrowserFigura 1: ZamfBrowser – O primeiro browser para Zend Amf desenvolvido em AIR.

Ele é o primeiro browser para o Zend Amf, como todos perguntavam, por que o Zend Amf não possuia ainda um browser e muitos desistiam dele por que não tinha este recurso e voltava para o AMFPHP, já sem manutenção a um bom tempo.

Vocês podem ver mais sobre o ZamfBrowser no site oficial: http://www.zamfbrowser.org/

Ainda não vou comentar sobre ele, até mesmo porque ainda não testei. Assim que testá-lo estarei trazendo notícias dele aqui e no twitter. Fique ligado!

Espero que seja útil para todos da turma do Zend Amf e aqueles que desejam finalmente migrar para ele.

Abraços e até a próxima.

Adobe Flex, ZamfBrowser, Zend Amf

[Fiel Cookbook] Previnindo que DataGrids aceitam itens de outros DataGrids

01/10/09

Escrito por José Carlos Silveira Fiel em Adobe Flex

Nenhum comentário

Problema

Você quer classificar itens (arrastando-os para cima e para baixo) de um DataGrid e evitar que outros componentes baseados na classe ListBase (DataGrid, List, Tree, etc.) aceitem estes itens.

Exemplo do Problema: Arraste um item do DataGrid do painel Itens para o DataGrid do painel Categorias. Terá um efeito de mover itens de um DataGrid para outro, algo que não queremos que aconteça.

Solução

Criar um componente DataGrid personalizado, setando as propriedades dragEnable, dropEnable e dragMoveEnable como TRUE e sobrescrever os métodos addDragData, dragEnterHandler, dragOverHandler, dragExitHandler, dragDropHandler da classe ListBase, para definir nosso próprio formato de dados que é definido pela classe DragSource.

Explicação Detalhada

Obs.: O ViewSource está habilitado no exemplo abaixo para quem quiser acompanhar melhor esta explicação.

Por padrão todos os componentes baseados na classe ListBase tem implementado um Drag and Drop. É definido também pela classe DragSource o formato de dados chamado “items”. Isso é uma espécie de controle de dados que estão sendo arrastados, ou seja, se o componente alvo esperado não possuir este formato, não será possível fazer um Drop destes dados. A ListBase trata o formato dos dados arrastados via drag and drop como “items”, então todos os componentes baseados nesta classe terão este formato.

Para alteramos isso, vamos sobrescrever os métodos addDragData, dragEnterHandler, dragOverHandler, dragExitHandler, dragDropHandler que contém uma validação dizendo se tem o formato como “items” para aceitar o Drop no componente alvo.

Criando um novo componente DataGrid personalizado, entre na classe ListBase e simplesmente copie os métodos acima para mantermos as mesmas funcionalidades. Não esqueça de importar as classes necessárias e o namespace mx_internal requerido para algumas variáveis que contém dentro dos métodos que estamos sobrescrevendo.

Feito isso vamos criar uma propriedade privada para este componente personalizado chamado format do tipo String e com valor de “items”. Em seguida criaremos um getter e setter para a propriedade recém criada. Agora substitui todas as strings “items” dentro dos métodos que copiamos da classe ListBase pelo método getter format, esse que será dinâmico quando utilizarmos nosso componente e poder definir o formato de dados a serem arrastados por cada componente instanciado.

Por último vamos definir no componente personalizado as propriedades dragEnable, dropEnable, dragMoveEnable como TRUE, para ativamos o drag and drop do nosso componente DataGrid e podermos mover os itens que queremos classificar.

Então em nossa aplicação incluimos nossos DataGrids personalizados e podemos setar a propriedade format com qualquer valor para referenciar aquele fomato para aquela instancia de DataGrid, ou seja, qualquer outro componente baseado no ListBase não poderá colocar seus itens dentro do seu DataGrid. Vejamos aplicação final com o viewSource habilitado:

Exemplo da Solução: Nosso DataGrid contendo os Itens agora possui um format chamado “dgItens” e o DataGrid contendo as categorias agora possui um format chamado “dgCategoria”, sendo que não pode ser aceito em outros componentes baseados no ListBase com format “items”, apenas em componentes que possuirão seus formatos definidos. Assim temos a solução final que é classificar os itens, arrastandos para cima e para baixo dentro do seu DataGrid sem que o item arrastado seja aceito por outros componentes.

Observações Finais

Este post foi baseado num problema que tivemos que solucionar nesta manhã. Posso dizer que boa parte dessa solução devo ao curso Imersão Flex. Como pode ver procurei entender os métodos relacionados ao Drag and Drop do ListBase e usei eles próprios para customizar o meu componente e solucionar o meu problema rapidamente. Se existe outras formas mais simples não sei, podem deixar comentários aqui, mas esta solução foi a única que venho em mente no momento. Então não se limitem e sim faça sua imersão em seus componentes Flex e procure entender como eles funcionam, certamente você encontrará a sua solução.

Abraços a todos e até o próximo Fiel Cookbook.

Adobe Flex, Fiel Cookbook, Imersão Adobe Flex

Treinamento Imersão Adobe Flex! Eu participei!

01/08/09

Escrito por José Carlos Silveira Fiel em Adobe Flex

1 comentário

Foi difícil descidir em fazer um curso online de Flex, pois em minha mente pensava que poderia ser mais um curso daqueles que você simplesmente poderia pegar um livro e estudar, mas depois de pensar muito e ver que o conteúdo era interessante e o instrutor não era qualquer um e sim se tratava do Beck Novaes e sua ampla experiência e mais a parceria da E-Genial, resolvi me matricular no treinamento de Imersão Adobe Flex.

Algumas semanas depois vi a surpresa e que realmente valia fazer aquele treinamento, um grande video de apresentação #http://blip.tv/file/2303081 do que seria e o que ia ser desenvolvido durante as aulas. Até pensei na hora: “Bah! Ainda bem que me matriculei a tempo!” rsrs.

O resultado foi um SUCESSO GERAL!!!
Gostei do ambiente da E-Genial, das aulas, das músicas rsrs (Thumder Cats Wowwww!!!) e pode ter certeza que aproveitei cada minuto deste curso. Realmente o melhor treinamento que já fiz até agora.

Antes deste curso posso considerar que não era um programador Flex, mas depois dele me considero um programador Flex apto a construir grandes aplicações RIAs que faça o usuário sorrir na frente dela.

Para conferir o resultado final e o fechamento com chave de ouro do curso segue abaixo o grande vídeo do Imersão Flex.

Obs.: Assista em tela cheia para melhor experiência.

Valeu equipe da E-Genial e Beck Novaes, estão de parabéns!

E-Genial, Imersão Adobe Flex
«1234»
    • Comentários recentes
    • Artigos populares
    • Arquivos
    • Marcadores
    Adobe AIR Adobe Certified Expert Adobe Flex Adobe Flex Adode Flex amf android apache E-Genial exec Fiel Cookbook Flash Builder flash builder 4.5 Flash Catalyst Flash Platform flash remoting Flex 4 flex 4.5 flexmania Flex Mobile form Imersão Adobe Flex InsideRIA macosx Melhores Práticas metas minizend mousewheel OReilly Otimização permission php portfolio RIA RichText Scroll spark system TextFlowUtil ux ZamfBrowser zend Zend Amf Zend Framework zf
    • maio 2011 (1)
    • abril 2011 (3)
    • fevereiro 2011 (1)
    • janeiro 2011 (1)
    • novembro 2010 (1)
    • agosto 2010 (1)
    • julho 2010 (3)
    • abril 2010 (2)
    • janeiro 2010 (2)
    • novembro 2009 (3)
    • outubro 2009 (1)
    • agosto 2009 (1)
    • julho 2009 (2)
    • junho 2009 (2)
    • maio 2009 (5)
    • abril 2009 (3)
    • Várias técnicas de melhores práticas e otimização em ActionScript 3.0 e Flex. (11)
    • Missão cumprida! Agora sou Adobe Certified Expert Flex with AIR (6)
    • Sou novo membro da comunidade O’Reilly (6)
    • Experimentando Flex Mobile #screencast (6)
    • Olá Mundo! Hello World! (4)
    • Integrando Flex + Zend Framework (Usando o Quickstart da Zend) – PARTE 1 (4)
    • [Fiel Cookbook] Manipulando Datas entre Flex e PHP (4)
    • Integrando Flex + Zend Framework (Usando o Quickstart da Zend) – PARTE 3 (3)
    • Compreendendo a Arquitetura de uma Rich Internet Application (3)
    • Maior atualização do Zend Amf (1.8.4 release) (3)
    • Alexandre: Olá José Carlos! Valeu pela demonstração, tô muito interessado no Flex for Mobile, e é sempre bom ...
    • José Carlos Silveira Fiel: Fala Rafael, Realmente, percebi isso logo depois, mas tranquilo :) Grande abraço!
    • Rafael Viero Marques: Olá, muito boa sua apresentação, estamos no começo de uma nova realidade. Mas você ao falar que Mato...
    • José Carlos Silveira Fiel: Grande Mário, Com certeza será um grande ganho. Quando a performance, também percebi e também não ...
    • Daniel Schmitz: WOW! parabéns !! Muito bom mesmo e rodando com performance!
    • Mário Santos: Opa José Carlos, Sem duvida uma boa demonstração do que ainda estará para vir da plataforma fle...
    • Alexandre: Valeu pelas informações! Bem esclarecedoras.
    • Ved: Muito útil este post! Obrigado Fiel!
  • Lista de Blogs

    • Blog do Paulo Miyashiro
    • Blog do Stefan Horochovec
    • Blog do Xorna
    • Blog Jotasnet
    • Carlos Tristacci
    • Corlan.org
    • FlexDev
    • Mario Junior
    • Rafael Jaques
    • redeRIA
    • Ronaldo Rigoni
    • Vedovelli
Tema Mystique por digitalnature | Movido a WordPress
RSS Feeds XHTML 1.1 Topo