Mostrando postagens com marcador C#. Mostrar todas as postagens
Mostrando postagens com marcador C#. Mostrar todas as postagens

quarta-feira, 25 de janeiro de 2012

Manipulando HTML com a Classe HtmlGenericControl e o Comando FindControl

    As vezes precisamos manipular o HTML para adicionar novas funções ou alterar o layout criado, neste post pretendo mostrar uma forma de se fazer isto.
    O comando FindControl é utilizado para localizar um controle, para que este comando funcione em projetos WEB precisamos no ASP.Net definir um ID e colocar o atributo runat=”server” conforme os exemplos abaixo:
 class="xml"><!-- runat="server" em uma div -->
<div class="menu" id="divMenu" runat="server">

<!-- runat="server" no body, repare que eu adicionei o atributo ID ao body -->
<body runat="server" id="body">
    O atributo runat=”server” pode ser adicionado em qualquer parte do HTML, este atributo server para informar que o controle (TAG HTML) vai ficar disponível no código do lado do servidor.
    Feito isso segue alguns exemplo do uso do comando FindControl :
// Pegando um controle ul 
HtmlGenericControl ulPrincipal = (HtmlGenericControl)FindControl("ulPrincipal");

// Pegando o body da página (o body deve conter o atributo ID e o atributo runat="server", conforme mencionado acima) 
HtmlGenericControl pgBody = (HtmlGenericControl)FindControl("body");

    Como a proposta deste artigo é a manipulação de controles HTML verifique que eu converti o controle localizado para a classe HtmlGenericControl, está classe vai nos ajudar a manipular os atributos do controle HTML, abaixo segue alguns exemplos de atributos que podemos manipular:
// Adicionando uma classe CSS
liLinhaF.Attributes.Add("class", "linha-menu");

// Adicionando um titulo, o conteúdo e o link de um controle a
aHref.Attributes.Add("title", "Titulo"); // Titulo
aHref.Attributes.Add("href", "link"); // link
aHref.InnerText = "Conteudo" // Conteúdo 

// Adicionando código HTML ao controle
liLinha.InnerHtml = " ";

// Adicionando o evento onload ao body da página
pgBody.Attributes.Add("onload", "javascript:alert(\'teste !\')");

// Manipulando o estilo de um controle HTML
lu.Style.Add("display", "none");
lu.Style.Add("visibility", "hidden");
    Além de manipular atributos também podemos adicionar outros controles dentro de outros controles (caso você tenha uma div ou table):
HtmlGenericControl ulPrincipal = (HtmlGenericControl)FindControl("ulPrincipal");
HtmlGenericControl liLinha = new HtmlGenericControl("li");
liLinha.Attributes.Add("class", "linha-menu");
liLinha.InnerHtml = "<B>Teste</B>";
ulPrincipal.Controls.Add(liLinha);
    Com o comando FindControl e a classe HtmlGenericControl fica muito fácil a manipulação do HTML do lado do servidor.

Referências:
Método Control.FindControl (String)
Classe HtmlGenericControl
Curso ASP.NET 3.5 em VB.NET e C# - Controles(Fernando Amaral)
Apply CSS for an HTML generic control like

terça-feira, 29 de novembro de 2011

Alimentando DataGrid WPF Dinamicamente com C#


                Muitas vezes precisamos alimentar um DataGrid dinamicamente, com o WPF está tarefa ficou bem fácil, vamos ao exemplo.
                Iremos criar um programa para exibir o alfabeto em maiúsculo , um contador e o código ASCII da letra dentro de um DataGrid assim que o usuário pressionar o botão.
                Vamos inserir um botão e um DataGrid, como o intuito aqui é alimentar dinamicamente o DataGrid, vamos alterar a propriedade AutoGenerateColumns  para true dentro do XAML , assim o DataGrid vai gerar as colunas para nós, abaixo segue como o código deve ficar :

