Mini curso de Visual Basic .NET Índice

Transcrição

Mini curso de Visual Basic .NET Índice
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Mini curso de Visual Basic .NET
Índice
Introdução...................................................................................................................................... 2
Exercício 1 ................................................................................................................................. 2
Exercício 2 ................................................................................................................................. 3
Exercício 3 ................................................................................................................................. 4
Exercício 4 ................................................................................................................................. 4
ToolTip........................................................................................................................................... 6
Menus ............................................................................................................................................ 7
Teclas de atalho ............................................................................................................................ 8
Try … Catch .................................................................................................................................. 9
Janelas Modal ............................................................................................................................. 11
Aplicações MDI............................................................................................................................ 12
Caixas de diálogo ........................................................................................................................ 13
Barra de estado ........................................................................................................................... 16
Timer ........................................................................................................................................... 17
Ícone na área de notificação ....................................................................................................... 18
Menus de contexto ...................................................................................................................... 19
Acesso a dados ........................................................................................................................... 20
ADO.NET ................................................................................................................................. 20
Consulta de um registo ............................................................................................................ 22
Commands............................................................................................................................... 23
Publicar uma aplicação ............................................................................................................... 25
Inserir pastas e ficheiros .......................................................................................................... 25
Debug ...................................................................................................................................... 26
Fazer o publish ........................................................................................................................ 27
Instalação................................................................................................................................. 30
1 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Introdução
Este pequeno manual resulta de uma acção de formação, onde os formandos já tinham noções
de programação, pelo que não demonstra os primeiros passos na programação e na linguagem
VB.NET.
Foram utilizados alguns exercícios como introdução à sintaxe e ao IDE (integrated
development environment – ambiente integrado de desenvolvimento) usado, o VB.NET 2008
Express fornecido gratuitamente pela Microsoft.
Com o lançamento de novas versões do IDE da Microsoft, poderá ser necessário alguma
adaptação destas matérias, sendo esta tipicamente simples.
Exercício 1
Criar uma aplicação de nome botoes.exe, com as seguintes características:
1. Tem quatro botões, um em cada canto do form;
2. O form tem um ícone diferente do default;
3. Ao clicar em cada botão, abre uma msgbox;
4. Cada msgbox tem um ícone e botões diferentes;
5. Ao redimensionar o form, os botões mantêm-se nos cantos.
Solução do exercício:
Public Class Form1
2 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button1.Click
MsgBox("Mensagem 1", MsgBoxStyle.Critical +
MsgBoxStyle.OkOnly, "MSG 1")
End Sub
Private Sub Button3_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button3.Click
MsgBox("Mensagem 2", MsgBoxStyle.Information +
MsgBoxStyle.RetryCancel, "MSG 2")
End Sub
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button2.Click
MsgBox("Mensagem 3", MsgBoxStyle.Question +
MsgBoxStyle.YesNoCancel, "MSG 3")
End Sub
Private Sub Button4_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button4.Click
MsgBox("Mensagem 4", MsgBoxStyle.Exclamation +
MsgBoxStyle.AbortRetryIgnore, "MSG 4")
End Sub
End Class
Exercício 2
Criar uma aplicação de nome impossivel.exe, com as seguintes características:
1. Tem dois botões, um de cada lado do form;
2. Apenas um botão está visível;
3. Ao passar por cima do botão, o mesmo botão desaparece e aparece o outro botão.
Solução do exercício:
Public Class Form1
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As
System.EventArgs) Handles MyBase.Load
Button1.Show()
Button2.Hide()
End Sub
3 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Private Sub Button1_MouseHover(ByVal sender As System.Object,
ByVal e As System.EventArgs) Handles Button1.MouseHover
Button1.Hide()
Button2.Show()
End Sub
Private Sub Button2_MouseHover(ByVal sender As System.Object,
ByVal e As System.EventArgs) Handles Button2.MouseHover
Button1.Show()
Button2.Hide()
End Sub
End Class
Exercício 3
Criar uma aplicação de nome lista.exe, com as seguintes características:
1. Tem uma caixa de texto, dois botões e uma listbox;
2. O primeiro botão adiciona à lista, o texto da caixa de texto;
3. Ao adicionar um elemento, a caixa de texto fica vazia;
4. O segundo botão elimina da lista o elemento seleccionado.
Solução do exercício:
Public Class Form1
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button1.Click
ListBox1.Items.Insert(0, TextBox1.Text)
TextBox1.Text = String.Empty
End Sub
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button2.Click
ListBox1.Items.Remove(ListBox1.SelectedItem)
End Sub
End Class
Exercício 4
Criar uma aplicação de nome tabuada.exe, com as seguintes características:
1. Tem uma caixa de texto e um botão;
4 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
2. Ao clicar no botão, abre um msgbox com a tabuada.
Solução do exercício:
Public Class Form1
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e
As System.EventArgs) Handles Button1.Click
Dim str As String = String.Empty
For i As Integer = 1 To 10
str = str & i & " x " & TextBox1.Text & " = " & (i *
TextBox1.Text) & Chr(13)
Next
MsgBox(str, MsgBoxStyle.Information, "Tabuada")
End Sub
End Class
5 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
ToolTip
O toolTip é a pequena caixa, normalmente de fundo amarela, que surge junto ao cursor do rato
quanto este se encontra sobre um objecto, e contém algum texto, tipicamente uma ajuda ou
informação adicional sobre esse mesmo objecto.
No VB, nenhum objecto tem, à partida, uma propriedade para definir o texto do toolTip, sendo
necessário adicionar o objecto ToolTip a cada formulário onde é pretendido definir toolTips.
Ao adicionar o objecto ToolTip, este não surge no form, mas sim numa região fora deste, em
baixo no IDE. Isto porque o objecto não está sempre presente no form – apenas surge se for
configurado nos objectos do form.
A nova propriedade que surge nos objectos do form tem o nome ToolTip on ToolTip1.
Significa que se houver mais objectos ToolTip no form, surgem novas propriedades nos
objectos, sendo possível p.ex. usar formatos diferentes de ToolTip em objectos diferentes.
A configuração do ToolTip, como as cores ou um ícone, é feita nas propriedades do próprio
objecto ToolTip.
6 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Menus
Os menus típicos de uma aplicação, que surgem no topo a seguir à barra de título,
disponibilização o acesso às diversas opções da aplicação.
No VB, o menu é gerado pelo objecto MenuStrip. Este objecto é adicionado à região em baixo
no IDE, e é criado uma barra no topo do form – é nessa barra que se define o menu.
A definição do menu é muito intuitiva, bastando clicar e escrever o nome de cada opção de
menu. Além do objecto, também cada opção de menu criada tem as suas próprias
propriedades.
Podem definir os menus (1º nível) e as várias opções nos níveis inferiores (2º nível, 3º nível,
etc).
Para programar cada opção do menu, basta fazer duplo clique sobre a opção – para o evento
Click, ou seleccionar a opção e escolher, nos eventos, o evento pretendido. Em tudo
semelhante p.ex. a um botão.
7 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Teclas de atalho
As teclas de atalho servem para aceder a um objecto de uma maneira rápida – uma
combinação de teclas em substituição do clique do rato. Essa combinação de teclas é a tecla
ALT e mais uma letra (número ou símbolo).
Para definir qual a tecla de atalho, na propriedade Text, coloca-se o símbolo & (“e” comercial)
à esquerda da letra / número que se pretende usar como atalho.
Ao clicar na tecla ALT, os caracteres definidos como atalhos surgem sublinhados – aplicável
p.ex. ao menu a um botão.
No caso de haver um atalho num label, e de haver uma textBox (ou outro elemento que pode
ter focus – ficar activo – como uma checkBox ou uma comboBox), o atalho coloca o focus no
elemento que tiver a propriedade TabIndex (índice do TAB) imediatamente seguinte à do label.
8 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Try … Catch
O Try Catch é usado para executar um bloco de código VB, e em caso de erro, previne a
aplicação de terminar abruptamente.
Erro quanto executado em debug:
Erro quando executado a partir do executável:
9 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
O bloco Try contém o código a executar. Caso ocorra um erro (designada por excepção) nesse
bloco a execução passa de imediato para o bloco Catch onde o erro é tratado.
Pode-se mostrar uma mensagem mais amigável ao utilizador (em vez de um erro) ou enviar
um email ao responsável da informática com o erro que ocorreu.
Por fim, e opcionalmente, pode existir um bloco Finally, cujo código executa quer tenha havido
ou não um erro no bloco Try – para libertar os recursos usados, como um ficheiro aberto ou
uma ligaçãoa uma base de dados.
Dim n As Integer
Try
n = 1 + TextBox1.Text
Catch ex As Exception
MsgBox("Erro: " & ex.Message)
Finally
'código que executa sempre
End Try
No bloco Catch, a variável do tipo Exception permite o acesso ao detalhe do erro.
Enquanto que ex.Message contém uma mensagem indicativa do erro, já ex.ToString()
contém toda a informação do erro (como o erro ou a linha em que ocorreu).
10 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Janelas Modal
Uma janela (form), quando é aberta a partir de outra, pode ser aberta de dois modos - Modal
ou não Modal.
Quando uma janela é Modal, não é permitido clicar noutra janelas da aplicação, enquanto a
própria janela (Modal) não for fechada. Ou seja, uma janela Modal fica sempre activa enquanto
não for fechada.
Já no caso de uma janela não Modal, é possível clicar noutra janela, passando esta a estar
activa, deixando de estar activa a janela anterior – ou seja há liberdade de ver livremente as
janelas (só uma de uma de cada vez é que pode estar activa).
' abrir um form modal
Form1.ShowDialog()
' abrir um form não modal
Form1.Show()
11 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Aplicações MDI
Uma aplicação pode usar um ou mais forms, sendo que quando estes são independentes,
chama-se SMI – Single Document Interface. É o modo predefinido no VB.
Quando uma aplicação usa vários forms, e onde existe a relação de “form pai – form filho”,
chama-se MDI – Multiple Document Interface.
Os forms “pai” podem albergar forms “filho”. Para tal, o form “pai” deve ter na propriedade
IsMdiContainer o valor true.
Form1 sem ser MDI container:
Form1 MDI container:
No form “pai”, deve-se definir que esse form é o “pai” dos outros forms.
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As
System.EventArgs) Handles MyBase.Load
Form2.MdiParent = Me
End Sub
Ao fazer show() do form2, este surge dentro do form ”pai”.
12 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Caixas de diálogo
As caixas de diálogo servem para pedir ao utilizador determinada informação. O VB
disponibiliza algumas caixas de diálogo, como p.ex. para selecção de uma cor, para selecção
de fonte e tamanho, para escolher um ficheiro a abrir, ou para escolher o nome do ficheiro a
guardar.
Todos os dialogs são janelas “modais”.
Para escolher uma cor, e após adicionar ao form o objecto ColorDialog (que surge em baixo
no IDE):
ColorDialog1.ShowDialog()
Surge então:
Para aplicar a cor escolhida no dialog à cor do texto de um label:
Label1.ForeColor = ColorDialog1.Color
13 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Para escolher uma fonte (e tamanho do texto), e após adicionar ao form o objecto FontDialog
(que surge em baixo no IDE):
FontDialog1.ShowDialog()
Surge então:
Para aplicar a fonte e tamanho escolhidos no dialog ao texto de um label:
Label1.Font = FontDialog1.Font
Para escolher o ficheiro a ler, e após adicionar ao form o objecto OpenFileDialog (que surge
em baixo no IDE):
OpenFileDialog1.ShowDialog()
Surge então:
Para mostrar o nome do ficheiro escolhido no dialog no texto de um label:
Label1.Text = OpenFileDialog1.SafeFileName
14 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Para escolher o nome do ficheiro a gravar, e após adicionar ao form o objecto SaveFileDialog
(que surge em baixo no IDE):
SaveFileDialog1.ShowDialog()
Surge então:
Para mostrar o nome e caminho do ficheiro guardado (escolhido no dialog) no texto de um
label:
Label1.Text = SaveFileDialog1.FileName
15 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Barra de estado
A maioria das aplicações Windows tem, no fundo da janela, uma barra – barra de estado.
Nessa barra de estado, surgem diversos tipos de informação.
Após adicionar a um form o objecto StatusStrip, surge no form uma barra:
Nesta barra de estado (status bar), é possível adicionar objectos de quatro tipos:
16 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Timer
O objecto Timer serve para executar um bloco de VB a cada X tempo. Este tempo é definido
em milissegundos.
Há duas propriedades importantes – Enabled, que activa ou não o Timer (por omissão está
False), e o Interval, onde se define o número de milissegundos.
O local onde se define o que é para fazer (X em X milissegundos) é no evento Tick, o único
evento do objecto Timer.
Private Sub Timer1_Tick(ByVal sender As System.Object, ByVal e As
System.EventArgs) Handles Timer1.Tick
Label1.Text = Now
End Sub
No label surge então a data / hora (resultado do Now), que é actualizada a cada 1000
milissegundos (valor da propriedade Interval).
Não esquecer de colocar True na propriedade Enabled.
17 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Ícone na área de notificação
Algumas aplicações usam um ícone na área de notificação – onde se encontra o relógio, e que
pertence à barra de tarefas.
Para que uma aplicação VB tenha também ela um ícone junto ao relógio, basta usar o objecto
NotifyIcon.
Para que surja na área de notificação, é necessário definir o ícone (que por omissão não vem
definido) – propriedade Icon.
Ao executar a aplicação, o ícone surge na área de notificação.
18 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Menus de contexto
Os menus de contexto (context menus) são os menus que surgem quando se clica com o
botão direito sobre um objecto. Tipicamente este menu é adequado ao objecto, ou seja, tem
opções específicas de acordo com o objecto clicado.
O objecto é o ContextMenuStrip, e podem ser usados diversos ContextMenuStrip, para
definir menus diferentes que depois são associados aos respectivos objectos.
A definição do menu é em tudo igual ao objecto MenuStrip – define-se o texto, e clica-se para
definir o evento Click.
Private Sub FecharToolStripMenuItem_Click(ByVal sender As
System.Object, ByVal e As System.EventArgs) Handles
FecharToolStripMenuItem.Click
Application.Exit()
End Sub
Para usar um menu de contexto, basta associá-lo na propriedade ContextMenuStrip p.ex. de
um botão ou de um NotifyIcon.
Ao clicar com o botão direito no ícone da aplicação, surge então o menu de contexto.
19 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Acesso a dados
O VB.NET (e as restantes linguagens de programação .NET) permite ligar a uma grande
variedade de bases de dados.
O .NET traz um novo modo como é feita a ligação e manipulação de dados, permitindo também
essa manipulação do modo mais clássico.
ADO.NET
O ADO.NET (versão .NET do antigo ActiveX Data Objects) permite lidar com os dados de uma
base de dados de diversas formas, desde a modo como se liga à base de dados até ao modo
como trata os dados.
Para ligar a uma base de dados é usado um .NET Data Provider. É ele que permite usar
determinado tipo de base de dados.
Exemplo:
• OLE DB .NET Data Provider
o Liga a qualquer fonte de dados (que suporte OLE)
o Necessita de identificar o provider (“tipo” de origem de dados)
o Definido no namespace de nome System.Data.OleDB
• SQL Server .NET Data Provider
o Liga somente ao SQL Server (optimizado para este)
o Definido no namespace de nome System.Data.SqlClient
Existem outros providers, que não fazem parte da .NET Framework (necessitam de ser
instalados à parte) destinados a uma melhor optimização (para Oracle ou MySQL p.ex.).
O ADO.NET tem a seguinte arquitectura.
Resumindo, e após a ligação (connection) à base de dados é possível:
1. Ler / escrever dados através de um comando (e usar um DataReader para ler dados
p.ex.),
2. Usar um DataAdapter na ligação, ficando os dados num DataSet.
Os dados, dentro do DataSet (e transparente para o utilizador) são manipulados via XML.
20 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Exemplos de algumas classes:
• Connection
o Estabelece a ligação a uma origem de dados.
• Command
o Executa comandos sobre a base de dados.
• DataReader
o Usado com o objecto Command disponibiliza acesso read-only, forward-only a
um conjunto de registos obtidos a partir de uma base de dados – executa sem
o uso de um DataSet, para disponibilização imediata de dados.
• DataAdapter
o Interface entre o DataSet e a base de dados
Exemplo de algumas classes:
• DataTable
o Referencia uma tabela no DataSet.
• DataRow
o Referencia registos (linhas) de um DataTable.
• DataColumn
o Referencia um campo (coluna) de um DataTable.
• ConstrainCollection
o Permite Impor restrições sobre os dados de um DataTable.
• DataRelation
o Relaciona dois objectos DataTable através do objecto DataColumn.
21 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Consulta de um registo
Exemplo com um command
' connection - ligação à base de dades
Dim conn As New OleDbConnection
' definir a ligação à DB
conn.ConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data
Source=C:\amigos.mdb"
' abrir a ligação
conn.Open()
' comando SQL
Dim sql As String
' definir o SQL e configura o command
sql = "SELECT id,nome,telefone FROM amigos WHERE ID=" & id.Text
Dim cmd As New OleDbCommand(sql, conn)
' definir um datareader, que vai receber o resultado da query
Dim dr As OleDbDataReader
' executa o comando - o resultado fica no datareader
dr = cmd.ExecuteReader
' ler os dados do datareader
dr.Read()
' coloca nos textboxes cada campo do datareader (1º row)
TextBox1.Text = dr.Item("id")
TextBox2.Text = dr.Item("nome")
TextBox3.Text = dr.Item("telefone")
' fecha a ligação à DB
conn.Close()
Exemplo com um DataSet
' connection - ligação à base de dades
Dim conn As New OleDbConnection
' definir a ligação à DB
conn.ConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data
Source=C:\amigos.mdb"
' abrir a ligação
conn.Open()
' comando SQL
Dim sql As String
' definir o SQL e executa-o atraves do dataadapter
sql = "SELECT id,nome,telefone FROM amigos WHERE ID=" & id.Text
Dim da = New OleDbDataAdapter(sql, conn)
' dataset - conjunto de tabelas (datatables) mas em memória
Dim ds As New DataSet
' cria uma datatable (friends) dentro do dataset e preenche-a com o
resultado do da
da.Fill(ds, "friends")
' coloca nos textboxes cada campo, do row (registo) 0 (é o 1º) da
datatable friends
TextBox1.Text = ds.Tables("friends").Rows(0).Item("id")
TextBox2.Text = ds.Tables("friends").Rows(0).Item("nome")
TextBox3.Text = ds.Tables("friends").Rows(0).Item("telefone")
' fecha a ligação à DB
conn.Close()
' limpar o dataset
ds.Clear()
22 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Commands
Dando seguimento ao descrito no livro da FCA fornecido, o uso de commands (em vez de
DataSet) mostra-se mais simples em virtude de o conceito do DataSet, DataTable e demais
classes representar um maior esforço de aprendizagem (mas também uma maior flexibilidade).
Para a execução de um comando que não tem retorno de registos (INSERT, UPDATE e
DELETE), o código a usar é:
Dim conn As New OleDbConnection
conn.ConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data
Source=C:\amigos.mdb"
conn.Open()
Dim sql As String
sql = "INSERT ... ou UPDATE ... ou DELETE ..."
Dim cmd As New OleDbCommand(sql, conn)
cmd.ExecuteNonQuery()
conn.Close()
O método ExecuteNonQuery() executa a query, e tem como retorno não registos (dados)
mas o número de registos que foram “mexidos” pela queryl (número de apagados ou
actualizados p.ex.).
...
sql = "UPDATE amigos set nome='nome' WHERE telefone='123'"
Dim cmd As New OleDbCommand(sql, conn)
Dim n As Integer
n = cmd.ExecuteNonQuery()
MsgBox("Número de registos: " & n, MsgBoxStyle.Information)
conn.Close()
...
Assim, e supondo que o resultado da query seria 2 registos (havia dois registos com o telefone
123), o resultado seria:
23 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
No campo da leitura de dados de uma base de dados, há dois métodos.
O ExecuteScalar devolve o primeiro campo do primeiro registo – ou seja devolver apenas
um valor (o primeiro).
Útil quando apenas se procura uma coluna de um registo.
...
sql = "SELECT nome FROM amigos WHERE id=" & id.Text
Dim cmd As New OleDbCommand(sql, conn)
Dim str As String
str = cmd.ExecuteScalar
MsgBox("Primeiro campo: " & str, MsgBoxStyle.Information)
conn.Close()
...
Para a leitura de vários registos e colunas, o método a usar é o ExecuteReader. Neste caso,
é necessário percorrer todos os registos que fazem parte do retorno da query.
...
sql = "SELECT nome FROM amigos WHERE id >= " & id.Text
Dim cmd As New OleDbCommand(sql, conn)
Dim dr As OleDbDataReader
dr = cmd.ExecuteReader
While dr.Read()
MsgBox("Nome: " & dr.Item("nome"), MsgBoxStyle.Information)
End While
conn.Close()
...
Para ler os registos e adicionar a uma listbox.
...
sql = "SELECT id, nome FROM amigos" & id.Text
Dim cmd As New OleDbCommand(sql, conn)
Dim dr As OleDbDataReader
dr = cmd.ExecuteReader
While dr.Read()
ListBox1.Items.Add(dr.Item("nome"))
End While
conn.Close()
...
24 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Publicar uma aplicação
O VB.NET 2008 Express permite publicar uma aplicação, para que esta possa ser instalada. A
publicação pode ser para um servidor Web (para ser instalada online via browser) ou para o
disco para ser instalada offline, p.ex. a partir de um CD.
Inserir pastas e ficheiros
Antes de publicar, há que garantir que os ficheiros necessários à aplicação estejam dentro do
projecto.
Para criar pastas:
• Botão direito sobre o projecto, escolher Add – New Folder e depois definir o nome:
Para adicionar ficheiro:
• Arrastar e largar dentro do projecto:
25 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
•
Botão direito sobre o projecto, escolher Add – Existing Item… e depois seleccionar os
itens a adicionar:
Debug
Ao fazer debug da aplicação, ainda no VB.NET, é criado um ficheiro executável, dentro de
\Bin\Debug, dentro do projecto.
No entanto, nem todas as pastas e ficheiros são colocados na pasta Debug, pelo que alguma
funcionalidade que dependesse destes não correria normalmente.
Assim, é normal ter que recorre a directivas de compilação.
Estas directivas de compilação indicam que pode haver código que apenas compila p.ex. em
modo debug.
As directivas de compilação são identificados pelo # (cardinal) no If Then Else e pela
constante DEBUG (no exemplo – há mais)
Imports System.Data.OleDb
Public Class Form1
#If DEBUG Then
' é compilado se estiver em debug
Public dbConn As String = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data
Source=D:\cinema_v2.mdb"
Public pathImagens As String = "D:\imagens\"
#Else
' é compilado caso não esteja em debug
Public dbConn As String = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data
Source=" & Application.StartupPath & "\dados\cinema_v2.mdb"
Public pathImagens As String = Application.StartupPath &
"\imagens\"
#End If
...
26 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
No exemplo, em debug são usados caminhos absolutos para as pastas do projecto – deste
modo, apenas funcionam num máquina que tenha as mesmas pastas / ficheiros e na mesma
localização.
Caso não seja debug (p.ex. numa publicação) os caminhos são dependentes do local onde se
instalou a aplicação, sendo acedido através de Application.StartupPath – devolve a
pasta a partir da qual a aplicação iniciou (e foi instalada).
É necessário garantir que todos os ficheiros fiquem então na pasta onde foi instalada a
aplicação.
Fazer o publish
Antes de fazer o publish, são necessárias algumas configurações.
Indo ao menu Project - <nome_do_projecto> Properties… surge a janela.
As opções de menu Application e Publish são tipicamente as que carecem de alguma
atenção e configuração.
27 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
Em Application pode-se configurar:
• Assembly name: é o nome da aplicação, que surge no menu do Windows;
• Icon: é o ícone, que surge no menu do Windows;
• Startup form: o primeiro form a executar, caso a aplicação tenha mais do que um form;
• Assembly Information…: informação que surge quando se verifica as propriedades do
ficheiro;
• Splash screen: caso se pretenda ter uma janela de apresentação enquanto a aplicação
inicia.
Em Publish pode-se configurar:
• Publish Folder Location: destino onde vão ser criados os ficheiros de instalação;
• Application Files…: onde se define que ficheiros são incluídos na instalação e como;
• Prerequisites…: onde se define os componentes adicionais necessário a incluir e como;
• Publish Version: a numeração da versão, que pode ou não ser automática;
• Publish Now: botão para publicar – criar ficheiros de instalação.
28 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
No Application Files, surgem os ficheiros da aplicação, incluindo as pastas e ficheiros incluídos
no projecto.
Por omissão, o VB.NET detecta (automaticamente) que há uma base de dados – coluna
Publish Status, com o valor Data File (Auto).
Para garantir que todos os ficheiros ficam na mesma pasta (para serem depois acedidos pelo
mesmo método Application.StartupPath, deve-se alterar para Include (Auto).
29 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
No Prerequisites, surge a possibilidade de incluir, no mesmo processo de instalação, alguns
componentes, que podem ser necessário à execução da aplicação – p.ex. a .NET Framework.
É possível identificar se os componentes são instalados a partir da Web (tornando a instalação
mais pequena, mas requerendo acesso à Web), ou a partir da mesma pasta onde está a
aplicação a instalar (tornando o pacote de instalação mais pesado, mas podendo ser instalado
offline).
Instalação
Os ficheiros de instalação gerados, são entre outros, constituído por um ficheiro setup.exe (o
que deve ser executado), e uma pasta com as várias versões que vão sendo publicadas.
A versão a instalar é mais recente.
Após a instalação, a aplicação fica disponível.
30 / 31
Mini curso
Benjamim Cardoso
Visual Basic . NET
[email protected]
No disco, a aplicação fica instalada numa localização algo difícil de encontrar.
No Windows XP:
C:\Documents and Settings\Benjamim\Definições locais\Apps\2.0\5ZJGWB74.81G\
AJ7CX2N5.J24\pos-..tion_8ddb3fdb2c83981c_0001.0000_75271df155732cf3
No Windows 7:
C:\Users\Benjamim\AppData\Local\Apps\2.0\R5KRJ54T.R7E\
TXM136CC.KC4\pos-..tion_8ddb3fdb2c83981c_0001.0000_648a89bcda2adeb5
Para que a mesma aplicação funcione no Windows 7, esta deve ser compilada no Windows 7 –
o VB.NET 2008 Express funciona sem qualquer problema.
31 / 31