Múltiples plataformes amb Visual Studio II ( i Estrenant GitHub )

Ja fa temp que volia fer alguna cosa semblant. Ja fa temps vaig crear un parser C# per a feeds atom que val tant per Android, com per a WP ( i deuria de valer per a IOS també). Molt modest però valia per a fer aplicacions que llegiren de blogs personals. El parser formarà part de d'una col·lecció que aniré afegint anomenada (molt originalment) util, que es pot trobar en https://github.com/fercavi/util.

La classe anomenada cAtom (notació hongaresa, la vaig fer abans de llegir Clean Code ;)), només té una operació, Run() ;) (realment 2, ara ho explique).  Quan acabe el Run tindrà dos llistes, una de títols (getTitle) i una de notícies (getValue).
Els passos seran els següents:
1. Inicialitzar-la en el constructor, diguent-li la url que volem llegir i, opcionalment, el nombre d'elements que volem extraure (per defecte 10).
2. Afegir-li un callback, en els mòbils la majoria d'events són asíncrons, per tant necessitarem una funció de callback que serà la que carregue la informació gràfica d'interfície  una vegada estiga carregada la informació del feed Atom.
3. Executar Run() que serà el procés que faça la feina i quan acabe execute la funció callback del pas 2.


Anem a veure l'exemple d'ús per a Android i per a WP. Tenim el projecte WPCore  (WP Class Library) què tindrà el namespace util, ara només la classe cAtom. (ho he havut de fer així per com funciona Xamarin). I creem un projecte testWP (Windows Phone App) que tindrà la interfície gràfica i demés coses específiques de WP. A la interfície WP afegim un botó i un navegador web, per a visualitzar les dades baixades. El codi seria:

private void Button_Click_1(object sender, RoutedEventArgs e)
        {

            carregador = new util.cAtom("http://www.vicentfernandez.cat/feeds/posts/default", 10);
            carregador.CarregarDades += callBackCarregador;
            carregador.Run();
        }

Vegem que hem afegit un callback que serà qui òmpliga les dades:

private void callBackCarregador()
        {
            string html = "<html><body>";
            foreach (var titol in carregador.getTitle())
            {
                html += "<h2>" + titol + "</h2>";
            }
            html += "</body></html>";
            visualitzador.NavigateToString(html);
        }

I ara vegem el resultat:



Ara anem a fer la mateixa aplicació en android. Creem una Android Class Library (anomenada AndroidCore) buida i afegirem un element existent (cAtom.css) de l'anterior projecte. Però hem de tindre en compte que haurem de posar afegir com a link enlloc de copiar, per tal que les modificacions en un projecte afecten a l'altre.
Després crearem un altre projecte Android (anomenat testAndroid), però esta vegada aplicació, i afegirem una referència a l'anterior projecte. Afegim un WebView a l'aplicació i posem el codi per a què quan s'aprete el botó es visualitze:

 button.Click += delegate
            {
                carregador = new util.cAtom("http://www.vicentfernandez.cat/feeds/posts/default", 10);
                carregador.CarregarDades += CallbackCarregarDades;
                carregador.Run();
            };

Vegem que (òbviament) també té un callback:
private void CallbackCarregarDades()
        {
             Android.Webkit.WebView wc = FindViewById<Android.Webkit.WebView>(Resource.Id.webView1);
             string html = "<html><body>";
             foreach (var titol in carregador.getTitle())
             {
                 html += "<h2>" + titol + "</h2>";
             }
             html += "</body></html>";
             wc.LoadData(html, "text/html; charset=UTF-8", "ISO-8859-1");
       }

I ara vegem el resultat:

Comentaris

Entrades populars d'aquest blog

Clean Code... WTF? És realment viable?

Comparativa dels Sistemes Polítics Espanyol, Valencià i d'un partit polític. (II)

Hui he vist la por als ulls