Registre-se E fique Por Dentro Das Novidades Do Site e Seja Mais Um Membro Seja Um Membro e Ajude Nois A Crese

Participe do fórum, é rápido e fácil

Registre-se E fique Por Dentro Das Novidades Do Site e Seja Mais Um Membro Seja Um Membro e Ajude Nois A Crese

Gostaria de reagir a esta mensagem? Crie uma conta em poucos cliques ou inicie sessão para continuar.

    [Tutorial] Criando um aplicativo para o Orkut

    Breno_Arthur
    Breno_Arthur
    Admin
    Admin


    Mensagens : 87
    Pontos : 26243
    Data de inscrição : 05/12/2010
    Idade : 29
    Localização : Aracaju-se

    [Tutorial] Criando um aplicativo para o Orkut Empty [Tutorial] Criando um aplicativo para o Orkut

    Mensagem por Breno_Arthur Sex Dez 10, 2010 6:58 am

    O Google lançou no final de outubro a API Open Social. A OpenSocial permite que se desenvolva aplicações para o MySpace, o Orkut ou LinkeIn, e ou outras redes sociais.
    Para desenvolver e testar os aplicativos no Orkut é necessário solicitar um convite na página orkut - Sandbox Signup. O Orkut passa a ser acessado pelo endereço: [Tens de ter uma conta e sessão iniciada para poderes visualizar este link]
    O Tutorial que acompanha este artigo mostra passo a passo como criar um aplicativo simples para o Orkut. O aplicativo irá ler um XML com notícias e exibirá os links na página principal do Orkut.
    Repare na imagem abaixo que algumas alterações foram realizadas na página inicial, que agora além de mostrar os aplicativos mostra também seus videos e fotos.


    [Tutorial] Criando um aplicativo para o Orkut Fig111


    [Tutorial] Criando um aplicativo para o Orkut Fig210

    [Tutorial] Criando um aplicativo para o Orkut Fig310

    Criaremos um Handler para gerar o XML
    Gerando o XML
    Precisamos gerar o XML com a lista de Notícias. Se eu não estivesse usando o .Net essa tarefa seria um pouco mais trabalhosa, pois teria que gerar o XML na mão fazendo um Loop nos registros do banco.
    O DataSet possui uma propriedade chamada WriteXml, essa propriedade varre o DataSet e gera o XML com ou sem o Schema, podendo salvá-lo em um arquivo físico ou em um Stream.
    ds.WriteXml(context.Response.Output, XmlWriteMode.IgnoreSchema);

    ds.WriteXml(context.Response.Output, XmlWriteMode.IgnoreSchema); O primeiro parâmetro informa ao DataSet para enviar o XML para o context.Response.Output, que é a saída do nosso Httphandler. O segundo parâmetro ‘XmlWriteMode.IgnoreSchema’ faz com que sejam gerados somente os dados, ignorando as definições de campos.



    <%@ WebHandler Language="C#" Class="gadget_noticias" %>
    using System;
    using System.Web;
    using System.Configuration;
    using System.Data;
    using System.IO;
    using MySql.Data.MySqlClient;
    public class gadget_noticias : IHttpHandler {
    public void ProcessRequest (HttpContext context) {
    Int32 qntNoticias;
    //Quantidade de Notícias, passado via QueryString
    if (!Int32.TryParse(context.Request.QueryString["q"], out qntNoticias))
    {
    //Se não for passado um número válido assume valor 5
    qntNoticias = 5;
    }
    try
    {
    using (MySqlConnection conn = new MySqlConnection(ConfigurationManager.AppSettings["conexaoMySql"]))
    {
    //Resgata as últimas notícias do Site
    String sqlStr = String.Format("SELECT id, titulo, data FROM noticias_dinamicas ORDER BY id DESC Limit 0, {0}", qntNoticias);
    DataSet ds = new DataSet("dsNoticias");
    MySqlDataAdapter AptNoticias = new MySqlDataAdapter(sqlStr, conn);
    AptNoticias.Fill(ds, "noticias");
    //Formato de Saída
    context.Response.ContentType = "text/xml";
    //Transforma o DataSet em XML e envia para o Cliente
    ds.WriteXml(context.Response.Output, XmlWriteMode.IgnoreSchema);
    }
    }
    catch
    {
    //Exibe uma Mensagem de erro
    context.Response.ContentType = "text/plain";
    context.Response.Write("Ocorreu um erro ao exibir notícias!");
    }
    }


    <%@ WebHandler Language="C#" Class="gadget_noticias" %> using System; using System.Web; using System.Configuration; using System.Data; using System.IO; using MySql.Data.MySqlClient; public class gadget_noticias : IHttpHandler { public void ProcessRequest (HttpContext context) { Int32 qntNoticias; //Quantidade de Notícias, passado via QueryString if (!Int32.TryParse(context.Request.QueryString["q"], out qntNoticias)) { //Se não for passado um número válido assume valor 5 qntNoticias = 5; } try { using (MySqlConnection conn = new MySqlConnection(ConfigurationManager.AppSettings["conexaoMySql"])) { //Resgata as últimas notícias do Site String sqlStr = String.Format("SELECT id, titulo, data FROM noticias_dinamicas ORDER BY id DESC Limit 0, {0}", qntNoticias); DataSet ds = new DataSet("dsNoticias"); MySqlDataAdapter AptNoticias = new MySqlDataAdapter(sqlStr, conn); AptNoticias.Fill(ds, "noticias"); //Formato de Saída context.Response.ContentType = "text/xml"; //Transforma o DataSet em XML e envia para o Cliente ds.WriteXml(context.Response.Output, XmlWriteMode.IgnoreSchema); } } catch { //Exibe uma Mensagem de erro context.Response.ContentType = "text/plain"; context.Response.Write("Ocorreu um erro ao exibir notícias!"); } } Confira o resultado:
    [Tens de ter uma conta e sessão iniciada para poderes visualizar este link]
    Configurando o Aplicativo
    As propriedades abaixo controlam a exibição do aplicativo na página. Título, Url, Autor, Descrição e Thumbnail. O Thumb pode ser um PNG transparente.


    1-<module>
    2-<moduleprefs
    3-title="N@Midia"
    4-title_url="http://projetos.atualizador.com/gadget_noticias.ashx"
    5-author="Caique Dourado"
    6-author_email="kellowdourado@gmail.com"
    7-description="Notcias recentes do N@Midia."
    8-thumbnail="http://www.jdnamidia.com.br/imagens/logo_transparente.png"
    9->
    10-<require feature="dynamic-height"></require>
    11-</moduleprefs>


    <UserPref name="quantidade" display_name="Quantidade" datatype="enum" default_value="5"> <EnumValue value="1" display_value="1"/> <EnumValue value="2" display_value="2"/> <EnumValue value="3" display_value="3"/> <EnumValue value="4" display_value="4"/> <EnumValue value="5" display_value="5"/> <EnumValue value="6" display_value="6"/> <EnumValue value="7" display_value="7"/> <EnumValue value="8" display_value="8"/> <EnumValue value="9" display_value="9"/> <EnumValue value="10" display_value="10"/> </UserPref> Criamos a função montaLinks() que montará os links varrrendo o XML.

    1-function montaLinks()

    function montaLinks() Resgatamos a propriedade quantidade


    1-var prefs = new _IG_Prefs(__MODULE_ID__);
    2-var quantidade = prefs.getString("quantidade");

    var prefs = new _IG_Prefs(__MODULE_ID__); var quantidade = prefs.getString("quantidade"); URL do arquivo XML que contém as notícias

    var url = "http://projetos.atualizador.com/gadget_noticias.ashx?q=" + quantidade;

    var url = "http://projetos.atualizador.com/gadget_noticias.ashx?q=" + quantidade; A função _IG_FetchXmlContent se resgata os dados do XML. Se não houver retorno é exibido o texto ‘Dados inválidos’.

    1-_IG_FetchXmlContent(url, function (response) {
    2-if (response == null || typeof(response) != "object" || response.firstChild == null)
    3-{
    4-_gel("conteudo").innerHTML = "<i>Dados inválidos.</i>";
    5-return;
    6-}


    _IG_FetchXmlContent(url, function (response) { if (response == null || typeof(response) != "object" || response.firstChild == null) { _gel("conteudo").innerHTML = "<i>Dados inválidos.</i>"; return; } Varremos todos os nós do XML que contém a tag ‘noticias’ e montamos os links usando o id, data e título. Ao terminar o laço inserimos os links na Div ‘conteúdo’

    1-var html = "";
    2-var itemList = response.getElementsByTagName("noticias");
    3-for (var i = 0; i < itemList.length ; i++)
    4-{
    5-var nodeList = itemList.item(i).childNodes;
    6-for (var j = 0; j < nodeList.length ; j++) {
    7-var node = nodeList.item(j);
    8-if (node.nodeName == "id")
    9-{
    10-var idNoticia = node.firstChild.nodeValue;
    11-}
    12-if (node.nodeName == "data")
    13-{
    14-var data = node.firstChild.nodeValue;
    15-}
    16-if (node.nodeName == "titulo")
    17-{
    18-var titulo = node.firstChild.nodeValue;
    19-}
    20-}
    21-html += "<p style='display: block; margin-left: 5px;'>"; html += "<a 22.href='http://www.jdnamidia.com.br/ver_noticia_novo.php?id=" + idNoticia + "' target='_blank' style='font-23.size:12px; color:#02679C;'>" + data + " - " + titulo + "</a>"; html += "</p>";
    24-}
    _gel('conteudo').innerHTML = html;




    var html = ""; var itemList = response.getElementsByTagName("noticias"); for (var i = 0; i < itemList.length ; i++) { var nodeList = itemList.item(i).childNodes; for (var j = 0; j < nodeList.length ; j++) { var node = nodeList.item(j); if (node.nodeName == "id") { var idNoticia = node.firstChild.nodeValue; } if (node.nodeName == "data") { var data = node.firstChild.nodeValue; } if (node.nodeName == "titulo") { var titulo = node.firstChild.nodeValue; } } html += "<p style='display: block; margin-left: 5px;'>"; html += "<a href='http://www.jdnamidia.com.br/ver_noticia_novo.php?id=" + idNoticia + "' target='_blank' style='font-size:12px; color:#02679C;'>" + data + " - " + titulo + "</a>"; html += "</p>"; } _gel('conteudo').innerHTML = html; Ajusta o tamanho do Frame utilizado pelo aplicativo

    1-_IG_AdjustIFrameHeight();

    _IG_AdjustIFrameHeight(); Registramos a função montaLinks no evento OnLoad

    1-_IG_RegisterOnloadHandler(montaLinks);

    _IG_RegisterOnloadHandler(montaLinks); Arquivo Completo:


    1-<module>
    2-<moduleprefs
    3-title="N@Midia"
    4-title_url="http://projetos.atualizador.com/gadget_noticias.ashx"
    5-author="Caique Dourado"
    6-author_email="kellowdourado@gmail.com"
    7-description="Notcias recentes do N@Midia."
    8-thumbnail="http://www.jdnamidia.com.br/imagens/logo_transparente.png"
    9->
    10-<require feature="dynamic-height"></require>
    11-</moduleprefs>
    12-<userpref name="quantidade" display_name="Quantidade" datatype="enum" default_value="5">
    13-<enumvalue value="1" display_value="1">
    14-<enumvalue value="2" display_value="2">
    15-<enumvalue value="3" display_value="3">
    16-<enumvalue value="4" display_value="4">
    17-<enumvalue value="5" display_value="5">
    18-<enumvalue value="6" display_value="6">
    19-<enumvalue value="7" display_value="7">
    20-<enumvalue value="8" display_value="8">
    21-<enumvalue value="9" display_value="9">
    22-<enumvalue value="10" display_value="10">
    23-</enumvalue>
    24-<content type="html">
    25-<!--[CDATA[
    26-<div id="conteudo"></div>
    27-<script type="text/javascript">
    28-function montaLinks() {
    29-var prefs = new _IG_Prefs(__MODULE_ID__); var quantidade = prefs.getString("quantidade"); var url = 30-&quot;http://projetos.atualizador.com/gadget_noticias.ashx?q=&quot; + quantidade;
    30-_IG_FetchXmlContent(url, function (response) {
    31-if (response == null || typeof(response) != "object" || response.firstChild == null) { _gel("conteudo").innerHTML = "<i>Dados inválidos.</i>"; return; }
    32-var html = ""; var itemList = response.getElementsByTagName("noticias");
    33-for (var i = 0; i < itemList.length ; i++) {
    34-var nodeList = itemList.item(i).childNodes;
    35-for (var j = 0; j < nodeList.length ; j++) {
    36-var node = nodeList.item(j);
    37-if (node.nodeName == "id") { var idNoticia = node.firstChild.nodeValue; }
    38-if (node.nodeName == "data") { var data = node.firstChild.nodeValue; }
    39-if (node.nodeName == "titulo") { var titulo = node.firstChild.nodeValue; }
    40-}
    41-html += "
    42-<p style=\'display: block; margin-left: 5px;\'>"; html += "<a 43..href=\'http://www.jdnamidia.com.br/ver_noticia_novo.php?id=" + idNoticia + "\' target=\'_blank\' 44..style=\'font-size:12px; color:#02679C;\'>" + data + " - " + titulo + "</a>"; html += "</p>
    45-"; }
    46-_gel(\'conteudo\').innerHTML = html; _IG_AdjustIFrameHeight();
    47-}); }
    48-_IG_RegisterOnloadHandler(montaLinks);
    49</script>
    50-]]-->
    51-</content>
    52-</enumvalue>




    <module> <moduleprefs title="N@Midia" title_url="http://projetos.atualizador.com/gadget_noticias.ashx" author="Caique Dourado" author_email="kellowdourado@gmail.com" description="Notcias recentes do N@Midia." thumbnail="http://www.jdnamidia.com.br/imagens/logo_transparente.png" > <require feature="dynamic-height"></require> </moduleprefs> <userpref name="quantidade" display_name="Quantidade" datatype="enum" default_value="5"> <enumvalue value="1" display_value="1"> <enumvalue value="2" display_value="2"> <enumvalue value="3" display_value="3"> <enumvalue value="4" display_value="4"> <enumvalue value="5" display_value="5"> <enumvalue value="6" display_value="6"> <enumvalue value="7" display_value="7"> <enumvalue value="8" display_value="8"> <enumvalue value="9" display_value="9"> <enumvalue value="10" display_value="10"> </enumvalue> <content type="html"> <!--[CDATA[ <div id="conteudo"></div> <script type="text/javascript"> function montaLinks() { var prefs = new _IG_Prefs(__MODULE_ID__); var quantidade = prefs.getString("quantidade"); var url = &quot;http://projetos.atualizador.com/gadg....ashx?q=&quot; + quantidade; _IG_FetchXmlContent(url, function (response) { if (response == null || typeof(response) != "object" || response.firstChild == null) { _gel("conteudo").innerHTML = "<i>Dados inválidos.</i>"; return; } var html = ""; var itemList = response.getElementsByTagName("noticias"); for (var i = 0; i < itemList.length ; i++) { var nodeList = itemList.item(i).childNodes; for (var j = 0; j < nodeList.length ; j++) { var node = nodeList.item(j); if (node.nodeName == "id") { var idNoticia = node.firstChild.nodeValue; } if (node.nodeName == "data") { var data = node.firstChild.nodeValue; } if (node.nodeName == "titulo") { var titulo = node.firstChild.nodeValue; } } html += " <p style=\'display: block; margin-left: 5px;\'>"; html += "<a href=\'http://www.jdnamidia.com.br/ver_noticia_novo.php?id=" + idNoticia + "\' target=\'_blank\' style=\'font-size:12px; color:#02679C;\'>" + data + " - " + titulo + "</a>"; html += "</p> "; } _gel(\'conteudo\').innerHTML = html; _IG_AdjustIFrameHeight(); }); } _IG_RegisterOnloadHandler(montaLinks); </script> ]]--> </content> </enumvalue>

      Data/hora atual: Sex Abr 19, 2024 12:07 am