<my:datagrid autogeneratecolumns="true" margin="12,42,12,20" name="dataGrid1" xmlns:my="clr-namespace:Microsoft.Windows.Controls;assembly=WPFToolkit"> </my:datagrid>
    

                No código vamos criar uma simples classe apenas com os atributos, segue o código:

    public class LetraNumero
    {
        public int Posicao { get; set; }
        public char Letra { get; set; }
        public int ASCII { get; set; }
    }

                Segue o código do evento Click do botão :

         private void button1_Click(object sender, RoutedEventArgs e)
        {   
            // Cria lista para os objetos (está lista tem que ser do tipo Generic)
            List<letranumero> lista = new List<letranumero>();

            // Rotina para alimentar a lista
            for (int i = 1; i < 27; i++)
            {
                LetraNumero item = new LetraNumero();
                item.Posicao = i;
                item.Letra = Convert.ToChar(64 + i);
                item.ASCII = 64 + i;
                lista.Add(item);
            }

             // Vinculando a lista ao grid
             dataGrid1.ItemsSource = lista; 
        }

                A propriedade ItemsSource do DataGrid aceita uma lista do tipo Generic e como a propriedade AutoGenerateColumns está como true, ele vai criar uma coluna para cada atributo da classe definida na lista. Abaixo segue o exemplo da tela em execução:


                Se for preciso, podemos alterar o titulo da coluna (pois ele sempre deixa a coluna com o nome da propriedade da classe) ou mesmo ocultar a coluna. Criei um outro botão com o mesmo código e inserir essas duas linhas, uma para renomear a coluna Posicao para Posição e a outra para ocultar a coluna ASCII:

             // Altera o titulo da coluna 0
            dataGrid1.Columns[0].Header = "Posição";           

            // Deixa a coluna 2 invisivel
            dataGrid1.Columns[2].Visibility = Visibility.Hidden;

                Executando o botão, verifique como ficou a tela:


 Referências:

sexta-feira, 17 de junho de 2011

Combo Box no WPF – Propriedades DisplayMemberPath e SelectedValuePath

                Muitas vezes queremos fazer um combo box onde mostraremos para o usuário um valor, mas internamente queremos utilizar outro. O combo box do WPF oferece uma forma muito fácil de fazer isso usando duas propriedades DisplayMemberPath e o SelectedValuePath.
                Abaixo segue o trecho do XAML do combo box, este combo box vai retornar o nome de alguns fabricantes:

<combobox displaymemberpath="ds_Fabricante" height="24" isenabled="True" itemssource="{Binding}" margin="92,0,66,200" name="cbFabricante" selectedvaluepath="cd_Id" selectionchanged="cbFabricante_SelectionChanged_1" verticalalignment="Bottom">
</combobox>
                Destaco as propriedades ItemsSource, onde coloquei o valor {Binding}, isso para que eu possa colocar dentro do código a chamada para a procedure que vai carregar este combo box, na propriedade DisplayMemberPath eu coloco o nome do campo que eu quero que apareça para o usuário(no caso o nome do fabricante do equipamento – ds_Fabricante) e na propriedade SelectedValuePath eu coloco o nome do campo que eu quero utilizar dentro do meu programa(cd_Id é o código do fabricante na tabela).
                Agora segue o código que coloquei para alimentar o combo box:
private void Window_Loaded(object sender, RoutedEventArgs e)
{
  using (SqlConnection conexao = new SqlConnection(@"String de Conexão com o Banco de dados"))
  {
    DataSet ds = new DataSet();
    SqlCommand cmd = new SqlCommand("exec pro_getFabricante", conexao);
    SqlDataAdapter sqlDA = new SqlDataAdapter(cmd);
    sqlDA.Fill(ds);
    cbFabricante.DataContext = ds.Tables[0].DefaultView;
    }
  }

                Está procedure está sendo executada no evento Loaded do formulário, no SqlCommand repare que eu executo uma procedure que está no banco de dados, está procedure pode ser substituída por um select e depois, na ultima linha, preencho o DataContext do combo box com o retorno da procedure. Segue a imagem de como fica o combo box:



                Para pegar o valor selecionado no combo box segue o código que foi configurado no evento SelectionChanged (este evento ocorre sempre que o valor do combobox for alterado)  e a imagem do alerta exibido:
private void cbFabricante_SelectionChanged_1(object sender, SelectionChangedEventArgs e)
{
  MessageBox.Show("Código selecionado: " + cbFabricante.SelectedValue); 
}


