Revista Active Delphi
quinta-feira, 29 de julho de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos
Criando e utilizando User Controls no Silverlight
Por: Edjan Santos
[Entre em contato com o autor ]
Desenvolvedor Web com mais de 6 anos de experiência, trabalha com a plataforma .NET desde 2006. Atualmente cursa bacharel de Sistemas de Informação e trabalha como coordenador de desenvolvimento. Vem se especializando em gerência de projetos e arquitetura de sistemas. Sócio Fundador da Labirintorium.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Criando e utilizando User Controls no Silverlight
Publicado em: 14/01/2010

Introdução

Constantemente no desenvolvimento de nossas aplicações necessitamos criar controles reutilizáveis, se você trabalha com ASP.NET com certeza já usou(ou ainda usa) muito User Control, no Silverlight essa necessidade também existe e o recurso também. Neste artigo abordaremos como criar e utilizar o User Controls, quais situações se aplica e os benefícios dessa prática.

Nesse artigo utilizaremos Silverlight 3, Visual Studio 2008 e Expression Blend 3.

Entendendo o User Control

Antes de iniciarmos a construção do nosso User Control gostaria de compara-lo com o MovieClip do Flash. Você possui um determinado “objeto” e cria-se instâncias dele dentro de sua aplicação, portanto ao alterar o “objeto” original todas suas instâncias são afetadas, entretanto, alterações feitas as instâncias se aplicam apenas a elas mesmas. O poder de customização de seu User Control após ser instanciado é enorme, já que se pode criar propriedades para alteração de valores nativos.

Criando e utilizando o User Control

Vamos logo então a criação do nosso User Control. Crie um novo projeto do tipo Silverlight Application:

O Visual Studio vai perguntar se você quer criar junto um projeto website para exibir sua aplicação Silverlight, caso queira confirme.

Após a criação do projeto vamos adicionar um novo item ao projeto Silverlight, do tipo Silverlight User Control, nomeie como “Topo.xaml” conforme a imagem abaixo:

O XAML gerado por um novo UserControl é idêntico ao criado pelo “MainPage.xaml” quando iniciamos um novo projeto, portanto a criação é tão livre quanto no MainPage, fique a vontade de criar StoryBoards, States, eventos, etc., mas para agilizar o artigo e o entendimento do funcionamento do User Control, copie e cole o código abaixo dentro da Grid “LayoutRoot”:

<UserControl x:Class="UserControlArtigo.Topo"

    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

    Width="550" Height="70">

    <Grid x:Name="LayoutRoot" Background="White">

      <Border Height="39" Margin="8,17,8,0" VerticalAlignment="Top" BorderBrush="Black" BorderThickness="1" Background="#FFDADADA">

            <TextBlock Text="Topo User Control" TextWrapping="Wrap" FontSize="29.333" FontWeight="Bold" FontFamily="Tahoma" Margin="8,0,-8,0"/>

            </Border>

    </Grid>

</UserControl>

 

Esse é todo o código do meu User Control, em negrito está o que adicionei e o que alterei (Width e Height do meu User Control).

Vamos agora voltar ao “MainPage.xaml” e adicionar o nosso User Control, para utilizarmos precisamos fazer uma referência a nossa própria aplicação no XAML do MainPage, essa referência é feita através da propriedade xmlns, essa propriedade adiciona ao XAML um determinado namespace, se você adicionar após o xmlns dois pontos “:” e um valor qualquer, “uc” por exemplo, estará nomeando a referência a esse WebService, vejamos como ficará o XAML da nossa MainPage após a referência:

<UserControl x:Class="UserControlArtigo.MainPage"

    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

    xmlns:uc="clr-namespace:UserControlArtigo"

    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"

    mc:Ignorable="d" d:DesignWidth="640" d:DesignHeight="480">

  <Grid x:Name="LayoutRoot" Width="640" Height="480" Background="White">

      

    </Grid>

</UserControl>

Em negrito a referência ao namespace do nosso projeto, para efetivamente adicionar o User Control adicione o seguinte código dentro da Grid “LayoutRoot”:

<uc:Topo x:Name="ucTopo"></uc:Topo>

 

Como você pode ver nosso User Control possui a propriedade x:Name, portanto pode ser facilmente acessado e manipulado no code-behind, além disso ele também possui as propriedades Width, Height, Margin, etc., podendo ser manipulado no XAML também.

Carregando User Controls dinamicamente

Um bom exemplo de uso de User Controls é criar “containers” para informações dinâmicas, por exemplo:

Para adicionar um User Control dinamicamente basta instanciar um objeto do tipo do seu User Control (no nosso caso “Topo”)  e depois adicionar o objeto a algum container (Grid, StackPanel, etc.), veja um exemplo abaixo:

Topo objTopo = new Topo();

objTopo.Margin = new Thickness(0, 100, 0, 0);

LayoutRoot.Children.Add(objTopo);

 

No exemplo acima instancio um objeto e manipulo o posicionamento dele no Grid “LayoutRoot”.

Outro modo de carregar um User Control é carregando dinamicamente um Assembly e obtendo o User Control, recomendo a leitura do artigo do Mike Taulty.





MS TechEd 2010



 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Ainda não existem comentários sobre este artigo. Seja o(a) primeiro(a)!
Outros artigos do autor Topo
Namespace em Javascript é possível?
JSON – Uma introdução
Artigos relacionados Topo
Usando o Scroll do mouse para dar Zoom em Imagens com Silverlight 4
Criando Protótipos com o SketchFlow Parte Final
Criando Protótipos com o SketchFlow Parte 1
Como Utilizar o Silverlight Media Player no SharePoint Server 2010
Silverlight 3 – Efeitos com Pixel Shader, parte final
Construindo uma aplicação Silverlight para Windows Phone 7
Desenvolvendo seu primeiro aplicativo para Silverlight Mobile
Silverlight 3 – Efeitos com Pixel Shader, parte 01
Usando AutoComplete TextBox Silverlight
Novidades do Silverlight 4 - Clipboard
Estratégia de Acesso a Dados para Silverlight
UserName e Password em serviços WCF para Silverlight
Serviços TCP no Silverlight
Binary Encoding no Silverlight 3.0
Usando Timer no WPF e Silverlight
Criando uma aplicação Silverlight que acessa uma base de dados PostgreSQL 8
Persistência de dados em aplicações Silverlight
Criando controles customizados em Silverlight
Simulando uma janela Pop-up no Silverlight
Controlando objetos pelo teclado (Silverlight)
Identificando valores selecionados em um DataGrid no Silverlight
Implementando AutoCompleteBox com dados retornados do SQL
Criando Storyboard no Silverlight pelo C#
Recebendo valores QueryString no Silverlight
Acessando funções JavaScript pelo Silverlight (C#)
Implementando Drag and Drop em aplicações Silverlight
Comunicação entre Silverlight e SQL Server
Produtos relacionados Topo
Livro: Desenvolvendo para web usando o Visual Studio 2008
Livro: Aprenda a programar Handheld e Pocket PC
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 2.488
Artigos: 2.972
Cases: 14
Oportunidades: 4.546
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
O que você fará com o Visual Studio 2010?
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
De: R$ 189,00
Por: R$ 126,00
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção C# Básico (válido somente para pagamento via boleto bancário)
De: R$ 185,90
Por: R$ 136,00
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
CDs/DVDs
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
Recursos Visuais na Web com PHP
Ciência Moderna
De: R$ 49,00
Por: R$ 29,40
Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
Erica
De: R$ 99,50
Por: R$ 84,50
Crie Projetos Gráficos com Adobe Photoshop CS4, CorelDRAW X4 e Adobe InDesign CS4 - em Português
Erica
De: R$ 77,50
Por: R$ 65,80
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Anderson Patricio
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
José Carlos Macoratti
Eric C M Oliveira
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Excel: fórmulas matriciais
ASP.NET 2.0 - Explorando o GridView
Iniciando um projeto de Nota Fiscal Eletrônica - NFe
PL/SQL - Procedures e Funções
Excel: Comparando Listas
PHP: Formulários e upload de múltiplos arquivos e fotos