Referencias:
Documentação da Microsoft (ComboClass)
Stackoverflow -Binding WPF ComboBox to a Custom List
C# Corner - WPF ComboBox
Macoratti - WPF - Preenchendo uma Combobox

terça-feira, 24 de agosto de 2010

Lendo os Dados de uma Planilha do Excel C#

    Me deparei com uma situação onde precisava ler os dados de uma planilha de Excel, e depois de muita pesquisa segue a forma mais fácil que eu encontrei para fazer isso usando o C#, porem é necessário que o Excel esteja instalado nas maquinas onde seu programa vai executar.    
    O primeiro passo é adicionar as referências do Excel ao seu projeto, para isso clique com o botão direito em cima do seu projeto na Solution Explorer, vá até a opção Add Reference, depois na aba COM, procure pelo Microsoft Excel (versão) Object Library e depois click em OK.
    Adicione as seguintes bibliotecas ao seu fonte :
using Excel =  Microsoft.Office.Interop.Excel; //*
using System.Reflection;
    * Renomeie esta biblioteca para evitar conflitos de nome e facilitar seu uso dentro do seu programa

    Segue o código comentado para abrir o Excel,  a planilha ler os dados :
// Cria uma instancia do Excel
Excel.Application oXL = new Excel.Application();
// Objeto que vai  conter seu arquivo
Excel.Workbook oWB; 
// Caso você queira que o seu programa  mostre a planilha aberta no Excel deixa está opção como true
oXL.Visible = true; 
//Comando para abrir a  planilha, basta substituir o "endereço da planilha"
oWB = oXL.Workbooks.Open("endereço da planilha", 0, true,  5, "", "", true, Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, null, null); 
// Pega a planilha ativa, se o Excel não estiver  aberto é a primeira planilha do arquivo
Excel.Worksheet activeSheet = (Excel.Worksheet) oWB.ActiveSheet;
// Pega o  texto da célula A1
string cellA1 = (string) activeSheet.get_Range("A1", Missing.Value).Text;
// Exibe uma mensagem com o texto da célula A1
MessageBox.Show(cellA1);
    Caso você queira pegar uma planilha especifica do arquivo use o seguinte comando :
// Substitua o X pelo número da planilha, é  a ordem que aparece as abas
Excel.Worksheet activeSheet = (Excel.Worksheet) oWB.Worksheets.get_Item(X); 
   Isto é o básico para abrir e ler uma planilha no Excel, mas saiba que é possível alterar fonte, criar formula adicionar conteúdo e alterar dados.


Referências:
http://support.microsoft.com/kb/302084

sexta-feira, 23 de julho de 2010

Função C# para Copiar uma Palavra de uma Frase usando StringBuilder


    Quando temos preocupação com o uso de memória em nossas aplicações o uso do tipo String não é recomendável, devemos usar a classe StringBuilder, porem ela não tem tantas funções como tem o a classe String.
    Uma função que eu senti falta foi para copiar uma palavra de uma frase, ou um trecho delimitado por isso criei a função abaixo:
// Copia as palavra na posição e seu separador
private StringBuilder Palavra(StringBuilder pacote, char separador, int posicao)
{
    StringBuilder retorno = new StringBuilder();           
    for (int i = 0, pos = 1; i < pacote.Length; i++)
    {          
        retorno.Append(pacote[i]);
        if (pacote[i] == separador)
                {
                    if (pos == posicao)
                    {
                        retorno.Remove(retorno.Length - 1, 1);
                        break;
                    }
                    else
                    {
                        retorno.Remove(0, retorno.Length);
                        pos++;
                    }
                }
            }
            return new StringBuilder().Append(retorno);
}

    Esta função possui três parâmetros :
        - pacote: é a frase que queremos pegar uma palavra;
        - separador: caracter utilizado para separar as palavras;
        - posicao: posição da palavra dentro da frase.

        Exemplo
        Temos a seguinte frase:
StringBuilder aux = new  StringBuilder("Santos campeão da Copa do Brasil de 2010");

        Para pegar a palavra "Santos" usaremos a função da seguinte forma
Palavra(aux,' ',1);