Elipse E3 Scripts

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 387

Manual de Referência e Scripts

do E3

Copyright © 1999 - 2022 Elipse Software Ltda. Todos os direitos reservados.


Versão 6.1.101 (08/12/2022)
Sumário
1 Introdução ................................................................................................................................................... 1
1.1 Objetos ................................................................................................................................................... 1
1.2 Scripts .................................................................................................................................................... 1
1.3 Picks ....................................................................................................................................................... 4
1.4 Eventos Definidos pelo Usuário ....................................................................................................... 10
2 Programando no E3 ................................................................................................................................. 14
2.1 Ambiente de Programação ............................................................................................................... 14
2.2 Declarando Variáveis ......................................................................................................................... 14
2.3 Obtendo Referências aos Objetos .................................................................................................... 15
2.4 Acessando Objetos ............................................................................................................................. 25
2.5 Trabalhando com Coleções ............................................................................................................... 25
2.6 Comando Set ....................................................................................................................................... 26
2.7 E3Globals ............................................................................................................................................. 26
2.8 Eventos, Métodos e Propriedades Gerais dos Objetos .................................................................. 34
3 Bibliotecas do Usuário ............................................................................................................................. 53
3.1 ElipseX ................................................................................................................................................. 53
4 Visualização .............................................................................................................................................. 58
4.1 Viewer .................................................................................................................................................. 58
4.2 Quadros e Divisores ........................................................................................................................... 82
4.3 Telas e Objetos de Tela ...................................................................................................................... 87
4.4 E3Alarm ............................................................................................................................................. 169
4.5 E3Browser ......................................................................................................................................... 190
4.6 E3Chart .............................................................................................................................................. 196
4.7 E3Playback ........................................................................................................................................ 226
4.8 Relatórios .......................................................................................................................................... 227
4.9 TrendAnalysis ................................................................................................................................... 251
5 Objetos de Servidor ............................................................................................................................... 255
5.1 Propriedades Comuns ..................................................................................................................... 255
5.2 Alarmes ............................................................................................................................................. 257
5.3 Banco de Dados ................................................................................................................................ 275
5.4 Coleção de Campos de Usuário de Alarmes ................................................................................. 278
5.5 Drivers ............................................................................................................................................... 280
5.6 Fórmulas ........................................................................................................................................... 332
5.7 Históricos .......................................................................................................................................... 334
5.8 Informações do Servidor ................................................................................................................. 341
5.9 Objetos em Tempo de Configuração ............................................................................................. 347
5.10 Objetos em Tempo de Execução do Servidor ............................................................................. 350
5.11 Servidor de Dados .......................................................................................................................... 353
5.12 Storage ............................................................................................................................................ 376
6 Dúvidas Mais Frequentes ...................................................................................................................... 383

I
CAPÍTULO
Introdução
1
Os Scripts são módulos de linguagem de programação nos quais se pode criar procedimentos associados a eventos
específicos, permitindo uma maior flexibilidade no desenvolvimento de aplicações. Cada objeto (item de um aplicativo)
do E3 possui uma lista de eventos previamente definidos, mas também é possível definir novos eventos próprios do
usuário.

1.1 Objetos
Os Objetos são componentes de software reutilizáveis que permitem maximizar o uso e aumentar a qualidade e
produtividade em seus aplicativos.
Um objeto no E3 encapsula ou contém três diferentes partes (propriedades, métodos e eventos) que podem ser
manipuladas para a utilização das vantagens de sua funcionalidade na aplicação.
Propriedades definem atributos de um objeto, como a aparência de um objeto de Tela ou o valor inicial de um objeto
quando o aplicativo é iniciado.
Métodos são funções que realizam uma ação específica dentro ou com um objeto.
Eventos são notificações geradas por um objeto em resposta a alguma ocorrência em particular, como um clique de
mouse ou uma mudança no valor de um Tag, entre outros.
Uma das principais características dos objetos e das linguagens orientadas a objeto é a capacidade de herança entre
eles, ou seja, estes podem herdar as características de um ou mais objetos, tendo as mesmas funcionalidades
específicas. Assim, pode se ter vários objetos trabalhando em conjunto para prover características de um outro objeto
derivado.
Tome como exemplo o objeto E3Chart. Ele é composto internamente de vários objetos, como títulos, legendas,
escalas, divisões, consultas e penas. Note que cada objeto contribui para a funcionalidade do todo: as escalas ajudam
a localizar os valores dos pontos no E3Chart, as legendas ajudam a identificar a pena e seus valores e a pena realiza
o desenho dos valores no E3Chart.
Através da manipulação de objetos dentro do E3Chart, pode-se criar duas instâncias deste objeto bastante diferentes
entre si. Para se manipular um objeto específico, deve-se acessá-lo através de uma hierarquia. Se os dois objetos
E3Chart estiverem na mesma Tela, deve-se acessar primeiro a Tela, depois o E3Chart desejado, depois uma de suas
propriedades ou objetos filhos. Quando há vários objetos de um mesmo tipo, geralmente eles podem ser acessados
através de uma coleção (collection). Uma coleção é um objeto especial que gerencia um conjunto de objetos
semelhantes. Um exemplo no objeto E3Chart é a coleção Pens, que permite o acesso a todas as penas do E3Chart.

1.2 Scripts
A linguagem que o E3 Studio usa em seus scripts é o VBScript, um subconjunto da linguagem Visual Basic
desenvolvida pela Microsoft. O VBScript possui um interpretador rápido, leve e portável, desenvolvido para uso em
navegadores para a Internet e outras aplicações que usam ActiveX Controls, Automation Servers e Java Applets.
Conforme visto anteriormente, os scripts são associados a eventos de um objeto. Entretanto, para facilitar e aumentar
a velocidade de desenvolvimento, o E3 já incorpora algumas ações mais comuns que poderiam ser realizadas com
scripts, através de assistentes chamados Picks. Pode-se portanto definir que um determinado evento executa um
script, um Pick ou uma combinação deles, em uma sequência também pré-definida.
Cada Editor do E3 Studio apresenta pelo menos duas abas na parte inferior, Design e Scripts, com exceção dos
objetos Banco de Dados e Servidor de Alarmes, que não possuem a aba Design. Os objetos e seus filhos podem ser
manipulados na aba Design. Para manipular seus scripts, utilize a aba Scripts. As opções disponíveis na aba Scripts
estão descritas na tabela a seguir.
Opções disponíveis na aba Scripts
OPÇÃO DESCRIÇÃO
Seleciona o objeto cujo script é manipulado
Lista de Objetos
Seleciona o evento a ser aplicado ao objeto
Lista de Eventos
Script Adiciona um script associado ao evento

Pick Abrir Tela Adiciona um Pick Abrir Tela

1 Introdução
OPÇÃO DESCRIÇÃO
Pick Abrir Tela Modal Adiciona um Pick Abrir Tela Modal

Pick Executar Aplicação Adiciona um Pick Executar Aplicação

Pick Carregar Valor Adiciona um Pick Carregar Valor

Pick Inverter Valor Adiciona um Pick Inverter Valor

Pick Imprimir Relatório Adiciona um Pick Imprimir Relatório

Remover script ou Pick selecionado Remove o script ou o Pick selecionado na


Lista de Ações

Mover script ou Pick selecionado para cima Move a ação selecionada para cima na
ordem da Lista de Ações para o evento

Mover script ou Pick selecionado para baixo Move a ação selecionada para baixo na
ordem da Lista de Ações para o evento

AppBrowser Abre a janela do AppBrowser

Procurar Busca por ocorrências de um determinado


texto

Procurar anterior Seleciona na lista de resultados a ocorrência


anterior

Procurar próxima Seleciona na lista de resultados a ocorrência


seguinte

Substituir Substitui as ocorrências encontradas por


outro texto especificado

Compila o script selecionado Compila o script selecionado, mostrando os


erros no painel Mensagens

Compila todos os scripts deste evento Compila todos os scripts associados ao


evento

Compila todos os eventos deste objeto Compila todos os eventos associados ao


objeto

A ordem de execução das ações é de cima para baixo. Para alterar a ordem, pode-se utilizar as opções Mover script
ou Pick selecionado para cima e Mover script ou Pick selecionado para baixo . Utilize a opção Compila o
script selecionado para verificar se não há erros no script especificado para o evento. As mensagens de erro do
compilador são apresentadas no painel Mensagens, que pode estar em uma janela flutuante ou ancorado na parte
inferior ou superior da aba Scripts. Clique duas vezes no erro para selecioná-lo no script.

Introdução 2
Mensagem do compilador

1.2.1 Adicionando um Script


Para adicionar um script a um objeto, siga estes procedimentos:
1. Selecione o objeto para criar o script e clique na aba Scripts.

Aba Scripts
2. Clique em Script . O Editor de Scripts é aberto, conforme a figura a seguir.

Adicionando um script ao objeto


3. Digite os comandos em VBScript na caixa de edição de texto.

3 Introdução
NOTA
Utilize o caractere de sublinhado para acrescentar uma quebra de linha e deixar o código mais legível. O caractere
de sublinhado indica que o código continua na linha subsequente.

Por exemplo:
If intTemperaturaCaldeira3 > 120 and _
intTemperaturaCaldeira4 > 120 Then
bEnviarAlarme = True
bAlarmeLigado = True
End If

Cada evento pode ter vários scripts e vários Picks associados, chamados Ações do Evento. A lista das ações pode ser
vista na parte superior da janela de edição de scripts. Cada objeto pode ter qualquer quantidade de eventos com
scripts ou Picks associados.

NOTA
Ao clicar com o botão direito do mouse em qualquer uma das ações descritas anteriormente, abre-se um menu
contextual que possibilita recortar, copiar ou colar scripts e Picks entre eventos.

1.3 Picks
Os Picks implementam uma forma mais amigável de realizar procedimentos mais comuns, poupando tempo de
configuração. Entre estes procedimentos estão ações como trocas de Tela ou atribuição de valores, bastante comuns
na criação de um projeto. Os tópicos a seguir descrevem os Picks disponíveis na aba Scripts.

NOTA
Todas as opções dos Picks que estão disponíveis via menu contextual (através do clique com o botão direito do
mouse) também estão disponíveis utilizando o atalho de teclado SHIFT + F10, que corresponde à tecla de aplicação
ou de menu .

Introdução 4
1.3.1 Abrir Tela
Abre uma determinada Tela ou Quadro.

Configurações do Pick Abrir Tela


Opções disponíveis no Pick Abrir Tela
OPÇÃO DESCRIÇÃO
Abrir a tela Indica qual Tela deve ser aberta

No quadro Indica o Quadro onde a Tela é visualizada. Se estiver em


branco, é o Quadro principal (_top)

Zoom inicial Define o zoom da Tela, quando mostrada

Alinhamento da Tela Define o alinhamento da Tela em relação à área visível.


Os valores possíveis são Utilizar padrão, Forçar
Esquerdo Superior ou Forçar Centralizado

Parâmetro Indica um parâmetro a ser passado na chamada da Tela

Habilitar scroll da tela Habilita o uso das barras de rolagem na Tela

Especificar posição da tela Indica a posição da Tela, em pixels

Especificar tamanho da tela Indica o tamanho da Tela, em pixels ou em Himetric

Estilo da janela Abre a caixa de diálogo Estilo de janela

1.3.1.1 Caixa de Diálogo Estilo de Janela


Permite configurar o estilo da janela a ser mostrada, definindo título e a disponibilidade das bordas e botões de
fechar, maximizar e minimizar, entre outras opções. Se a opção Usar configuração padrão das janelas está

5 Introdução
selecionada, a aplicação desabilita as opções desta janela e assume a configuração padrão do Viewer, conforme as
opções configuradas na aba Visualizador das propriedades do Viewer.

Caixa de diálogo Estilo da janela

1.3.2 Abrir Tela Modal


Abre uma Tela Modal, isto é, uma Tela que não permite a interação do usuário com outras Telas enquanto esta estiver
ativa.

Introdução 6
Configurações do Pick Abrir Tela Modal
Opções disponíveis no Pick Abrir Tela Modal
OPÇÃO DESCRIÇÃO
Abrir a tela Seleciona a Tela a ser aberta

Título Define o título da janela. Este texto é concatenado com o


nome da Tela

Zoom inicial Define o zoom da Tela, quando mostrada

Alinhamento da Tela Define o alinhamento da Tela em relação à área visível.


Os valores possíveis são Utilizar padrão, Forçar
Esquerdo Superior ou Forçar Centralizado

Parâmetro Indica um parâmetro a ser passado na chamada da Tela

Habilitar scroll da tela Habilita o uso das barras de rolagem na Tela

Especificar a posição da tela Determina a posição, em pixels, do quadro na Tela, a


partir do canto superior esquerdo da Tela

Especificar o tamanho da tela Determina a largura e a altura, em pixels ou em Himetric,


da Tela

Estilo da janela Abre a caixa de diálogo Estilo de Janela

7 Introdução
1.3.3 Executar Aplicação
Executa uma aplicação específica.

Configurações do Pick Executar Aplicação


Opções disponíveis no Pick Executar Aplicação
OPÇÃO DESCRIÇÃO
Aplicação Clicando-se em pode-se navegar no disco para indicar
o arquivo da aplicação a ser executada

Argumentos Permite especificar argumentos para a chamada da


aplicação

Executar no diretório Determina o diretório de trabalho da aplicação que é


executada

Modo de exibição Determina o tipo de janela de execução da aplicação. Os


valores possíveis são Normal, Maximizado ou
Minimizado

1.3.4 Carregar Valor


Carrega um valor em um Tag.

Configurações do Pick Carregar Valor

Introdução 8
Opções disponíveis no Pick Carregar Valor
OPÇÃO DESCRIÇÃO
Nome do tag Especifica o nome do Tag no qual é carregado o valor.
Pode-se selecionar o Tag no AppBrowser clicando em

Valor Determina o valor que é carregado no Tag. Pode-se


selecionar o tipo de dados clicando na caixa de seleção

1.3.5 Inverter Valor


Permite inverter o valor de um Tag. Se o valor do Tag é igual a Valor1, então o Tag recebe Valor2. Se o valor do Tag
é igual a Valor2, então o Tag recebe Valor1. Se o valor do Tag não é igual a Valor1 nem Valor2, o Tag recebe
Valor1.
É possível colocar tantos Picks Inverter Valor quantos se desejar. Isto permite a verificação de múltiplos valores para
um mesmo Tag ou até mesmo para diversos Tags em um mesmo evento.

Configurações do Pick Inverter Valor


Opções disponíveis no Pick Inverter Valor
OPÇÃO DESCRIÇÃO
Nome do tag Clique em para abrir o AppBrowser e selecionar um
Tag

Valor 1 Determina o primeiro valor a comparar. Se o valor do Tag


é igual a Valor1, então o Tag recebe Valor2

Valor 2 Determina o segundo valor a comparar. Se o valor do Tag


é igual a Valor2, então o Tag recebe Valor1

9 Introdução
1.3.6 Imprimir Relatório
Permite imprimir um Relatório em uma impressora ou mostrar em tela.

Configurações do Pick Imprimir Relatório


Opções disponíveis no Pick Imprimir Relatório
OPÇÃO DESCRIÇÃO
Imprimir relatório Permite selecionar um Relatório para impressão

Saída Determina o tipo de saída do Relatório. Os valores


possíveis são Impressora: Envia o Relatório para a
impressora, que corresponde ao método Print, ou Tela:
Executa uma prévia de impressão do Relatório na tela,
que corresponde ao método PrintPreview

Especificar a posição da tela Determina a posição da prévia de impressão, em pixels,


a partir do canto superior esquerdo da tela. Se estes
valores não são definidos, a prévia de impressão é
mostrada na posição (0, 0)

Especificar o tamanho da tela Especifica o tamanho da prévia de impressão na tela, em


pixels ou em Himetric. Se estes valores não são
definidos, a prévia de impressão é criada com o
tamanho de 500 por 500 pixels e a janela é aberta
maximizada. Se apenas uma das dimensões é definida,
largura ou altura, a outra dimensão é configurada para
500 pixels e a janela não é aberta maximizada

1.4 Eventos Definidos pelo Usuário


Apesar do E3 vir com uma extensa gama de eventos, muitas vezes o usuário pode querer criar um evento específico
para uma aplicação.
Um exemplo para a utilização de eventos definidos pelo usuário seria a realização de um cálculo ou tarefa mais
complexa em um objeto quando o evento gerador vem de um outro Tag ou propriedade.
Apesar de se poder criar e executar este mesmo tipo de tarefa a partir do próprio Tag ou da propriedade geradora
do evento, existem vantagens em manter-se um script junto ao objeto que sofre a ação. Dentre elas, pode-se citar o
trabalho adicional necessário para que um objeto aponte para outro, além de facilidades de manutenção, pois se por

Introdução 10
algum motivo é necessário modificar ou apagar o Tag ou a propriedade que seja o evento gerador, não é necessário
modificar um segundo objeto.
Outra vantagem é o fato de que se o Tag gerador do evento é apagado, o objeto não perde o script, só é necessário
indicar uma outra fonte geradora daquele evento.
A geração de eventos internos facilita ainda a criação de bibliotecas, pois cada vez que um componente de biblioteca
é inserido em uma aplicação, traz consigo os scripts e cálculos que podem ser necessários, diminuindo o trabalho de
configuração. Para gerar um novo evento interno em um objeto, siga estes procedimentos:
1. Clique em Criar novo evento na lista de eventos da aba Scripts para abrir a janela Novo Evento de Usuário,
mostrada na figura a seguir.

Janela Novo Evento de Usuário


2. Digite um nome para o evento e clique em OK para abrir o Editor do evento de usuário, conforme as figuras a
seguir, que descrevem as opções possíveis para a condição de ocorrência deste evento.

Opção Sempre que a expressão alterar seu valor

Opção Sempre que a expressão for verdadeira


3. As opções disponíveis neste Editor estão descritas na tabela a seguir.

11 Introdução
Opções disponíveis no Editor de eventos de usuário
OPÇÃO DESCRIÇÃO
Nome Nome que identifica este evento. Esta opção não é
editável, portanto clique em Renomear Evento de
Usuário para modificar o nome do evento

Renomear Evento de Usuário Abre uma janela para modificar o nome do evento

Expressão Expressão geradora deste evento. Clique em para


abrir o AppBrowser para selecionar um Tag ou
propriedade, por exemplo

Remover Evento de Usuário Remove este evento da Lista de Eventos. NOTA: Ao


remover um evento de usuário, todos os scripts
associados a este evento são perdidos

Condição da Ocorrência Especifica qual a condição para que este evento ocorra.
As opções possíveis são Sempre que a expressão for
verdadeira ou Sempre que a expressão alterar seu
valor. No primeiro caso o evento é do tipo etOnEvent (o
evento ocorre no momento em que a expressão é
verdadeira) ou do tipo etWhileEvent (o evento ocorre
ciclicamente, em intervalos pré-definidos). No segundo
caso o evento é do tipo etOnValueChanged (o evento
ocorre sempre que a expressão muda o valor)

Repetir o evento Quando disponível, indica que o evento é do tipo


etWhileEvent, ou seja, o evento se repete enquanto a
expressão é verdadeira. Esta opção só está disponível
quando a opção Condição de Ocorrência está
configurada como Sempre que a expressão for
verdadeira. O intervalo de repetição é configurado na
opção Período (ms)

Período (ms) Intervalo de repetição, em milissegundos, do evento. Esta


opção só está disponível quando a opção Condição de
Ocorrência está configurada como Sempre que a
expressão for verdadeira e a opção Repetir o evento
está selecionada

Tratar desconexão como mudança Indica que a conexão ou desconexão da expressão


geradora do evento deve ser tratada como mudança.
Esta opção só está disponível quando a opção Condição
de Ocorrência está configurada como Sempre que a
expressão alterar seu valor

4. Para alterar este evento usando a aba Scripts do objeto, selecione-o na lista de eventos. Um evento de usuário
também pode ser editado usando a opção Editar Associações do menu contextual de um objeto. Na janela Editar
Associações, clique na coluna Conexão correspondente a este evento e, no menu contextual, selecione a opção
Editar para abrir a janela da figura a seguir.

Introdução 12
Janela Editar Eventos

13 Introdução
CAPÍTULO
Programando no E3
2
Apesar de a maioria dos aspectos do VBScript se aplicarem à programação de scripts no E3, algumas
particularidades devem ser destacadas no que diz respeito às implementações do conceito de orientação a objetos.
O VBScript é uma linguagem baseada no Visual Basic que traz a capacidade de scripting (roteirização) para aplicações
que executam no sistema operacional Windows.
O VBScript troca informações com as aplicações utilizando a tecnologia ActiveX Scripting. Com o ActiveX Scripting,
navegadores e outras aplicações cliente, como o E3 Viewer, podem compilar scripts e chamar funções, dentre outros
procedimentos. Isto possibilita que scripts desenvolvidos para uma aplicação ou biblioteca, que devam ser executados
na interface gráfica, possam ser executados tanto no Viewer quanto em um navegador de Internet, sem a necessidade
de qualquer adaptação do aplicativo.
Mais informações sobre o VBScript podem ser obtidas no VBScript Language Reference Guide.

2.1 Ambiente de Programação


O ambiente de programação de scripts no E3 Studio pode ser acessado ao clicar com o botão direito do mouse em
qualquer objeto e selecionar a opção Propriedades. Na aba Scripts do Editor do objeto, pode-se definir qual evento
é o gerador do script. Como visto no capítulo anterior, os tipos de eventos em um objeto do E3 são os Pré-Definidos
e os Definidos pelo Usuário.
Os eventos pré-definidos variam de objeto para objeto, dependendo da utilização e funcionalidade. Um objeto de
Tela, por exemplo, possui eventos relacionados à interface gráfica, tais como Click (utilizado ao clicar em um objeto)
ou DblClick (utilizado com um duplo clique do mouse). Já um objeto como um Driver de Comunicação possui eventos
relacionados à comunicação, tal como OnCommError (utilizado quando há um erro de comunicação). Pode-se
também definir outros eventos para o objeto, como visto anteriormente.
Quando um script é associado a um evento em um objeto, o campo de digitação apresenta uma declaração de
procedimento (procedure), cuja definição é automática e composta do texto a seguir.
Sub NomeDoObjeto_NomeDoEvento()
End Sub

Nesta definição, NomeDoObjeto é o nome do objeto associado e NomeDoEvento é o nome do evento. Os comandos
do script devem estar entre estas duas linhas.
Para ajudar na digitação do script, pode-se utilizar o AppBrowser. Ao selecionar um método ou propriedade, pode-se
utilizar a opção Copiar. O Tag, propriedade ou método selecionado é inserido na posição do cursor na área de
edição do script. O local do cursor é mostrado através de uma animação com seta piscante.

2.2 Declarando Variáveis


É possível declarar variáveis implicitamente ou explicitamente.
Para declarar uma variável implicitamente, use o nome no script. Automaticamente, a variável é criada e inicializada
com o valor da atribuição ou permanece com o valor EMPTY, ou seja, vazia ou sem nenhum valor, caso não receba
nenhum valor antes de ser utilizada.
Esta é uma prática rápida, porém se o script é muito extenso, pode causar confusão e a criação de mais de uma
variável com o mesmo nome, gerando erros no script.
Para declarar variáveis explicitamente, utilize o comando Dim, como no exemplo a seguir.
Dim Temperatura

Pode-se declarar múltiplas variáveis separando cada nome de variável com uma vírgula, como no exemplo a seguir.
Dim Esquerda, Direita, Topo, Base

Em virtude de os scripts no E3 serem todos associados a um objeto em particular, as variáveis são sempre locais,
válidas apenas para o escopo do script. Para ter-se variáveis públicas ou globais, deve-se criar um Tag Interno e
utilizá-lo para armazenar o valor desejado.

Programando no E3 14
2.3 Obtendo Referências aos Objetos
Uma das características mais importantes ao se trabalhar com scripts dentro do E3 é considerar a separação existente
entre os processos que são executados no servidor e aqueles executados na interface do cliente (E3 Viewer). Para se
trabalhar com scripts, pode-se manipular:
· Objetos do servidor através do servidor
· Objetos do servidor através do E3 Viewer
· Objetos do Viewer através do mesmo E3 Viewer

No entanto, não se pode manipular diretamente:


· Objetos do Viewer através do servidor, pois isto só é possível através da criação de eventos no Viewer, ligados a
variáveis que estão no servidor
· Objetos de um Viewer a partir de outro Viewer, pois isto só é possível através da criação de eventos ligados a
variáveis que estão no servidor

Tais limitações são decorrentes do fato de que, por definição, existe uma independência entre o que cada uma das
estações E3 Viewer está executando ou visualizando e o servidor, e vice-versa. Por isto, todas as atividades, tanto do
servidor como do E3 Viewer, necessitam ser coordenadas de forma assíncrona ou através de eventos para operarem
de forma harmoniosa.
Logo, devido a esta independência ao se criar um script, primeiro deve-se obter uma referência correta dos objetos
que se deseja manipular, ou seja, é necessário que o objeto seja primeiramente encontrado nos vários módulos do
E3.
Vale repetir que, ao se editar um script, o usuário pode utilizar o AppBrowser, que permite copiar para o script o
caminho de um método ou propriedade de forma completa, auxiliando-o na criação de scripts.
Portanto, para acessar os objetos externos que estão sendo manipulados em um script, são utilizadas algumas
diretivas básicas. Por exemplo, para se manipular o valor de um Tag de Comunicação, o caminho é Servidor - Driver -
Pasta (se houver) - Tag. Já se o objetivo é manipular um botão em uma Tela, o caminho é Viewer - Quadro (se
houver) - Tela - Botão.
As localizações de origem de scripts, do ponto de vista da metodologia para acesso dos objetos, são as seguintes:
· Servidor
· Telas e Quadros (E3 Viewer)
· ElipseX (bibliotecas): podem ser XFolders, XObjects, que executam no servidor, ou XControls, que executam no E3
Viewer

2.3.1 Acessando Propriedades do Servidor


Para se acessar um objeto em execução no servidor a partir de um objeto de Tela ou um ElipseX, deve-se usar o
método Application.GetObject.
A palavra Application retorna o objeto de aplicação relacionado ao contexto atual do objeto, e o método GetObject
procura no servidor por um objeto dentro de Application com o nome fornecido, conforme o exemplo a seguir.
Sub Button1_Click()
Application.GetObject("Driver1")._
Item("tag001").AllowRead = False
End Sub

Ou ainda conforme o exemplo a seguir.


Sub Button1_Click()
Application.GetObject("Driver1.tag001").AllowRead = False
End Sub

O método Item foi utilizado para, a partir da referência de Driver1, localizar o tag001, pois um Driver é uma coleção
de Tags. Depois de localizado o objeto, as propriedades e métodos podem ser acessados livremente.
Caso alguma outra operação tivesse que ser realizada com Driver1 ou tag001, outra alternativa para o script anterior
seria a do exemplo a seguir.
Sub Retangulo1_Click()
Set obj = Application.GetObject("Driver1")
obj.Item("tag001").AllowRead = False
obj.Item("tag002").AllowRead = False
End Sub

15 Programando no E3
Neste caso, a variável obj está apontando para o objeto Driver1 e, na próxima vez que se quiser acessar algum
objeto que descende de Driver1 dentro do script, pode-se utilizar a variável obj diretamente. Isto traz um ganho de
performance, já que cada chamada do método GetObject executa um acesso ao servidor. Através desta técnica,
chamadas desnecessárias ao servidor são evitadas. Este exemplo usa o comando Set, que é explicado mais adiante.
Note que a utilização de variáveis também torna o código mais claro e de modificação mais fácil. Caso seja necessário
alterar o objeto para executar comandos, mude a linha de atribuição desta variável.
A palavra Application nos scripts pode indicar tanto funções que são executadas no E3 Viewer quanto no servidor.
Neste caso, o objeto Application sabe de antemão quais funções devem ser executadas tanto para um quanto para o
outro caso. Não é possível, entretanto, executar funções de E3 Viewer dentro do servidor, assim como também não é
possível executar funções de servidor dentro do E3 Viewer.

2.3.2 Acessando Propriedades do E3 Studio


Para acessar um objeto de servidor qualquer em um script que executa no E3 Studio, pode-se usar a diretiva
Application.GetObject. A palavra Application retorna o objeto de aplicação relacionado ao contexto atual do objeto,
e o método GetObject procura no Domínio carregado no E3 Studio por um objeto da aplicação ou do Domínio com
o caminho fornecido. No exemplo a seguir, o evento CustomConfig é disparado no E3 Studio.
Sub XControl1_CustomConfig
Application.GetObject("Dados.TagDemo1").DocString = "Documentação"
End Sub

2.3.3 Acessando Propriedades do Servidor de dentro do Servidor


Caso seja necessário acessar as propriedades de um Tag a partir de outro, origem e destino estão no servidor
ligados via um módulo pai, que é Driver1.
Nesta situação, deve ser usada a propriedade Parent. Isto permite que seja acessado primeiro o objeto pai onde está
o script, para depois descer-se na hierarquia em busca de outro elemento, conforme a figura e o exemplo a seguir.

Driver1 é o objeto pai de Tag1 e de


Tag2

Sub Tag1_OnRead()
Parent.Item("Tag2").AllowRead = False
End Sub

Estando-se dentro de um grupo, e desejando-se acessar o mesmo Tag2, pode-se aninhar vários comandos Parent,
conforme a figura e o exemplo a seguir.

Programando no E3 16
Pasta1 é o objeto pai de Tag1

Sub Tag1_OnRead()
Parent.Parent.Item("Tag2").AllowRead = False
End Sub

2.3.4 Acessando Objetos de uma Tela a partir de um Script na Tela


Deve-se usar somente o método Item, já que os objetos são filhos da Tela, conforme o exemplo a seguir.
Sub Tela1_OnPreShow(vArg)
Item("Retangulo1").Visible = True
End Sub

Retangulo1 é um item da TelaInicial

17 Programando no E3
2.3.5 Acessando Objetos de uma Tela a partir de um Script em outro
Objeto na Tela
Pode-se usar a propriedade Parent ou o método Screen, conforme a figura e o exemplo a seguir.

TelaInicial é o objeto pai de


Retangulo1 e Retangulo2

Sub Retangulo1_Click()
Parent.Item("Retangulo2").Visible = True
End Sub

2.3.6 Modificando a Tela ou Objetos de Tela a partir do Servidor


A modificação de um comportamento qualquer em uma Tela só pode ser executada a partir de Associações, em que
o servidor reporta automaticamente para os E3 Viewers todas as mudanças das variáveis selecionadas, ou através de
uma busca explícita do E3 Viewer por informações no servidor. Toda a operação de associação da interface gráfica é
realizada do cliente para o servidor, e não do servidor para o cliente. Assim, não é possível modificar Telas ou objetos
de Tela a partir do servidor via scripts, pois cada cliente de dados tem uma cópia diferente das Telas.
Um exemplo prático é mudar a cor de um Texto na Tela para verde quando um Tag é ligado, ou seja, o valor é
alterado para 1 (um), e para vermelho quando é desligado, ou seja, o valor é alterado para 0 (zero). Neste caso,
deve-se simplesmente criar uma Associação Digital entre a propriedade TextColor de Texto1 com Tag1. Associações
são preferíveis devido à rapidez de execução e simplicidade de manutenção e construção da aplicação.

Associando a cor do texto ao valor de Tag1


Uma outra forma de executar o procedimento anterior é criar um script no Viewer que verifique constantemente se
Tag1 mudou ou não de valor, para então mudar a cor do Texto. Este tipo de script é possível de ser realizado, mas
degrada muito a performance da aplicação. Por isto, esta prática não é aconselhável.

Programando no E3 18
2.3.7 Acessando Objetos de um ElipseX a partir do próprio ElipseX
Na criação de um ElipseX, pode-se declarar propriedades (XProperties) e inserir objetos, que podem ser objetos de
Tela (XControl) ou objetos do servidor (XFolder e XObject). Para se acessar as XProperties através de scripts, acesse o
nome da propriedade diretamente.

Aba Design

Aba Propriedades
Por exemplo, na figura anterior tem-se o objeto XControl1 com a propriedade Propriedade1, e os objetos Texto1 e
Retangulo1.
A propriedade Propriedade1, do tipo Booleano, pode ser acessada com o script a seguir.
Sub XControl1_OnStartRunning()
XControl1.Propriedade1 = True
End Sub

Ou ainda com o script a seguir.


Sub XControl1_OnStartRunning()
Propriedade1 = True
End Sub

Se o ElipseX possui objetos internos, então é possível utilizar o método Item para obter uma referência destes
objetos, como no script a seguir.
Sub XControl1_OnStartRunning()
Item("Texto1").Value = "motor"
Item("Retangulo1").ForegroundColor = RGB(212, 208, 20)
End Sub

19 Programando no E3
2.3.8 Acessando Objetos de um ElipseX Externamente
O acesso externo a um objeto ElipseX só pode ser realizado através de suas propriedades, utilizando suas instâncias
criadas. Não é possível acessar objetos internos diretamente.
Se o ElipseX em questão é um XControl, este se comporta como um objeto de Tela. Por exemplo, considere a
aplicação da figura a seguir.

Exemplo de XControl
Para alterar a propriedade Propriedade1 do XControl pode-se executar o script a seguir no evento Click de um Botão
de Comando.
Sub CommandButton1_Click()
Screen.Item("XControl11").Propriedade1 = True
End Sub

Ou ainda executar o script a seguir no evento Click de um Botão de Comando.


Sub CommandButton1_Click()
Parent.Item("XControl11").Propriedade1 = True
End Sub

No caso de um XFolder ou XObject, deve-se inseri-lo em um Servidor de Dados, conforme o exemplo da figura a
seguir.

Programando no E3 20
Exemplo de XObject
Para alterar a propriedade Valor do XObject, use o script a seguir.
Sub CommandButton1_Click()
Application.GetObject("Dados.XObject11").Valor = 123
End Sub

Ou ainda o script a seguir.


Sub CommandButton1_Click()
Application.GetObject("Dados").Item("XObject11").Valor = 123
End Sub

Pode-se ainda ter um XControl acessando um XFolder ou XObject, através de uma XProperty. Por exemplo, a figura a
seguir mostra um XControl chamado XControl1 que possui uma propriedade XValor do tipo XObject1, que é o
nome do XObject criado.

XObject

XControl

21 Programando no E3
Cria-se, por exemplo, uma Associação do valor do objeto Texto1 com a propriedade Valor do XObject1. Isso é
realizado através da propriedade XValor, criada no XControl1. Assim, o valor da propriedade Valor do XObject1 é
mostrada no objeto Texto1 do XControl1.

Propriedade Valor
No projeto, o vínculo da instância XObject11 à instância XControl11 pode ser realizado através de uma Associação
na propriedade XValor.

Associação na Propriedade XValor

2.3.8.1 Exemplo de Criação de um ElipseX


Suponha que determinada aplicação necessite supervisionar e comandar 10 motores. Cada motor precisa ser
representado por um desenho na Tela, que exibe a cor verde quando em operação e vermelho quando desligado.
Também deve ser permitido o comando do motor na Tela, enviando instruções para ligar e desligar, além de exibir a
velocidade.
Uma possibilidade é a criação de um XControl chamado MotorA com as propriedades Estado igual a Boolean e
Velocidade igual a Double, conforme a figura a seguir.

Programando no E3 22
Aba Design

Aba Propriedades
1. Para a indicação da cor, a propriedade OverrideFillColor do motor deve estar associada à propriedade Estado
do XControl, através de uma Associação Digital. Configure a propriedade OverrideFillMode para 2 - SolidFill.
2. Para exibir a velocidade, a propriedade Value do Display deve ser associada à propriedade Velocidade do
XControl.
3. O Botão Liga-Desliga troca o valor da propriedade Estado através de uma Associação Simples.

Note que:
· As Associações dentro da biblioteca são internas, e seu formato é Nome_do_Controle.Nome_da_Propriedade
· O objeto, depois de inserido na Tela, deve ter estas propriedades associadas aos Tags verdadeiros, para cada
um dos motores
· Uma Associação de um Tag para a propriedade Estado tem que ser realizada para cada objeto MotorA

23 Programando no E3
E3 Viewer
Outra possibilidade, mais abrangente, utiliza um XObject para o motor. Desta forma, todas as informações relativas
aos motores residem em objetos que estão no servidor. Assim, pode-se construir vários tipos de interface para o
motor (XControls) que trazem do servidor, através do XObject, somente as informações necessárias.
Desta maneira, o objeto MotorA teria que ser modificado para apontar para um XObject, ao invés de declarar em si
mesmo todas as propriedades.
1. Crie um XObject chamado MotorADados e declare neste objeto as propriedades Estado e Velocidade.
2. Crie um XControl MotorA que possua apenas uma propriedade, chamada MeusDados, do tipo MotorADados.
3. MotorADados deve ser inserido em uma Pasta de Dados no servidor e corresponde a cada um dos motores.
MotorA, por sua vez, aponta para o MotorADados desejado, não sendo necessária a criação de novos Tags.

Configuração no Editor do XObject

Configuração no Editor do XControl


4. A propriedade Estado, associada à propriedade OverrideFillColor do motor, seria MotorA.MeusDados.Estado.
5. A propriedade Velocidade, associada ao Display, seria MotorA.MeusDados.Velocidade.

Programando no E3 24
2.4 Acessando Objetos
Seguindo o conceito de encapsulamento de programação orientada a objetos, os métodos e propriedades são
associados aos objetos de origem. Isto significa que sempre se deve indicar o objeto do qual se está acessando o
método ou propriedade.

2.4.1 Propriedades
Para referenciar as propriedades de um objeto, deve-se usar o método GetObject. A sintaxe é a seguinte:
Application.GetObject("<objeto>").<propriedade>

Neste caso, <objeto> é o nome do objeto e <propriedade> é o nome da propriedade, conforme o exemplo a seguir.
Application.GetObject("Dados.TempTanque2").Type

Para facilitar a digitação, é aconselhável sempre utilizar o AppBrowser, que já traz a sintaxe correta.

2.4.1.1 Propriedade Value


No E3, muitos objetos possuem uma propriedade em comum chamada Value. Neste caso específico, pode-se acessar
esta propriedade utilizando se o próprio nome do objeto, conforme o exemplo a seguir.
Button1 = False

Que é equivalente ao exemplo a seguir.


Button1.Value = False

2.4.2 Métodos
A sintaxe a seguir exemplifica a chamada de um método que não precisa de parâmetros.
Application.GetObject("<objeto>").<metodo>

Neste caso, <objeto> é o nome do objeto e <metodo> é o nome do método.


Se o método aceita parâmetros, use a sintaxe a seguir.
Application.GetObject("<objeto>").<metodo>(<parametro>)

Neste caso, <parametro> é o parâmetro a ser passado para o método. Quando houver mais de um parâmetro, utilize
vírgulas para separá-los.
Se o método retorna um resultado, e for desejável guardá-lo, então os parâmetros devem ser colocados
obrigatoriamente entre parênteses, conforme o exemplo a seguir.
<V> =Application.GetObject("<objeto>").<metodo>(<parametro>)

Neste caso, <V> é a variável que recebe o resultado do método.

2.5 Trabalhando com Coleções


Uma Coleção, ou Collection, é um objeto que gerencia um conjunto de objetos similares. Os objetos contidos em uma
coleção são referenciados por índices, semelhante à referência de arrays. Pode-se adicionar ou remover objetos
individuais de uma coleção, conforme o exemplo a seguir.
Sub CommandButton1_Click()
' Adiciona uma Pena no objeto E3Chart1
Screen.Item("E3Chart1").Pens.AddPen "Pena"
End Sub

Sub CommandButton2_Click()
' Remove a primeira Pena
Screen.Item("E3Chart1").Pens.Remove 0
End Sub

NOTA
O primeiro objeto em uma coleção possui o índice 1 (um).

Todas as coleções possuem uma propriedade em comum chamada Count, que é o número de objetos ou filhos
existentes, conforme o exemplo a seguir.

25 Programando no E3
Sub CommandButton1_Click()
' Mostra uma caixa de diálogo com o número de Penas
MsgBox Screen.Item("E3Chart1").Pens.Count
End Sub

2.5.1 Acessando Objetos com o Método Item


Toda coleção possui um método Item, que pode ser usado para acessar qualquer objeto dentro da coleção. Este
método aceita um parâmetro Item, que pode ser um número inteiro positivo ou o nome do objeto dentro da coleção.
O exemplo a seguir é um ajuste da cor da segunda Pena de um objeto E3Chart.
Sub CommandButton1_Click()
' Modifica a cor da segunda pena
Screen.Item("E3Chart1").Pens.Item(2).Color = RGB(212, 208, 20)
End Sub

O mesmo ajuste pode ser obtido com o exemplo a seguir.


Sub CommandButton1_Click()
' Modifica a cor da pena com nome "Pena2"
Screen.Item("E3Chart1").Pens.Item("Pena2").Color = RGB(212, 208, 20)
End Sub

Os comandos anteriores são equivalentes, o primeiro indicando o índice da Pena na coleção e o segundo indicando o
nome da Pena.

2.6 Comando Set


O VBScript implementa o conceito de polimorfismo das linguagens orientadas a objeto, permitindo que uma variável
do tipo Variant assuma a forma de um objeto qualquer através do comando Set. Deste modo, a variável funciona
como um ponteiro para o objeto desejado, permitindo acessar seus métodos e propriedades, conforme o exemplo a
seguir.
Sub CommandButton1_Click()
Set E3Chart = Screen.Item("E3Chart1")
E3Chart.Pens.Item(2).Color = RGB(212, 208, 20)
End Sub

Neste exemplo foi executada a mesma tarefa da seção anterior, porém a parte referente a como chegar até o objeto
específico havia sido omitida. Sem o comando Set, a mesma chamada teria que ser escrita conforme o exemplo a
seguir.
Screen.Item("E3Chart1").Pens.Item(2).Color = RGB(212, 208, 20)

Aparentemente não existe vantagem neste caso, pois pode-se realizar todo o procedimento em uma única linha de
código. Porém, se logo adiante no mesmo script outras operações forem necessárias, o processo se torna mais
simples e rápido se a chamada ao método Item não tiver sido colocada em todas as linhas.
Sub CommandButton1_Click()
'Exemplo ruim
Screen.Item("E3Chart1").Pens.Item(0).Color = RGB(212, 208, 20)
Screen.Item("E3Chart1").Pens.Item(1).Color = RGB(200, 208, 20)
Screen.Item("E3Chart1").Pens.Item(2).Color = RGB(100, 208, 20)
End Sub

Sub CommandButton2_Click()
'Exemplo melhor
Set Penas = Screen.Item("E3Chart1").Pens
Penas.Item(0).Color = RGB(212, 208, 20)
Penas.Item(1).Color = RGB(200, 208, 20)
Penas.Item(2).Color = RGB(100, 208, 20)
End Sub

2.7 E3Globals
O E3Globals é um módulo do E3 que contém métodos de uso global. Os métodos GetCurrentWindowsUserName,
GetLocalTime e GetLocalTimeUTC não podem ser utilizados em Associações, somente em scripts. O restante dos
métodos pode ser utilizado tanto em scripts quanto em Associações.
A forma de utilização destes métodos admite as sintaxes E3Globals.<método> ou simplesmente <método>, exceto
no caso do objeto Relatório, onde a sintaxe E3Globals.<método> é obrigatória.

Programando no E3 26
2.7.1 Métodos
Esta seção contém informações sobre os métodos do módulo E3Globals.

2.7.1.1 BShl
BShl(Value, Bits)
Retorna o valor passado no parâmetro Value deslocado à esquerda o número de bits especificado no parâmetro Bits.
Este método retorna um erro caso o parâmetro Bits esteja fora da faixa permitida (entre zero e 31). Este método está
disponível tanto em Associações quanto em scripts.

NOTA
Este método permite passar um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, no parâmetro
Value, mas seu valor de retorno é sempre um valor de 32 bits com sinal, no intervalo entre -2.147.483.648 e
2.147.483.647. Caso seja utilizado um valor de ponto flutuante, somente a parte inteira deste valor é utilizada.

2.7.1.2 BShr
BShr(Value, Bits, [PreserveSign])
Retorna o valor passado no parâmetro Value deslocado à direita o número de bits especificado no parâmetro Bits.
Este método retorna um erro caso o parâmetro Bits esteja fora da faixa permitida (entre zero e 31). O parâmetro
PreserveSign é um Booleano que permite preencher ou não os bits à esquerda com uma cópia do bit de sinal. Se
omitido, preenche os bits à esquerda com zeros. Este método está disponível tanto em Associações quanto em
scripts.

NOTA
Este método permite passar um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, no parâmetro
Value, mas seu valor de retorno é sempre um valor de 32 bits com sinal, no intervalo entre -2.147.483.648 e
2.147.483.647. Caso seja utilizado um valor de ponto flutuante, somente a parte inteira deste valor é utilizada.

2.7.1.3 Choose
Choose(Index, Values)
Retorna um dos itens especificados em Values, baseado no parâmetro Index, iniciando em 0 (zero). Este método
retorna Null caso o valor de Index seja menor que 0 (zero) ou maior ou igual ao número de valores em Values. Este
método está disponível tanto em Associações quanto em scripts.

NOTA
O método Choose não propaga a qualidade nem a estampa de tempo dos valores. Se uma Associação contém a
expressão Choose(TagIndex, Tag1.Value, Tag2.Value, Tag3.Value), o resultado é o valor selecionado, porém com
qualidade Boa (192) e estampa de tempo atual. Para que estas informações sejam preservadas, é necessário
especificar somente o objeto, como por exemplo Choose(TagIndex, Tag1, Tag2, Tag3).

2.7.1.4 DwordToLong
DwordToLong(Value)
Converte um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, passado no parâmetro Value para um
valor de 32 bits com sinal, no intervalo entre -2.147.483.648 e 2.147.483.647, no mesmo padrão de bits. Se o valor
estiver no intervalo entre zero e 2.147.483.647, o valor é retornado sem mudanças.

NOTA
Caso o valor passado no parâmetro Value seja um valor de ponto flutuante, somente a parte inteira deste valor é
utilizada.

27 Programando no E3
2.7.1.5 E3Format
E3Format(Value, [Format])
Formata a expressão em Value utilizando o formato especificado em Format. Este formato utiliza as mesmas definições
da propriedade Format de objetos Texto, Display e SetPoint. Se omitido, mostra a expressão em Value formatada
conforme as configurações de região e idioma do Windows. Este método está disponível tanto em Associações
quanto em scripts.

2.7.1.6 E3ProductString
E3ProductString()
Este método retorna uma String contendo o nome e a versão do componente onde é invocado, como por exemplo
"E3 6.1.101" ou "E3 (64-bits) 6.1.101".

2.7.1.7 E3ProductVersionBuild
E3ProductVersionBuild()
Este método retorna o número de build da versão do componente onde é invocado. Por exemplo, se a versão do
componente é a 6.1.101, este método retorna o valor 101.

2.7.1.8 E3ProductVersionMajor
E3ProductVersionMajor()
Este método retorna o número principal da versão do componente onde é invocado. Por exemplo, se a versão do
componente é a 6.1.101, este método retorna o valor 6.

2.7.1.9 E3ProductVersionMinor
E3ProductVersionMinor()
Este método retorna o número secundário da versão do componente onde é invocado. Por exemplo, se a versão do
componente é a 6.1.101, este método retorna o valor 1.

2.7.1.10 GetBit
GetBit(Value, BitIndex)
Retorna o valor (verdadeiro ou falso) do bit de Value especificado em BitIndex. Este método retorna um erro caso o
parâmetro BitIndex esteja fora da faixa permitida (entre zero e 31). Este método está disponível tanto em Associações
quanto em scripts.

NOTA
Este método permite passar um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, no parâmetro
Value. Caso seja utilizado um valor de ponto flutuante, somente a parte inteira deste valor é utilizada.

2.7.1.11 GetComputerName
GetComputerName()
Retorna uma String contendo o nome do computador atual. Este método está disponível tanto em Associações
quanto em scripts.

2.7.1.12 GetCurrentWindowsUserName
GetCurrentWindowsUserName()
Retorna uma String contendo o nome do usuário logado no processo corrente. Este método não está disponível em
Associações, somente em scripts.

2.7.1.13 GetLocalTime
GetLocalTime()
Retorna a data e hora do computador local, com precisão de milissegundos e no fuso horário local. Este método não
está disponível em Associações, somente em scripts.

Programando no E3 28
2.7.1.14 GetLocalTimeUTC
GetLocalTimeUTC()
Retorna a data e hora do computador local, com precisão de milissegundos e no fuso horário UTC (Tempo Universal
Coordenado). Este método não está disponível em Associações, somente em scripts.

2.7.1.15 IIf
IIf(Condition, ExprTrue, ExprFalse)
Retorna a expressão contida em ExprTrue se a condição avaliada em Condition é verdadeira, e a expressão contida em
ExprFalse se a condição avaliada é falsa. Este método está disponível tanto em Associações quanto em scripts.

NOTA
O método IIf não propaga a qualidade nem a estampa de tempo dos valores. Se uma Associação contém a
expressão IIf(Tag1.Value = 0, Tag2.Value, Tag3.Value), o resultado é o valor de Tag2 ou Tag3, porém com
qualidade Boa (192) e estampa de tempo atual. Para que estas informações sejam preservadas, é necessário
especificar somente o objeto, como por exemplo IIf(Tag1.Value = 0, Tag2, Tag3).

2.7.1.16 LongToDword
LongToDword(Value)
Converte um valor de 32 bits com sinal, no intervalo entre -2.147.483.648 e 2.147.483.647, passado no parâmetro Value
para um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, no mesmo padrão de bits. Se o valor
estiver entre zero e 2.147.483.647, o valor é retornado sem mudanças.

NOTA
Caso o valor passado no parâmetro Value seja um valor de ponto flutuante, somente a parte inteira deste valor é
utilizada.

2.7.1.17 MsgBoxEx
MsgBoxEx(prompt, [buttons], [title], [PosX], [PosY])
Este método permite mostrar uma caixa de diálogo padrão do Windows e especificar a posição na tela. Os
parâmetros disponíveis neste método são os seguintes:
· prompt: Texto a ser mostrado na caixa de diálogo. O tamanho máximo deste texto é de aproximadamente 1024
caracteres, dependendo da largura dos caracteres usados. Para inserir quebras de linha no texto, separe as linhas
usando a função Chr do VBScript com os valores 10 (avanço de linha), 13 (retorno de carro) ou uma combinação
destes valores entre cada linha
· buttons: Uma expressão numérica opcional que representa a soma dos valores especificando a quantidade e o
tipo dos botões mostrados, o estilo, o botão padrão e se a caixa de diálogo é modal ou não. O valor padrão
deste parâmetro é 0 (zero), ou seja, mostra apenas o botão OK. Consulte a tabela a seguir para mais informações
sobre este parâmetro
· title: Texto opcional mostrado na barra de título da caixa de diálogo. Se este parâmetro é omitido, a caixa de
diálogo não mostra nenhum título
· PosX: Indica a posição, em pixels, da caixa de diálogo em relação à margem esquerda da janela. Caso este
parâmetro seja omitido, a respectiva coordenada da caixa de diálogo é centralizada na janela
· PosY: Indica a posição, em pixels, da caixa de diálogo em relação à margem superior da janela. Caso este
parâmetro seja omitido, a respectiva coordenada da caixa de diálogo é centralizada na janela

NOTA
Caso os valores indicados nos parâmetros PosX e PosY posicionem a caixa de diálogo fora da área visível da janela,
estes valores são ajustados automaticamente para garantir que a caixa de diálogo esteja visível.

Os valores possíveis para o parâmetro buttons estão descritos na tabela a seguir.

29 Programando no E3
Valores possíveis para o parâmetro buttons
VALOR DESCRIÇÃO CONSTANTE NO VBSCRIPT
TIPO DE BOTÃO
0 Mostra apenas o botão OK vbOKOnly

1 Mostra os botões OK e Cancelar vbOKCancel


(Cancel)

2 Mostra os botões Abortar (Abort), vbAbortRetryIgnore


Repetir (Retry) e Ignorar (Ignore)

3 Mostra os botões Sim (Yes), Não vbYesNoCancel


(No) e Cancelar (Cancel)

4 Mostra os botões Sim (Yes) e Não vbYesNo


(No)

5 Mostra os botões Repetir (Retry) e vbRetryCancel


Cancelar (Cancel)
ESTILO DOS ÍCONES
16 Mostra um ícone indicando uma vbCritical
mensagem crítica

32 Mostra um ícone indicando uma vbQuestion


pergunta

48 Mostra um ícone indicando uma vbExclamation


afirmação

64 Mostra um ícone indicando uma vbInformation


informação
BOTÃO PADRÃO
0 Indica que o primeiro botão é o vbDefaultButton1
padrão de retorno

256 Indica que o segundo botão é o vbDefaultButton2


padrão de retorno

512 Indica que o terceiro botão é o vbDefaultButton3


padrão de retorno

768 Indica que o quarto botão é o vbDefaultButton4


padrão de retorno
TIPO DE JANELA MODAL
0 Indica que o usuário deve responder vbApplicationModal
esta caixa de diálogo antes de
continuar trabalhando na aplicação

4096 Indica que todas as aplicações estão vbSystemModal


suspensas até que o usuário
responda esta caixa de diálogo

Este método retorna um valor numérico que representa o botão clicado na caixa de diálogo, conforme a tabela a
seguir.
Valores de retorno do método MsgBoxEx
VALOR BOTÃO CONSTANTE NO VBSCRIPT
1 OK vbOK

2 Cancelar (Cancel) vbCancel

3 Abortar (Abort) vbAbort

4 Repetir (Retry) vbRetry

5 Ignorar (Ignore) vbIgnore

Programando no E3 30
VALOR BOTÃO CONSTANTE NO VBSCRIPT
6 Sim (Yes) vbYes

7 Não (No) vbNo

2.7.1.18 OPCGetLimit
OPCGetLimit(Quality)
Retorna a informação de Limite de uma Qualidade OPC especificada no parâmetro Quality. Este método está
disponível tanto em Associações quanto em scripts. Os valores possíveis de retorno deste método são os seguintes:
· 0: Livre
· 1: Baixo
· 2: Alto
· 3: Constante

2.7.1.19 OPCGetQuality
OPCGetQuality(Quality)
Retorna a informação de Qualidade de uma Qualidade OPC especificada no parâmetro Quality. Este método está
disponível tanto em Associações quanto em scripts. Os valores possíveis de retorno deste método são os seguintes:
· 0: Ruim
· 1: Incerta
· 2: Não utilizada
· 3: Boa

2.7.1.20 OPCGetSubStatus
OPCGetSubStatus(Quality)
Retorna a informação de Substatus (de 0 a 15) de uma Qualidade OPC especificada no parâmetro Quality. Este
método está disponível tanto em Associações quanto em scripts. O Padrão OPC especifica os seguintes valores:
· Qualidade Boa:
· 0: Não especificado
· 1: Sobrescrita local
· Qualidade Ruim:
· 0: Não especificado
· 1: Erro de configuração
· 2: Não conectado
· 3: Falha no dispositivo
· 4: Último valor conhecido
· 5: Falha de comunicação
· 6: Fora de serviço
· Qualidade Incerta:
· 0: Não especificado
· 1: Último valor utilizável
· 4: Sensor não confiável
· 5: Unidade de engenharia excedida
· 6: Subnormal

2.7.1.21 OPCGetVendor
OPCGetVendor(Quality)
Retorna a informação de Reservado para o Fabricante (de 0 a 255) de uma Qualidade OPC especificada em Quality.
Este método está disponível tanto em Associações quanto em scripts.

31 Programando no E3
2.7.1.22 OPCIsBad
OPCIsBad(Quality)
Retorna verdadeiro se a Qualidade OPC é Ruim, ou falso caso contrário. Este método está disponível tanto em
Associações quanto em scripts.

2.7.1.23 OPCIsGood
OPCIsGood(Quality)
Retorna verdadeiro se a Qualidade OPC é Boa, ou falso caso contrário. Este método está disponível tanto em
Associações quanto em scripts.

2.7.1.24 OPCIsUncertain
OPCIsUncertain(Quality)
Retorna verdadeiro se a Qualidade OPC é Incerta, ou falso caso contrário. Este método está disponível tanto em
Associações quanto em scripts.

2.7.1.25 OPCMakeQuality
OPCMakeQuality(QualityFlag, [SubStatus], [Limit], [Vendor])
Retorna um novo valor de Qualidade OPC utilizando os valores passados nos parâmetros QualityFlag, SubStatus, Limit
e Vendor. Este método está disponível tanto em Associações quanto em scripts. Os valores possíveis para cada um
dos parâmetros são os seguintes:
· QualityFlag: Especifica a qualidade do valor
· 0: Ruim
· 1: Incerta
· 3: Boa
· SubStatus: Especifica o substatus do valor (entre 0 e 15, veja o método OPCGetSubStatus para os valores
possíveis). Se este parâmetro é omitido, assume o valor 0 (zero)
· Limit: Especifica o limite do valor. Se este parâmetro é omitido, assume o valor 0 (zero)
· 0: Livre
· 1: Baixo
· 2: Alto
· 3: Constante
· Vendor: Valor específico do fabricante (entre 0 e 255). Se este parâmetro é omitido, assume o valor 0 (zero)

2.7.1.26 OPCSetLimit
OPCSetLimit(Quality, Limit)
Modifica a informação de Limite de uma Qualidade OPC e retorna o valor modificado. Este método está disponível
tanto em Associações quanto em scripts. Os valores possíveis para o parâmetro Limit são os seguintes:
· 0: Livre
· 1: Baixo
· 2: Alto
· 3: Constante

2.7.1.27 OPCSetQuality
OPCSetQuality(Quality, QualityFlag)
Modifica a informação de Qualidade de uma Qualidade OPC e retorna o valor modificado. Este método está
disponível tanto em Associações quanto em scripts. Os valores possíveis para o parâmetro QualityFlag são os
seguintes:
· 0: Ruim
· 1: Incerta
· 2: Não utilizada

Programando no E3 32
· 3: Boa

2.7.1.28 OPCSetSubStatus
OPCSetSubStatus(Quality, SubStatus)
Modifica a informação de Substatus de uma Qualidade OPC (de 0 a 15) e retorna o valor modificado. Este método
está disponível tanto em Associações quanto em scripts. O Padrão OPC especifica os seguintes valores:
· Qualidade Boa:
· 0: Não especificado
· 1: Sobrescrita local
· Qualidade Ruim:
· 0: Não especificado
· 1: Erro de configuração
· 2: Não conectado
· 3: Falha no dispositivo
· 4: Último valor conhecido
· 5: Falha de comunicação
· 6: Fora de serviço
· Qualidade Incerta:
· 0: Não especificado
· 1: Último valor utilizável
· 4: Sensor não confiável
· 5: Unidade de engenharia excedida
· 6: Subnormal

2.7.1.29 OPCSetVendor
OPCSetVendor(Quality, Vendor)
Modifica a informação de Reservado para o Fabricante (de 0 a 255) de uma Qualidade OPC e retorna o valor
modificado. Este método está disponível tanto em Associações quanto em scripts.

2.7.1.30 SetBit
SetBit(Value, BitIndex, BitValue)
Ajusta o valor de Value (verdadeiro ou falso) do bit especificado em BitIndex para BitValue. Este método retorna um
erro caso o parâmetro BitIndex esteja fora da faixa permitida (entre zero e 31). Este método está disponível tanto em
Associações quanto em scripts.

NOTA
Este método permite passar um valor de 32 bits sem sinal, no intervalo entre zero e 4.294.967.296, no parâmetro
Value, mas seu valor de retorno é sempre um valor de 32 bits com sinal, no intervalo entre -2.147.483.648 e
2.147.483.647. Caso seja utilizado um valor de ponto flutuante, somente a parte inteira deste valor é utilizada.

2.7.1.31 SourceTypeName
SourceTypeName(SourceType)
Retorna uma String com a descrição da Fonte de Medida ativa (propriedade ActiveSource dos objetos Medida
Analógica e Medida Discreta do E3). Este método está disponível tanto em Associações quanto em scripts. Os valores
possíveis para o parâmetro SourceType são os seguintes:
· -1: String vazia
· 0: Fonte Ativa
· 1: SCADA
· 2: Operador
· 3: Centro de Comando
· 4: Faturamento

33 Programando no E3
· 5: Calculada
· 6: Banco de Dados
· 100: Processador Topológico
· 101: Fluxo de Potência
· 102: Estimador de Estados
· 103: Descarte de Cargas
· 104: Modelagem de Cargas para Distribuição
· 105: Autorrecuperação
· 106: Leitor Externo

NOTA
Caso o valor passado no parâmetro SourceType não esteja entre os valores possíveis, este método retorna a String
"???".

2.8 Eventos, Métodos e Propriedades Gerais dos Objetos


Esta seção contém informações sobre os eventos, métodos e propriedades gerais dos objetos.

2.8.1 Eventos
Eventos são ocorrências relacionadas a um objeto que permitem disparar ações programadas. Existem, basicamente,
eventos Físicos ou Externos e Internos. Os Eventos Físicos são, por exemplo, ações do usuário. No caso do usuário
digitar algo no teclado, a informação relevante pode ser a tecla pressionada, ou se o usuário apontar e clicar com o
mouse, a informação relevante pode ser a posição do cursor e o status dos botões. Os Eventos Internos são, por
exemplo, mudanças de valor de uma variável ou Tag na aplicação. Como o Tag pode ser associado a um dispositivo
externo, diz-se que os eventos internos podem ter associações físicas, como a mudança da temperatura de uma
câmara, por exemplo.

2.8.1.1 Variáveis de Evento


Variáveis de Evento são criadas quando um evento inicia. Para serem utilizadas, devem ser associadas a parâmetros
na chamada do script do evento. O exemplo a seguir é a chamada de um procedimento associado ao evento
KeyDown de AlgumObjeto.
Sub AlgumObjeto_KeyDown(KeyCode, Shift)

Note que a chamada contém as variáveis KeyCode e Shift. O E3 atribui valores a estas variáveis automaticamente no
momento da ocorrência do evento. Neste caso, KeyCode recebe o código da tecla pressionada e Shift recebe
Verdadeiro ou Falso, conforme a tecla SHIFT esteja pressionada ou não.

2.8.1.2 OnStartRunning
OnStartRunning()
Ocorre tão logo um objeto seja iniciado. No exemplo a seguir, Meses é um Tag Interno e utiliza este evento para
inicializar o vetor.
Sub Meses_OnStartRunning()
Value = Array("Janeiro", "Fevereiro", "Março", "Abril",_
"Maio", "Junho", "Julho", "Agosto", "Setembro", "Outubro",_
"Novembro", "Dezembro")
End Sub

NOTA
Para acessar este array, é necessário copiar a propriedade Value para uma variável local.

2.8.1.3 OnStopRunning
OnStopRunning()
Ocorre quando termina a execução de uma instância de um objeto. Utilize este evento para realizar operações de
finalização para um objeto. Exemplo:
Sub TagInterno1_OnStopRunning()
' Quando finaliza o objeto TagInterno1

Programando no E3 34
' atribui False ao TagInterno2
Set tag2 = Application.GetObject("Dados.TagInterno2")
tag2.Value = False
End Sub

2.8.2 Métodos
Esta seção contém informações sobre os métodos comuns aos objetos do E3. Cada tópico mostra o nome do
método com os respectivos parâmetros, na sintaxe correta, e um exemplo de utilização.

2.8.2.1 Chamadas de Métodos


Muitos métodos pré-definidos possuem parâmetros, que podem ou devem ser passados na chamada do método.
Para isto, o VBScript possui uma regra que deve ser seguida. Se um método é utilizado em uma atribuição, os
parâmetros devem estar entre parênteses, como neste exemplo de chamada do método GetObject.
obj = Application.GetObject("dados.tag001")

Já se um método é chamado sozinho, deve-se retirar os parênteses, como neste exemplo de chamada do método
SetVariableValue.
Screen.Item("Consulta").SetVariableValue Valor, 12

Os parênteses usados nas citações de métodos neste documento servem apenas como indicativo para diferenciá-los
das propriedades. Nos scripts, deve-se seguir esta mesma regra.

2.8.2.2 Activate
Activate()
Ativa um objeto que está inativo no momento. Exemplo:
Sub CommandButton1_Click()
Dim obj, tag
Set obj = Application.GetObject("Dados")
' Cria um novo objeto e o desativa (False)
Set tag = obj.AddObject("DemoTag", False)
' Inicializa os parâmetros do novo objeto
tag.Name = "tag001"
tag.Type = 3
' Ativa o objeto (coloca em execução)
tag.Activate()
End Sub

NOTA
Ativar um objeto usando este método configura a propriedade IsObjectActive deste objeto para Verdadeiro.

2.8.2.3 AddObject
AddObject(ClassName, [Activate], [ObjectName])
Este método adiciona um novo objeto à aplicação. Este método possui o parâmetro ClassName, que indica o tipo de
objeto que é criado. Por exemplo, para se criar um retângulo na Tela, o parâmetro ClassName deve ser igual a
"DrawRect". O objeto criado está contido no objeto que chamou este método e pode ser acessado através do
método Item.
O parâmetro Activate é opcional e indica se o objeto é ativado após a criação. Se o objeto é ativado, as Associações e
scripts são habilitados. Se o objeto é criado com o parâmetro Activate em Falso, mais tarde pode ser ativado pelo
método Activate. Se este parâmetro é omitido, o objeto é ativado após a criação. O valor configurado neste
parâmetro é usado para configurar a propriedade IsObjectActive do objeto criado.
O parâmetro ObjectName também é opcional e indica um nome para o objeto criado. Caso o nome já exista, o novo
nome é automaticamente incrementado. Se este parâmetro é omitido, o novo objeto é nomeado a partir do nome da
classe definida no parâmetro ClassName. Consulte a propriedade geral Name para mais informações sobre os
caracteres permitidos nos nomes de objetos.
O objeto só é criado se é de um tipo compatível com o objeto que o contém. Para se ter certeza que o objeto foi
criado, pode-se utilizar o método IsObject do VBScript.

35 Programando no E3
NOTA
Apenas objetos que possuem a opção Inserir no seu menu contextual podem acessar este método.

2.8.2.4 Context
Context(ContextName)
Retorna o objeto que implementa o contexto indicado pelo parâmetro ContextName, que deve ser uma String entre
aspas duplas. Este método falha se nenhum objeto na hierarquia superior do objeto que está chamando este método
implementar o contexto indicado. Os seguintes contextos estão disponíveis:
· Container: Objetos de servidor e do Viewer, ou seja, objetos inseridos em arquivos de projeto ou em pastas
dentro de projetos
· Area: Áreas de Alarme, ou qualquer objeto de servidor cuja propriedade IsAlarmArea esteja configurada para
Verdadeiro

NOTA
Os nomes dos contextos estão sempre em inglês, e não diferenciam maiúsculas de minúsculas. Para verificar o
contexto a que um objeto pertence, abra sua Janela de Propriedades, selecione a aba Item e verifique os contextos
válidos no quadro Contextos. Caso um objeto defina mais de um contexto, os nomes são apresentados em ordem
alfabética, separados por vírgulas.

2.8.2.5 Deactivate
Deactivate()
Este método desativa um objeto criado ou previamente ativado pelo método Activate. Pode-se desativar um objeto
quando é necessário realizar uma configuração prévia, como por exemplo na inicialização de propriedades, ou
quando é necessário realizar testes nos quais o objeto não pode estar presente e ativo. Exemplo:
Sub CommandButton1_Click()
Dim obj, novo
Set obj = Application.GetObject("Dados")
Set novo = obj.AddObject("DemoTag", True)
' Desativa o objeto
novo.Deactivate()
End Sub

NOTA
Desativar um objeto usando este método configura a propriedade IsObjectActive deste objeto para Falso.

2.8.2.6 DeleteObject
DeleteObject(ChildName)
Apaga do projeto o objeto especificado. O parâmetro ChildName é uma String (ignora maiúsculas e minúsculas) que
indica o objeto filho que se deseja apagar. O método retorna Verdadeiro caso a operação de apagar o objeto tenha
sido bem-sucedida, ou Falso caso o objeto filho não exista.
Para se apagar um objeto a partir de uma referência a um elemento, utilize este método no objeto pai. Exemplo:
Sub CommandButton1_Click()
Set obj = Application.GetObject("Dados")
If obj.DeleteObject("Tag001") Then
MsgBox("Tag apagado com sucesso!")
Else
MsgBox("Falha ao apagar: o Tag não existe.")
End If
End Sub

NOTA
Apenas objetos que possuem a opção Inserir no seu menu contextual podem acessar este método.

Programando no E3 36
2.8.2.7 GetChildObject
GetChildObject(ObjectPath)
Este método retorna uma referência para o objeto filho apontado pelo parâmetro ObjectPath. Com isto é possível
acessar todas as propriedades e métodos deste objeto, semelhante ao funcionamento do método GetObject. Este
método falha se o caminho apontado por ObjectPath contiver uma propriedade ou método ao final. O caminho
apontado pelo objeto filho não é um caminho desde a raiz (o arquivo .prj) e sim um caminho sempre a partir do
objeto onde o método é chamado.

NOTA
Este método NÃO existe no objeto Application do Servidor e nem nas Pastas de Aplicativo, porém existe no objeto
Application do Viewer e é acessível mesmo em um E3 Viewer em modo Somente Leitura.

2.8.2.8 GetObject
GetObject(ObjectPath)
Este método retorna a referência do objeto especificado em ObjectPath. Isto permite acessar todas as propriedades
ou métodos do objeto. Esta é uma prática bastante comum na programação de scripts no E3, facilita a manipulação
de objetos e deixa o código mais inteligível. Exemplo:
Sub CommandButton1_Click()
' Atribui o valor 20 à propriedade Value do objeto
' TagInterno1 que está em Dados.
Set tag = Application.GetObject("Dados.TagInterno1")
tag.Value = 20
End Sub

2.8.2.9 Item
Item(ItemId)
Retorna a referência para o objeto filho ItemId do objeto que chamou este método. Este método pode buscar um
objeto tanto pelo nome quanto pelo índice, um inteiro entre 1 (um) e o valor especificado na propriedade Count. Se o
índice ou o nome especificado é válido, este método retorna a referência ao objeto. Caso contrário, o método retorna
um erro de "Parâmetro Inválido". Exemplo:
Sub Tela1_Click()
' Atribui a obj a referência para o objeto filho Botao1
' de Tela1.
Set obj = Item("Botao1")
' Configura a propriedade BackColor de obj, ou seja,
' de Botao1.
obj.BackColor = RGB(255, 0, 0)
End Sub

2.8.2.10 RunEvent
RunEvent(EventName, [Arguments])
Executa o script ou scripts associados ao evento indicado pelo parâmetro EventName, que deve ser uma String. O
parâmetro Arguments é opcional e deve ser usado nos casos em que o evento necessite de argumentos. Estes
argumentos devem estar separados por vírgulas. Este método falha caso o evento indicado não tenha nenhum script
a ser executado.

2.8.2.11 RunProcedure
RunProcedure(ProcedureName, [Arguments])
Executa o script ou scripts associados ao procedimento (procedure) ou função (function) indicado pelo parâmetro
ProcedureName, que deve ser uma String. O parâmetro Arguments é opcional e deve ser usado nos casos em que o
procedimento ou função necessitem de argumentos. Estes argumentos devem estar separados por vírgulas. Este
método falha caso o procedimento ou função indicados não tenham nenhum script a ser executado. Este método
retorna um valor nos casos em que a função indicada pelo parâmetro ProcedureName também retorne um valor.

37 Programando no E3
2.8.2.12 Save
Save()
Este método salva o objeto especificado, que foi modificado em tempo de execução (runtime). Os objetos filhos
também são salvos, conforme as especificações do objeto pai. Este método não é válido para os objetos Tela e
Viewer. Exemplo:
Sub CommandButton1_Click()
Set area = Application.GetObject("ConfigAlarms")._
AddObject("Area", True)
Application.GetObject("ConfigAlarms").Save()
End Sub

NOTA
As modificações executadas em tempo de execução e salvas no objeto só são visíveis no E3 Studio após a
atualização do projeto. Para isto, clique com o botão direito do mouse no nome do projeto e selecione a opção
Atualizar.

2.8.3 Propriedades
Todo objeto possui Propriedades, que servem para guardar informações a respeito das características daquele
objeto. Por exemplo, um objeto do tipo Retângulo possui a propriedade Name, que contém o nome, e as
propriedades Width e Height, que guardam a largura e altura, respectivamente, entre outras propriedades.
Neste capítulo são listadas todas as propriedades gerais dos objetos do E3. Cada tópico traz o nome da
propriedade, a descrição e, quando aplicável, um exemplo de uso. As propriedades são identificadas por um ícone
que indica o tipo de dados suportado no conteúdo. Os tipos de dados disponíveis estão descritos na tabela a seguir.
Tipos de dados disponíveis
TIPO DE DADOS DESCRIÇÃO
Booleano Representa os valores Verdadeiro (True) ou Falso (False)

Coleção Representa uma coleção de objetos

Item de Coleção Representa um item de uma coleção de objetos

Cor Representa uma cor no formato RGB

Data e Hora Representa uma data no calendário Gregoriano,


iniciando em 1899

Enumeração Representa um conjunto determinado de valores

Fonte Representa uma fonte a ser aplicada a um texto

GUID Representa um valor GUID (Globally Unique Identifier ou


Identificador Único Global)

Propriedade Indexada Representa uma propriedade cujos valores podem ser


acessados através de um índice

Link Representa uma associação entre objetos

Número Representa um valor inteiro ou Double, positivo ou


negativo, a ser definido pela propriedade

Figura Representa uma imagem no formato BMP, EMF, GIF,


ICO, JPEG, PNG, TIFF ou WMF

Texto Representa um texto

Variant Representa um valor variável, que pode assumir vários


formatos

Algumas propriedades podem propagar seus valores à mesma propriedade nos objetos filhos. Neste caso, são
chamadas de propriedades propagáveis. Pode-se, no entanto, forçar a propriedade do objeto filho a se comportar
de modo diferente.

Programando no E3 38
NOTA
O E3 utiliza para definição de coordenadas e espessura o sistema Himetric. Neste sistema, cada unidade lógica
equivale a um milésimo de centímetro, ou seja, cada 1000 unidades equivalem a um centímetro. Assim, este é o
padrão adotado na descrição das propriedades do E3, quando aplicável.

2.8.3.1 Application
Esta propriedade retorna o objeto de aplicação relacionado ao contexto atual do objeto. Esta propriedade é
somente de leitura. Com o objeto Aplicação é possível, por exemplo, buscar outros objetos presentes no aplicativo.
Exemplo:
Sub Tela1_Click()
' Quando clica na tela, atribui um valor e abre um MessageBox
set obj = Application.GetObject("Dados.TagInterno1")
obj.Value = 100
MsgBox "Valor do TagInterno1: " & obj.Value
End Sub

2.8.3.2 Count
Retorna o número de objetos filhos, ou itens, que um objeto possui. Esta propriedade funciona em conjunto com o
método Item. Se o objeto não possuir filhos, o valor retornado é 0 (zero). Esta propriedade é somente de leitura.
Exemplo:
Sub Tela1_Click()
' Busca todos os objetos de tela
' e ajusta a propriedade
' ForegroundColor para vermelho
Dim obj
For i = 1 To Count
Set obj = Item(i) ' Objeto filho
obj.ForegroundColor = RGB(255, 0, 0)
Next
End Sub

2.8.3.3 DocString
Texto livre que tem por objetivo possibilitar a documentação das funcionalidades ou características do objeto pelos
programadores do projeto. Exemplo:
Sub CommandButton1_Click()
Docstring = "Este botão ativa o condensador do sistema."
MsgBox Docstring
End Sub

2.8.3.4 IsObjectActive
Esta propriedade indica se um objeto está ativado. Em tempo de execução, todos os objetos definidos em um
projeto retornam Verdadeiro nesta propriedade até que seja usado o método Deactivate no objeto ou em um de
seus objetos pai. Objetos criados em tempo de execução usando o método AddObject configuram esta propriedade
de acordo com o parâmetro Activate deste método. Para o caso de objetos pré-ativados em Hot-Standby, ou seja, os
objetos configurados na opção Serviços pré-ativados no servidor reserva da aba Opções na janela de configuração
do Domínio do E3 Admin, têm esta propriedade configurada em Falso até que o servidor reserva assuma a execução
do Domínio.

2.8.3.5 Links
Retorna um objeto que é uma coleção das conexões (ou Associações) de um objeto qualquer do E3. Esta
propriedade é somente de leitura. Consulte o tópico Coleção de Associações para mais informações sobre a coleção
de objetos retornados por esta propriedade.

2.8.3.6 Name
Identifica um objeto na aplicação. Esta propriedade não pode ser alterada com o objeto ativo. Ao alterar esta
propriedade, é necessário modificar todas as propriedades ou scripts que utilizam este objeto. Não é aconselhável a
alteração desta propriedade em tempo de execução.
Os caracteres a seguir são reservados e automaticamente substituídos pelo caractere de sublinhado (_):
· Qualquer caractere com código ASCII menor que 32 e o caractere com código ASCII 127 (DEL)
· Colchetes ([ e ]), quando usados em expressões

39 Programando no E3
· Barra invertida (\), que é usada em caminhos de recursos
· Dois pontos (:), que são usados em caminhos de Domínios Remotos e bancos de dados
· Aspas duplas ("), que são usadas para delimitar Strings em expressões
· Ponto de interrogação (?), que é usado para delimitar opções na propriedade SplitLink e nos métodos
ShowScreen e OpenScreen do Divisor, além do evento OnPreShow da Tela

Os demais caracteres podem ser utilizados, mas devem ser delimitados por colchetes quando utilizados em um
caminho nos seguintes casos:
· Contenha qualquer caractere que não seja uma letra (a-z | A-Z) quando usado como primeiro caractere do
caminho
· Contenha qualquer caractere que não seja uma letra (a-z | A-Z), um número (0-9) ou um sublinhado (_) quando
usado após o primeiro caractere do caminho

2.8.3.7 ObjectEvents
Retorna um objeto que é uma coleção de Eventos, tanto pré-definidos quanto de usuário, de um objeto qualquer
do E3. Esta propriedade é somente de leitura. Consulte o tópico Coleção de Eventos para mais informações sobre a
coleção de objetos retornados por esta propriedade.

2.8.3.8 Parent
Retorna o objeto pai deste objeto. Sendo assim, se um objeto está inserido na Tela, esta propriedade retorna o
valor "Tela". Da mesma forma, se um Tag Interno está inserido diretamente abaixo de um Servidor de Dados, esta
propriedade deste Tag Interno aponta para o Servidor de Dados. Esta propriedade é somente de leitura. Exemplo:
Sub Retangulo1_Click()
' Ao clicar no Retangulo1,
' troca a cor do Retangulo2
Parent.Item("Retangulo2").ForegroundColor = RGB(255, 0, 0)
End Sub

2.8.3.9 PathContainer
Retorna uma String contendo o caminho do objeto que contém o objeto atual, incluindo as Pastas. Este valor é
determinado apenas no momento em que é requisitado, por isto não é recomendado criar Associações para esta
propriedade. Esta propriedade é somente de leitura.

2.8.3.10 PathName
Identifica o caminho de um objeto na aplicação. Esta propriedade é somente de leitura. Exemplo:
Sub CommandButton9_Click()
MsgBox "O caminho da Tela é " & (Screen.PathName)
End Sub

2.8.3.11 PathVolume
Retorna uma String contendo o nome do arquivo .prj ou .lib que contém o objeto. No E3 Studio, esta propriedade
retorna o caminho completo do projeto ou biblioteca (c:\folder\folder\volume.prj). Em tempo de execução, os objetos
que executam no E3 Viewer retornam sempre uma String vazia. Já os que executam no servidor retornam o caminho
relativo do projeto ou biblioteca, conforme esteja armazenado no Domínio (volume.prj). Este valor é determinado
apenas no momento em que é requisitado, por isto não é recomendado criar Associações para esta propriedade.
Esta propriedade é somente de leitura.

2.8.4 Coleção de Associações


Esta seção contém informações sobre os métodos e propriedades comuns à coleção de Associações (Links) de um
objeto qualquer do E3, retornada pela propriedade Links.

2.8.4.1 Métodos Comuns


Esta seção contém informações sobre os métodos comuns à coleção de Associações (Links) retornada pela
propriedade Links.

Programando no E3 40
2.8.4.1.1 CreateLink
CreateLink(Property, Source, [BindType])
Este método permite criar uma Associação com uma propriedade de um objeto. Em caso de sucesso, este método
retorna o objeto criado. Caso contrário, ocorre um erro de script e o método retorna Nothing. Este método possui
os parâmetros Property, que especifica o nome da propriedade para a qual é criada a Associação, Source, que
especifica o nome do objeto de origem da Associação, e BindType, que é opcional e especifica o tipo de Associação a
ser criada. Se este parâmetro é omitido, cria uma Associação Simples.

NOTA
Nem todas as propriedades existentes em um objeto permitem a criação de Associações. Para verificar quais as
propriedades permitem este recurso, acesse a aba Associações da Janela de Propriedades do objeto. Se a
propriedade é inválida para uma Associação, não existir ou já possuir uma Associação, ocorre um erro de script.

Opções disponíveis para o parâmetro BindType


OPÇÃO DESCRIÇÃO
0 - Associação Simples Na Associação Simples, o valor da origem é copiado
para a propriedade toda vez que é modificado

1 - Associação Bidirecional Na Associação Bidirecional ocorre o mesmo que na


Simples, mas caso haja uma variação na propriedade, o
valor é copiado para a origem, gerando assim uma
Associação de duas direções

2 - Associação Analógica A Associação Analógica estabelece uma escala de


conversões entre a variável de origem e a propriedade

3 - Associação Digital Na Associação Digital são especificados valores fixos ou


alternantes para a propriedade, que são atribuídos de
acordo com a fonte ser verdadeira ou falsa

4 - Associação por Tabela Na Associação por Tabela pode-se estabelecer


condições entre a variável, os valores e o destino. Na
tabela são especificados os valores mínimos e máximos
e demais configurações

5 - Associação Reversa A Associação Reversa é uma Associação unidirecional da


propriedade para a fonte

6 - Associação Múltipla A Associação Múltipla é semelhante a uma Associação


por Tabela, exceto que cada linha da Associação permite
buscar seu valor de uma fonte diferente

No exemplo a seguir, clicar no Botão de Comando cria uma Associação Bidirecional para o valor de um Tag Interno
no objeto Texto1, ou seja, configura o parâmetro BindType para o valor 1 (um).
Sub CommandButton1_Click()
On Error Resume Next
Dim bndType, bndValue
bndType = 1 'Associação Bidirecional
Set bndValue = Screen.Item("Texto1").Links.Item("Value")
If bndValue Is Nothing Then
MsgBox "Criando uma Associação Bidirecional"
Set bndValue = Screen.Item("Texto1").Links.CreateLink("Value", "Dados.TagInterno1.Value",
bndType)
Else
MsgBox "Texto1 já tem uma Associação para " & bndValue.Source
End If
End Sub

41 Programando no E3
2.8.4.1.2 Item
Item(ItemId)
Este método retorna um objeto Associação de uma determinada propriedade de um objeto. Se é um texto, o
parâmetro ItemId especifica o nome da propriedade cuja Associação deseja-se acessar. A Associação também pode
ser acessada por um índice numérico. Este índice deve estar entre 1 (um) e Count. Caso não exista Associação com a
propriedade, ou o índice seja inválido, ocorre um erro de script. Assim como as demais coleções, a coleção de
Associações permite o uso da declaração For Each do VBScript. Exemplo:
Sub Texto1_Click()
For Each Link In Links
MsgBox "Origem do link: " & Link.Source
Next
End Sub

2.8.4.1.3 RemoveLink
RemoveLink(Property)
Este método remove uma Associação com a propriedade especificada por Property, caso exista. Caso não exista
Associação com a propriedade especificada, este método não tem efeito. Exemplo:
Sub CommandButton2_Click()
On Error Resume Next
Dim Bind
Set Bind = Screen.Item("ScrollBar1").Links.Item("Value")
If Bind Is Nothing Then
' Se a conexão não existe
MsgBox "ScrollBar1 não está conectado."
Else
MsgBox "ScrollBar1 está ligado à " & Bind.Source & "."
MsgBox "Removendo o link."
Screen.Item("ScrollBar1").Links.RemoveLink("Value")
End If
End Sub

2.8.4.2 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns à coleção de Associações (Links) retornada pela
propriedade Links.

2.8.4.2.1 Count
Retorna o número de objetos filhos, ou itens, de uma coleção de Associações. Esta propriedade trabalha em
conjunto com o método Item. Se a coleção não possui objetos filhos, o valor retornado é 0 (zero). Esta propriedade é
somente de leitura.

2.8.4.3 Associações
Esta seção contém informações sobre os objetos do tipo Associação contidos na coleção de Associações retornada
pela propriedade Links. Os tipos de Associações disponíveis são os seguintes:
· Analógica
· Bidirecional
· Digital
· Múltipla
· Por Tabela
· Reversa
· Simples

2.8.4.3.1 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns aos objetos contidos na coleção de Associações
retornada pela propriedade Links.

Programando no E3 42
2.8.4.3.1.1 Property
Especifica o nome da propriedade que está conectada. Ao ser modificada, permite deslocar a Associação para
outra propriedade do mesmo objeto. Exemplo:
Sub CommandButton1_Click()
Dim bind
Set bind = Screen.Item("TableBind").Links.Item(1)
bind.Property = "Caption"
End Sub

2.8.4.3.1.2 Source
Especifica a fonte da Associação, que pode ser o nome de outro objeto da aplicação ou uma expressão mais
complexa, acessando vários objetos. Exemplo:
Sub CommandButton1_Click()
Dim bind
Set bind = Screen.Item("TableBind").Links.Item(1)
bind.Source = "Dados.TagDemo1.Value"
End Sub

2.8.4.3.1.3 Type
Esta propriedade é somente de leitura e informa o tipo de Associação. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade Type
OPÇÃO DESCRIÇÃO
0 - bsSimple Associação Simples

1 - bsSimpleBiDir Associação Bidirecional

2 - bsAnalog Associação Analógica

3 - bsAnimation Associação Digital

4 - bsTable Associação por Tabela

5 - bsReverse Associação Reversa

6 - bsMultiSource Associação Múltipla

2.8.4.3.2 Associação Analógica


Esta seção contém informações sobre as propriedades do objeto Associação Analógica (AnalogBind). Este objeto não
possui eventos nem métodos associados.

2.8.4.3.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação Analógica (AnalogBind).
DstHiValue
Esta propriedade especifica o valor máximo atingido na propriedade. Exemplo:
Sub DstHiValue_ValueChange()
On Error Resume Next
Dim Bind
Set Bind = Screen.Item("ScrollBar1").Links.Item("Value")
Screen.Item("ScrollBar1").Max = Value
If Bind Is Nothing Then
MsgBox "ScrollBar1 não tem associação."
Else
MsgBox "ScrollBar1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando DstHiValue de " &_
Bind.DstHiValue & " para " & Value
Bind.DstHiValue = Value
End If
End Sub
DstLoValue
Esta propriedade especifica o valor mínimo atingido na propriedade. Exemplo:
Sub DstLoValue_ValueChange()
On Error Resume Next
43 Programando no E3
Dim Bind
Set Bind = Screen.Item("ScrollBar1").Links.Item("Value")
Screen.Item("ScrollBar1").Min = Value
If Bind Is Nothing Then
MsgBox "ScrollBar1 não tem associação."
Else
MsgBox "ScrollBar1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando DstLoValue de " &_
Bind.DstLoValue & " para " & Value
Bind.DstLoValue = Value
End If
End Sub
SrcHiValue
Esta propriedade especifica o valor máximo atingido na fonte. Exemplo:
Sub SrcHiValue_ValueChange()
On Error Resume Next
Dim Bind
Set Bind = Screen.Item("ScrollBar1").Links.Item("Value")
Screen.Item("ScrollBar2").Max = Value
If Bind Is Nothing Then
MsgBox "ScrollBar1 não tem associado."
Else
MsgBox "ScrollBar1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando SrcHiValue de " &_
Bind.SrcHiValue & " para " & Value
Bind.SrcHiValue = Value
End If
End Sub
SrcLoValue
Esta propriedade especifica o valor mínimo atingido na fonte. Exemplo:
Sub SrcLoValue_ValueChange()
On Error Resume Next
Dim Bind
Set Bind = Screen.Item("ScrollBar1").Links.Item("Value")
Screen.Item("ScrollBar2").Min = Value
If Bind Is Nothing Then
MsgBox "ScrollBar1 não tem associado."
Else
MsgBox "ScrollBar1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando SrcLoValue de " &_
Bind.SrcLoValue & " para " & Value
Bind.SrcLoValue = Value
End If
End Sub

NOTA
Caso os valores especificados para as propriedades SrcHiValue e SrcLoValue sejam iguais, não é possível executar
a escala, e a Associação funciona como se fosse uma Associação Simples.

2.8.4.3.3 Associação Bidirecional


Esta seção contém informações sobre as propriedades do objeto Associação Bidirecional (AgSimple). Este objeto não
possui eventos nem métodos associados.

2.8.4.3.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação Bidirecional (AgSimple).
BiDirectional
Esta propriedade retorna Verdadeiro se a Associação é Bidirecional e Falso se a Associação é Reversa ou Simples.

2.8.4.3.4 Associação Digital


Esta seção contém informações sobre as propriedades do objeto Associação Digital (AnimationBind). Este objeto não
possui eventos nem métodos associados.

Programando no E3 44
2.8.4.3.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação Digital (AnimationBind).
BlinkOff
Quando esta propriedade estiver configurada para Verdadeiro, a propriedade conectada alterna periodicamente
entre os valores das propriedades OffValue e BlinkOffValue, caso a fonte retorne Falso. Exemplo:
Sub BlinkOff_Change()
On Error Resume Next
Dim Bind
Set Bind = Screen.Item("Retangulo1")._
Links.Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando BlinkOff de " & _
Bind.BlinkOff & " para " & Value
Bind.BlinkOff = Value
End If
End Sub
BlinkOffValue
Esta propriedade especifica o valor alternativo a ser assumido periodicamente pela propriedade quando a
expressão da fonte resultar em Falso e a propriedade BlinkOff estiver configurada em Verdadeiro. Exemplo:
Sub BlinkOffValue_Click()
On Error Resume Next
Dim Value
If Application.ShowPickColor_
(Value, ForegroundColor, 400, 300) Then
Dim Bind
Set Bind = Screen.Item("Retangulo1").Links._
Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '"& Bind.Source & "'"
MsgBox "Mudando BlinkOffValue de " &_
Bind.BlinkOffValue & " para " & Value
Bind.BlinkOffValue = Value
End If
ForegroundColor = Value
End If
End Sub
BlinkOn
Quando esta propriedade estiver configurada para Verdadeiro, a propriedade conectada alterna periodicamente
entre os valores das propriedades OnValue e BlinkOnValue, caso a fonte retorne Verdadeiro. Exemplo:
Sub BlinkOn_Change()
On Error Resume Next
Dim Bind
Set Bind =_
Screen.Item("Retangulo1").Links.Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '" & Bind.Source & "'"
MsgBox "Mudando BlinkOn de " & Bind._
BlinkOn & " para " & Value
Bind.BlinkOn = Value
End If
End Sub
BlinkOnValue
Esta propriedade especifica o valor alternativo a ser assumido periodicamente pela propriedade quando a
expressão da fonte resultar em Verdadeiro e a propriedade BlinkOn estiver configurada para Verdadeiro. Exemplo:
Sub BlinkOnValue_Click()
On Error Resume Next
Dim Value
If Application.ShowPickColor_
(Value, ForegroundColor, 400, 300) Then

45 Programando no E3
Dim Bind
Set Bind = Screen.Item("Retangulo1").Links._
Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '"& Bind.Source & "'"
MsgBox "Mudando BlinkOnValue de " &_
Bind.BlinkOnValue & " para " & Value
Bind.BlinkOnValue = Value
End If
ForegroundColor = Value
End If
End Sub
OffValue
Esta propriedade especifica o valor assumido pela propriedade quando a expressão da fonte resultar em Falso.
Exemplo:
Sub OffValue_Click()
On Error Resume Next
Dim Value
If Application.ShowPickColor_
(Value, ForegroundColor, 400, 300) Then
Dim Bind
Set Bind = Screen.Item("Retangulo1").Links._
Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '"& Bind.Source & "'"
MsgBox "Mudando OffValue de " &_
Bind.OffValue & " para " & Value
Bind.OffValue = Value
End If
ForegroundColor = Value
End If
End Sub
OnValue
Esta propriedade especifica o valor assumido pela propriedade quando a expressão da fonte resultar em
Verdadeiro. Exemplo:
Sub OnValue_Click()
On Error Resume Next
Dim Value
If Application.ShowPickColor_
(Value, ForegroundColor, 400, 300) Then
Dim Bind
Set Bind = Screen.Item("Retangulo1").Links._
Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação."
Else
MsgBox "Retangulo1 está associado a '"& Bind.Source & "'"
MsgBox "Mudando OnValue de " &_
Bind.OnValue & " para " & Value
Bind.OnValue = Value
End If
ForegroundColor = Value
End If
End Sub

2.8.4.3.5 Associação Múltipla


Esta seção contém informações sobre os métodos e propriedades do objeto Associação Múltipla (MultiSourceBind).
Este objeto não possui eventos associados.

2.8.4.3.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Associação Múltipla (MultiSourceBind).

Programando no E3 46
InsertRow
InsertRow([InsertAtRow])
Insere uma nova Linha na tabela de Associações Múltiplas na posição indicada pelo parâmetro InsertAtRow. Este
parâmetro é opcional e, se omitido, insere a nova Linha ao final da tabela de Associações Múltiplas, o que equivale a
usar o parâmetro InsertAtRow com o valor -1 (menos um). Se o valor informado em InsertAtRow não é omitido e é
diferente de -1 (menos um), este valor deve estar entre 1 (um) e Count e a nova Linha criada desloca as Linhas de
índice maior ou igual para a direção ascendente dos índices.
Item
Item(ItemId)
Retorna uma referência para o objeto Linha da Conexão Múltipla, indicado por ItemId.
RemoveRow
RemoveRow(Row)
Remove a Linha no índice indicado pelo parâmetro Row.

2.8.4.3.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação Múltipla (MultiSourceBind).
AdviseAll
Esta propriedade mantém todas as Associações da tabela de Associações Múltiplas em modo Advise (ativas). O
valor padrão desta propriedade é Verdadeiro. Para aplicações criadas em versões anteriores, esta propriedade tem o
valor Falso, por compatibilidade.
Count
Esta propriedade retorna o número de Linhas da tabela de Associações Múltiplas. Esta propriedade é somente de
leitura.

2.8.4.3.5.3 Linha da Associação Múltipla


Esta seção contém informações sobre as propriedades do objeto Linha da Associação Múltipla (MultiSourceRow). Este
objeto não possui eventos nem métodos associados.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Linha da Associação Múltipla (MultiSourceRow).
Max
Esta propriedade especifica o intervalo máximo para o valor da Associação indicada na propriedade Source.
Min
Esta propriedade especifica o intervalo mínimo para o valor da Associação indicada na propriedade Source.
Source
Esta propriedade especifica a fonte da Associação da Linha da Conexão Múltipla, que pode ser o nome de outro
objeto da aplicação ou uma expressão mais complexa, acessando vários objetos.

2.8.4.3.6 Associação por Tabela


Esta seção contém informações sobre os métodos e propriedades do objeto Associação por Tabela (TableBind). Este
objeto não possui eventos associados.

2.8.4.3.6.1 Métodos
Esta seção contém informações sobre os métodos do objeto Associação por Tabela (TableBind).
InsertRow
InsertRow([InsertAtRow])
Insere uma nova Linha na tabela. O parâmetro InsertAtRow é opcional e especifica em que posição da tabela deve ser
inserida a Linha. Quando omitido assume o comportamento padrão de inserir a Linha no fim da tabela, o que equivale
a usar InsertAtRow igual a -1 (menos um). Quando informado e diferente de -1 (menos um), deve ser um valor entre 1
(um) e Count e a nova Linha criada desloca as Linhas de índice maior ou igual para a direção ascendente dos índices.
Uma Linha nova sempre assume os seguintes valores padrão para as propriedades:
· Min: 0.0

47 Programando no E3
· Max: 1.0
· Blink: False
· BlinkValue: 0.0
· Value: 0.0

Exemplo:
Sub Retangulo1_Click()
On Error Resume Next
Dim Bind
Set Bind = _
Screen.Item("Retangulo1").Links.Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem nenhuma associação."
Else
Dim row
row = Screen.Item("SetPointRow").Value
MsgBox Bind.RowCount
If (row < 1 OR row > Bind.RowCount) Then
MsgBox "Número de linha inválido: " & row
Else
MsgBox "Acrescentando uma linha em: " & row
Bind.InsertRow(row)
If row = -1 Then
row = Bind.RowCount
Bind.Value(line) = _
Screen.Item("RectangleValue").ForegroundColor
Bind.BlinkValue(line) = _
Screen.Item("RectangleBlinkValue").ForegroundColor
Bind.Max(line) = Screen.Item("SetPointMax").Value
Bind.Min(line) = Screen.Item("SetPointMin").Value
Bind.Blink(line) = _
Screen.Item("CheckBoxBlink").Value
End If
End If
End If
End Sub
Item
Item(ItemId)
Retorna uma referência para o objeto Linha da Conexão por Tabela, indicado por ItemId.
RemoveRow
RemoveRow(Row)
Remove a Linha no índice especificado. O parâmetro Row determina a Linha da tabela a ser removida e deve estar
entre 1 (um) e Count. Exemplo:
Sub RemoveRow_Click()
On Error Resume Next
Dim Bind
Set Bind =_
Screen.Item("Retangulo1").Links.Item("ForegroundColor")
If Bind Is Nothing Then
MsgBox "Retangulo1 não tem associação!"
Else
MsgBox "Retangulo1 está ligado à '" & Bind.Source & "'"
Dim row
row = Screen.Item("Row").Value
MsgBox "Removendo a linha " & row
Bind.RemoveRow row
End If
End Sub

2.8.4.3.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação por Tabela (TableBind).
Count
Esta propriedade informa o número de linhas na tabela. Esta propriedade é somente de leitura.

Programando no E3 48
2.8.4.3.6.3 Linha da Associação por Tabela
Esta seção contém informações sobre as propriedades do objeto Linha da Associação por Tabela (TableBindRow).
Este objeto não possui eventos nem métodos associados.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Linha da Associação por Tabela (TableBindRow).
Blink
Esta propriedade determina que quando a fonte estiver no intervalo desta Linha, a propriedade alterna
periodicamente entre os valores especificados nas propriedades Value e BlinkValue. Exemplo:
Sub CheckBox1_Click()
Screen.Item("Retangulo1").Links.Item("ForegroundColor")._
Item(1).Blink = Value
Screen.Item("Retangulo1").Links.Item("ForegroundColor")._
Item(2).Blink = Value
End Sub
BlinkValue
Esta propriedade especifica o valor alternativo (para piscar) da propriedade a ser assumido quando a fonte estiver
no intervalo especificado na Linha e a propriedade Blink estiver configurada para Verdadeiro. Exemplo:
Sub CommandButton1_Click()
Dim Cor
' Escolhe uma cor
Application.ShowPickColor Cor, 0, 100, 100
Screen.Item("Retangulo1").Links.Item("ForegroundColor")._
Item(1).BlinkValue = Cor
End Sub
Max
Esta propriedade especifica o valor máximo da fonte para uma Linha da Tabela.
Min
Esta propriedade especifica o valor mínimo da fonte para uma Linha da Tabela. O exemplo a seguir se aplica tanto
para a propriedade Max quanto para Min.
Sub CommandButton1_Click()
Set Bind = _
Screen.Item("Retangulo1").Links.Item("ForegroundColor")
Set Linha1 = Bind.Item(1)
Linha1.Min = 0
Linha1.Max = 20
Set Linha2 = Bind.Item(2)
Linha2.Min = 21
Linha2.Max = 100
End Sub
Value
Esta propriedade especifica o valor da propriedade a ser assumido quando a fonte estiver no intervalo especificado
na Linha. Exemplo:
Sub CommandButton1_Click()
Dim Cor
' Escolhe uma cor
Application.ShowPickColor Cor, 0, 100, 100
Screen.Item("Retangulo1").Links.Item("ForegroundColor")._
Item(1).Value = Cor
End Sub

2.8.4.3.7 Associação Reversa


Esta seção contém informações sobre as propriedades do objeto Associação Reversa (AgSimple). Este objeto não
possui eventos nem métodos associados.

2.8.4.3.7.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Associação Reversa (AgSimple).
Reverse
Esta propriedade retorna Verdadeiro se a Associação é Reversa e retorna Falso se a Associação é Bidirecional ou
Simples.

49 Programando no E3
2.8.4.3.8 Associação Simples
O objeto Associação Simples (AgSimple) não tem eventos, métodos ou propriedades associadas.

2.8.5 Coleção de Eventos


Esta seção contém informações sobre os métodos e propriedades do objeto Coleção de Eventos (Events) retornado
pela propriedade ObjectEvents. Este objeto não possui eventos associados.

2.8.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Eventos (Events) retornado pela propriedade
ObjectEvents.

2.8.5.1.1 AddUserEvent
AddUserEvent(Name, [Link], [Type], [ScanTime], [ChangeOnDisconnect])
Adiciona um Evento de Usuário na Coleção de Eventos e retorna este objeto. Os parâmetros deste método estão
descritos na tabela a seguir.
Parâmetros do método AddUserEvent
PARÂMETRO DESCRIÇÃO
Name Nome deste Evento de Usuário. Este parâmetro é
obrigatório

Link Expressão a ser avaliada neste Evento de Usuário. Este


parâmetro é opcional e, se omitido, assume o valor de
uma String vazia. Corresponde à propriedade Link do
objeto Evento de Usuário

Type Tipo de Evento de Usuário. Este parâmetro é opcional e,


se omitido, assume o valor 0 (zero). Corresponde à
propriedade Type do objeto Evento de Usuário

ScanTime Tempo, em milissegundos, de repetição deste Evento de


Usuário. Este parâmetro é opcional e, se omitido, assume
o valor 1000, ou seja, um segundo. Corresponde à
propriedade ScanTime do objeto Evento de Usuário

ChangeOnDisconnect Indica se a desconexão é tratada como mudança no


valor da expressão deste Evento de Usuário. Este
parâmetro é opcional e, se omitido, assume o valor 0
(zero), ou seja, Falso. Corresponde à propriedade
ChangeOnDisconnect do objeto Evento de Usuário

2.8.5.1.2 Item
Item(ItemId)
Este método retorna um objeto Evento ou Evento de Usuário da Coleção de Eventos de um objeto qualquer do E3. Se
este parâmetro é um texto, o parâmetro ItemId especifica o nome do objeto a acessar. O objeto também pode ser
acessado por um índice numérico. Este índice deve estar entre 1 (um) e Count. Caso o objeto não exista, ou o índice
seja inválido, ocorre um erro de script.

2.8.5.1.3 RemoveUserEvent
RemoveUserEvent(Name)
Remove um Evento de Usuário, indicado pelo parâmetro Name, da Coleção de Eventos. Este método retorna erro em
caso de parâmetro inválido.

2.8.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Eventos (Events) retornado pela
propriedade ObjectEvents.

Programando no E3 50
2.8.5.2.1 Count
Retorna o número de objetos filhos, ou itens, de uma coleção de Eventos. Esta propriedade trabalha em conjunto
com o método Item. Se a coleção não possui objetos filhos, o valor retornado é 0 (zero). Esta propriedade é somente
de leitura.

2.8.5.3 Evento
Esta seção contém informações sobre os métodos e propriedades do objeto Evento (Event) da Coleção de Eventos.
Este objeto não possui eventos associados.

2.8.5.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Evento (Event) da Coleção de Eventos.

2.8.5.3.1.1 AddScript
AddScript(bstrCode)
Adiciona um Pick do tipo Executar Script a este Evento com o código especificado no parâmetro bstrCode. Este
parâmetro deve conter apenas o corpo do script, sem a linha inicial Sub e sem a linha final End Sub, e pode ser uma
String vazia.

2.8.5.3.1.2 RemoveAll
RemoveAll()
Remove todos os Picks do tipo Executar Script deste Evento. Este método não retorna erro caso não haja Picks neste
Evento.

2.8.5.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Evento (Event) da Coleção de Eventos.

2.8.5.3.2.1 Name
Retorna o nome deste Evento na Coleção de Eventos. Esta propriedade é somente de leitura.

2.8.5.4 Evento de Usuário


Esta seção contém informações sobre os métodos e propriedades do objeto Evento de Usuário (UserEvent) da
Coleção de Eventos. Este objeto não possui eventos associados.

2.8.5.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Evento de Usuário (UserEvent) da Coleção de Eventos.

2.8.5.4.1.1 AddScript
AddScript(bstrCode)
Adiciona um script a este Evento de Usuário com o código especificado no parâmetro bstrCode. Este parâmetro deve
conter apenas o corpo do script, sem a linha inicial Sub e sem a linha final End Sub, e pode ser uma String vazia.

2.8.5.4.1.2 RemoveAll
RemoveAll()
Remove todos os scripts deste Evento de Usuário. Este método não retorna erro caso não haja scripts neste Evento
de Usuário.

2.8.5.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Evento de Usuário (UserEvent) da Coleção de
Eventos.

51 Programando no E3
2.8.5.4.2.1 ChangeOnDisconnect
Indica se uma desconexão é tratada como uma alteração no valor da expressão indicada na propriedade Link. Esta
propriedade somente se aplica a Eventos de Usuário cuja propriedade Type seja igual a 2 (dois,
uetOnValueChanged). O valor padrão desta propriedade é Falso.

2.8.5.4.2.2 Link
Texto com a expressão avaliada no Evento de Usuário. O valor padrão desta propriedade é uma String vazia.

2.8.5.4.2.3 ScanTime
Tempo, em milissegundos, referente ao período de repetição deste Evento de Usuário. Esta propriedade somente
se aplica a Eventos de Usuário cuja propriedade Type seja igual a 1 (um, uetWhileTrue). O valor padrão desta
propriedade é 1000, ou um segundo.

2.8.5.4.2.4 Type
Indica o tipo de Evento de Usuário. Os valores possíveis para esta propriedade são os seguintes:
· 0 - uetOnEvent: o Evento de Usuário dispara quando o valor da expressão muda de Falso para Verdadeiro
(padrão)
· 1 - uetWhileTrue: o Evento de Usuário dispara periodicamente enquanto o valor da expressão é igual a
Verdadeiro
· 2 - uetOnValueChanged: o Evento de Usuário dispara quando o valor da expressão é alterado

Programando no E3 52
CAPÍTULO
Bibliotecas do Usuário
3
Esta seção contém informações sobre os objetos ElipseX (XControls, XFolders e XObjects).

3.1 ElipseX
Esta seção contém informações sobre eventos e propriedades comuns aos objetos ElipseX (XControls, XFolders e
XObjects). Estes objetos não possuem métodos comuns associados.

3.1.1 Eventos Comuns


Esta seção contém informações sobre os eventos comuns aos objetos ElipseX (XControls, XFolders e XObjects).

3.1.1.1 Constructor
Constructor()
Disparado quando o ElipseX é iniciado. Pode-se utilizar este evento para executar um script que inicie valores internos
de um ElipseX, por exemplo.

3.1.1.2 CustomConfig
CustomConfig()
Permite configurações automatizadas nas instâncias de objetos ElipseX. Uma opção de configuração aparece no menu
contextual das instâncias de objetos ElipseX sempre que existir um script associado ao evento CustomConfig da
definição do objeto ElipseX. Quando esta opção é selecionada no menu contextual, o evento é disparado. O texto que
aparece na opção do menu contextual pode ser informado na propriedade CustomConfigText da definição do
objeto ElipseX. Se esta propriedade estiver em branco, aparece o texto "Configurar".

53 Bibliotecas do Usuário
Menu contextual da instância do objeto ElipseX

NOTA
O script associado ao evento CustomConfig executa no E3 Studio, onde os objetos não estão ativos. Portanto, o
comportamento é diferente do usual.

3.1.2 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns aos objetos ElipseX (XControls, XFolders e XObjects).

3.1.2.1 Contexts
Define uma variável de contexto usada em expressões de Associações. Para mais informações sobre contextos, veja
o método Context no tópico Eventos, Métodos e Propriedades Gerais dos Objetos.

NOTA
O valor desta propriedade não permite caracteres especiais, apenas letras (sem diferenciar maiúsculas e minúsculas)
e números.

3.1.2.2 CustomConfigText
Indica o texto que deve aparecer no menu contextual para a opção de configuração da instância do ElipseX. A
opção só aparece se existir um script associado ao evento CustomConfig da definição do ElipseX. Se o valor da
propriedade estiver em branco, aparece o texto "Configurar" na opção do menu contextual. O valor padrão desta
propriedade é uma String vazia.

Bibliotecas do Usuário 54
3.1.2.3 DefaultIsAlarmArea
Define o comportamento de habilitar ou não a propriedade IsAlarmArea nas instâncias do ElipseX.

NOTA
Esta propriedade não está disponível para XControls.

3.1.2.4 EnableTagBehavior
Esta propriedade permite habilitar um comportamento de Tag a uma instância do ElipseX, ou seja, se a instância
contém pelo menos as propriedades Value, Quality e Timestamp, os valores destas propriedades são sempre
propagados em conjunto. O valor padrão desta propriedade é Falso. Ao habilitar esta propriedade, o E3 Studio
verifica se o ElipseX contém todas as propriedades obrigatórias, Value (do tipo Variant), Quality (do tipo Word) e
Timestamp (do tipo Date). As propriedades a seguir são opcionais e também podem ser criadas durante o processo
de verificação:
· ActiveSource (fonte de medida ativa, do tipo PowerSourceType)
· EU (unidade de engenharia, do tipo String)
· EULow (valor mínimo da propriedade Value, do tipo Double)
· EUHigh (valor máximo da propriedade Value, do tipo Double)

NOTA
· Se alguma das propriedades obrigatórias para o funcionamento do comportamento de Tag (Value, Quality ou
Timestamp) é apagada, isto impede o uso do ElipseX em tempo de execução.
· Da mesma forma, alterar o tipo de dados das propriedades (obrigatórias ou opcionais) para um tipo de dados
incompatível também impede o uso do ElipseX em tempo de execução.
· Configurar esta propriedade em Verdadeiro habilita o comportamento da propriedade ValueMode.

3.1.2.5 FriendlyName
Define um nome amigável para a classe do ElipseX, utilizado no menu contextual de inserção de objetos e na janela
Contagem de Objetos do Domínio.

3.1.2.6 IconPath
Define o nome do arquivo de imagem a ser utilizado como ícone para as instâncias do ElipseX. Este ícone é
mostrado no menu contextual Inserir de Telas (para XControls) e Servidores de Dados (para XFolders e XObjects),
bem como no Organizer, AppBrowser, etc. Esta propriedade permite arrastar e soltar um arquivo de imagem inserido
como Recurso no projeto. O valor padrão desta propriedade é uma String vazia, ou seja, a instância do ElipseX
mostra o ícone para XControls, o ícone para XFolders e o ícone para XObjects.

3.1.2.7 InstanceName
Define um nome padrão para as instâncias criadas a partir do ElipseX. Consulte a propriedade geral Name para
mais informações sobre os caracteres permitidos no nome desta instância.

3.1.2.8 ValueMode
Esta propriedade informa se as instâncias de um ElipseX possuem valores analógicos, discretos ou não definidos.
Os valores possíveis para esta propriedade são os seguintes:
· 0: vmUndefined (valor padrão)
· 1: vmAnalog
· 2: vmDiscrete

Esta propriedade somente tem efeito se a propriedade EnableTagBehavior estiver configurada em Verdadeiro.

3.1.3 Objeto Definição de Propriedades


Esta seção contém informações sobre eventos e propriedades do objeto Definição de Propriedades (XMethod). Este
objeto não possui métodos associados.

55 Bibliotecas do Usuário
3.1.3.1 Eventos
Esta seção contém informações sobre os eventos do objeto Definição de Propriedades (XMethod).

3.1.3.1.1 OnPropertyChanged
OnPropertyChanged()
Ocorre quando uma Definição de Propriedade de um ElipseX é modificada. Pode-se utilizar este evento para disparar
scripts que executem ações de acordo com determinado status de um ElipseX.

3.1.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Definição de Propriedades (XMethod).

3.1.3.2.1 DefaultValue
Define o valor inicial para a Definição de Propriedade quando uma nova instância do objeto é criada. Se a Definição
de Propriedade está configurada como retentiva, ela é inicializada com este valor cada vez que o objeto é carregado.
O valor padrão desta propriedade é vazio (empty).

3.1.3.2.2 HelpString
Texto contendo a descrição da Definição de Propriedade. Este texto é mostrado na parte inferior da Lista de
Propriedades no E3 Studio quando a Definição de Propriedade é selecionada. O valor padrão desta propriedade é
uma String vazia.

3.1.3.2.3 Persistable
Indica se a Definição de Propriedade é salva no arquivo de projeto (Verdadeiro) ou se está disponível apenas em
tempo de execução (Falso). O valor padrão desta propriedade é Verdadeiro. Se esta propriedade é configurada com
o valor Falso, a Definição de Propriedade não pode ser editada no E3 Studio, nem salva ou lida do arquivo de
projeto. Entretanto, a Definição de Propriedade ainda é visível no AppBrowser. Esta propriedade é representada pelo
ícone .
Quando esta propriedade está configurada para Verdadeiro, a Definição de Propriedade recebe seu valor padrão
(propriedade DefaultValue) apenas na criação de uma instância. Se a propriedade DefaultValue é alterada, as
instâncias do objeto já criadas não são afetadas.
Quando esta propriedade está configurada para Falso, a Definição de Propriedade recebe seu valor padrão sempre
que uma instância é carregada, ou seja, sempre que a propriedade DefaultValue é alterada, todas as instâncias já
criadas são inicializadas com o novo valor padrão.

3.1.3.2.4 Public
Quando uma Definição de Propriedade de um ElipseX é pública (Verdadeiro), ela é visível fora da Biblioteca. Caso
contrário, a Definição de Propriedade é interna e somente visível para o objeto. O valor padrão desta propriedade é
Verdadeiro. A Definição de Propriedade pública é representada pelo ícone .

3.1.3.2.5 Retentive
Indica se o valor atual da Definição de Propriedade em tempo de execução é persistido no arquivo de Domínio
(Verdadeiro), enquanto o Domínio estiver carregado. Uma Definição de Propriedade retentiva é representada pelo
ícone . Definições de Propriedade retentivas têm o seguinte comportamento:
· Propagam o seu valor para o servidor em Standby
· Mantêm o seu valor se a aplicação é atualizada em tempo de execução
· Mantém o seu valor se a aplicação é parada (desde que o Domínio não seja fechado)

NOTAS
· Esta propriedade somente está disponível para Definições de Propriedades cujo tipo de dados não seja um objeto
(Variant, Double, Integer, etc.).
· O uso desta propriedade em Verdadeiro implica em um aumento no uso de memória e CPU por parte do E3Run,
por isto deve ser utilizada com cautela.

Bibliotecas do Usuário 56
3.1.3.2.6 Type
Determina o tipo de valores que a Definição de Propriedade aceita (por exemplo, Boolean, Double, Integer,
Variant, etc.). Quando é especificado um objeto como tipo (por exemplo DemoTag, IOTag, XObject, etc.), esta
propriedade tem o seguinte comportamento:
· Caso o ElipseX esteja inativo: A propriedade funciona como uma String, que especifica o caminho da instância
de um objeto do tipo configurado
· Caso o ElipseX esteja ativo: Na escrita, a propriedade funciona da mesma maneira de quando o objeto está
desativado. Porém, na leitura a propriedade retorna o objeto especificado, caso exista. Se o caminho não aponta
para um objeto existente no momento, a propriedade retorna Nothing

57 Bibliotecas do Usuário
CAPÍTULO
Visualização
4
Esta seção contém informações sobre eventos, métodos e propriedades dos objetos de visualização do E3:
· Viewer
· Quadros e Divisores
· Telas e Objetos de Tela
· E3Alarm
· E3Browser
· E3Chart
· E3Playback
· Relatórios
· TrendAnalysis

4.1 Viewer
Esta seção contém informações sobre eventos, métodos e propriedades do objeto Viewer.

4.1.1 Eventos
Esta seção contém informações sobre os eventos do objeto Viewer.

4.1.1.1 OnInactive
OnInactive()
Este evento ocorre enquanto o E3 Viewer estiver inativo e se a propriedade EnableInactivity estiver em Verdadeiro.
Este evento inicia quando se constata que o usuário está sem utilizar o E3 Viewer por um período de tempo igual ou
superior ao valor da propriedade InactivityTime.
Em um script para este evento, o usuário pode programar uma ação quando o E3 Viewer estiver inativo por um
determinado período de tempo. Por exemplo, é possível determinar que após 20 minutos sem uso seja efetuado o
logout do E3 Viewer, como no exemplo a seguir.
Sub Viewer_OnInactive()
Logout(false)
If MsgBox("Essa sessão do E3 Viewer foi fechada_
devido à inatividade.") = 0 Then
Application.GetFrame("").OpenScreen "TelaInicial", 0
End Sub

4.1.1.2 Eventos de Usuário


Esta seção contém informações sobre eventos de usuário do objeto Viewer.

4.1.1.2.1 OnLogin
OnLogin()
Ocorre quando um usuário executa um login na aplicação, ou autenticação de usuário, com sucesso. O login na
aplicação pode ser executado através do método Login ou quando um objeto que só pode ser acessado por
usuários com um determinado nível de autorização exige autenticação.

4.1.1.2.2 OnLogout
OnLogout()
Ocorre quando é executado um logout, ou seja, a saída do usuário de uma aplicação. O logout é realizado através da
chamada ao método Logout.

4.1.2 Métodos
Esta seção contém informações sobre os métodos do objeto Viewer.

Visualização 58
4.1.2.1 CaptureScreen
CaptureScreen(FileName)
Este método captura a Tela atual e a salva em um arquivo. Este método é semelhante ao efeito realizado pela tecla
PRINT SCREEN no Windows. O parâmetro FileName determina o nome do arquivo no qual a Tela é salva.

NOTA
O formato final do arquivo é Bitmap (.bmp), mesmo que no parâmetro FileName seja informada outra extensão,
como por exemplo .gif ou .jpg.

Exemplo:
Sub CommandButton1_Click()
Screen.Frame.CaptureScreen "c:\temp\tela.bmp"
End Sub

4.1.2.2 ChangePassword
ChangePassword([PosX], [PosY])
Este método abre uma caixa de diálogo para permitir a troca de senha do usuário atual e retorna Verdadeiro se o
usuário atual tem permissão para trocar a senha ou retorna Falso se houve falha na operação ou se não é possível
trocar a senha porque o usuário não tem autorização.
Este método tem os parâmetros opcionais PosX, que indica a posição em pixels da caixa de diálogo em relação à
margem esquerda da janela, e PosY, que indica a posição em pixels da caixa de diálogo em relação à margem
superior da janela. Caso algum destes parâmetros seja omitido, a respectiva coordenada da caixa de diálogo é
centralizada na janela. Caso os valores indicados nestes parâmetros posicionem a caixa de diálogo fora da área visível
da janela, estes valores são ajustados automaticamente para garantir que a caixa de diálogo esteja visível.

NOTA
Este método só está disponível se o usuário logado é um usuário do Domínio do E3.

4.1.2.3 ChangeUserPassword
ChangeUserPassword(Username, PasswordOld, PasswordNew, [OpStatus])
Este método permite alterar a senha de um usuário sem mostrar nenhuma mensagem. O parâmetro Username é o
nome do usuário, o parâmetro PasswordOld é a senha atual deste usuário e o parâmetro PasswordNew é a nova senha.
O parâmetro opcional de retorno OpStatus é um mapa de bits que indica o status desta operação. Este método
retorna um Booleano indicando se a operação falhou ou não. Consulte a tabela Valores de retorno possíveis para o
parâmetro OpStatus no método LoginUser para mais informações sobre os valores possíveis em caso de falha.

4.1.2.4 DoModal
DoModal(Screen, Title, Left, Top, Width, Height, Arg, [Flags])
Abre uma Tela modal, que é uma janela que não permite clicar em outras Telas ou janelas enquanto não é fechada. O
parâmetro Title passado neste método só é utilizado se a propriedade Caption está vazia. Do contrário, este
parâmetro é ignorado. Este método possui os seguintes parâmetros:
· Screen: Determina o nome da Tela
· Title: Determina o título da janela modal
· Left, Top: Posição XY da janela modal, em pixels
· Width: Largura da janela modal, em pixels ou Himetric
· Height: Altura da janela modal, em pixels ou Himetric
· Arg: Determina a variável a ser usada no evento OnPreShow da Tela
· Flags: Determina a combinação utilizada na janela modal. Tal combinação é realizada somando-se os valores da
tabela correspondentes às opções que o usuário deseja. Quando o valor especificado é igual a -1 (menos um,
usado quando o parâmetro e omitido), são adotadas as configurações do Viewer para a janela modal. Quando
este valor é diferente de -1 (menos um), pode-se usar as combinações descritas na tabela a seguir

59 Visualização
Combinações possíveis para o parâmetro Flags
VALOR DESCRIÇÃO
1 Habilita a barra de título na janela

2 Habilita o botão Fechar na janela

4 Habilita o botão Minimizar na janela

8 Habilita o botão Maximizar na janela

16 Habilita a borda na janela

32 Especifica que a janela pode ser dimensionada

64 Especifica que a janela pode ser movida

256 Especifica que a janela permanece no topo da Tela

512 Especifica que a janela é configurada no estilo Barra de


Ferramentas

1024 Desabilita os botões de objeto

2048 Centraliza a Tela modal no Quadro, tanto horizontal


quanto verticalmente

Exemplo:
Sub Botao1_Click()
' Ao clicar no Botão, abre uma outra Tela modal
Application.DoModal "Tela1", "Titulo", 0, 0, 400, 200, 0, 3
End Sub

NOTA
Os valores de tamanho neste método podem ser informados como números ou Strings. No caso de números, são
considerados em pixels. No caso de Strings, se vierem acompanhados da unidade "hm", são interpretados como
Himetric. Qualquer outro caso é considerado em pixels.

4.1.2.5 ESign
ESign(ObjName, [Description], [Action], [From], [To], [User], [Comment])
Este método é utilizado para validar a alteração de um campo através de assinatura eletrônica. Quando este método
é utilizado, a caixa de diálogo da figura a seguir é mostrada.

Visualização 60
Caixa de Diálogo de Assinatura Eletrônica
Parâmetros do método ESign
PARÂMETRO DESCRIÇÃO
ObjName Texto que contém o nome de um Tag ou outro objeto da
aplicação

Description Texto que contém a descrição de ObjName. Este


parâmetro é opcional e, se omitido, a caixa de diálogo
tenta buscar os dados da propriedade DocString de
ObjName

Action Texto que contém a ação a ser executada, como por


exemplo "Alteração do valor". Este parâmetro é opcional
e, se omitido, insere uma String vazia no campo Ação

From Variant que contém o valor original ou o estado a ser


alterado. Este parâmetro é opcional e, se omitido, insere
uma String vazia no campo De

To Variant que contém o novo valor do Tag ou o valor a


ser aplicado em Action. Este parâmetro é opcional e, se
omitido, insere uma String vazia no campo Para

User Texto de retorno. Recebe o nome de login selecionado


na caixa de diálogo. Este parâmetro é opcional e, se
omitido, insere uma String vazia no campo Usuário

Comment Texto de retorno. Recebe o comentário digitado na caixa


de diálogo. Este parâmetro é opcional e, se omitido,
insere uma String vazia no campo Comentário

Ao clicar em , abre-se uma janela que permite autenticar o usuário. Se a opção Windows é selecionada, os campos
Nome do usuário e Senha são automaticamente desabilitados. Clique em Outro usuário para selecionar um usuário
pertencente ao domínio de rede. Caso a opção E3 seja selecionada, digite as informações de um usuário pertencente
ao Domínio do E3 nos campos Nome do usuário e Senha.

61 Visualização
Login integrado
Este método retorna Verdadeiro se o usuário clica em OK, e se os campos Usuário e Senha são válidos. Caso
contrário, se a caixa de diálogo é cancelada ou se o login ou a senha estiverem errados, após três tentativas o
método retorna Falso. Em caso de falha, User e Comment são configurados para uma String vazia.
Os comentários pré-definidos são armazenados no Registro do Windows. Apenas os últimos 26 comentários são
salvos. Cada vez que a janela é criada, os últimos comentários são buscados no Registro e usados para preencher a
lista de seleção. Se um novo comentário é informado pelo usuário, este é salvo e o mais antigo é descartado, caso
não haja posição livre. Se um comentário já existente é utilizado, este passa a ser o primeiro da lista de comentários
mais recentes. Exemplo:
Sub Button1_Click()
Dim Tag, User, Comment
Set Tag = Application.GetObject("IO.Inputs.I001")
If Application.ESign(Tag.PathName, , "Alteração do Valor", _
Tag.Value, 1, User, Comment) Then
If Tag.WriteEx(1) Then
Application.TrackEvent _
"Tag IO.Inputs.I001 alterado para 1 " &_
"pelo usuário" & User, Comment
End If
End If
End Sub

4.1.2.6 ExecuteExternalApp
ExecuteExternalApp(AppPath, Arguments, InitialDir, CmdShow, [ProcessId])
Este método executa uma aplicação externa de nome e caminho indicado no parâmetro AppPath, com os argumentos
indicados pelo parâmetro Arguments, iniciando no diretório de trabalho indicado pelo parâmetro InitialDir. Quando
especificado um documento no parâmetro AppPath, a aplicação associada a este documento é executada e o
documento é passado como um dos parâmetros da aplicação. O parâmetro ProcessID é opcional e recebe o número
que identifica o processo da aplicação externa no sistema operacional. Este número é utilizado no método
IsAppRunning e é o mesmo valor que aparece no Gerenciador de Tarefas do Windows, na coluna PID. O parâmetro
CmdShow especifica o modo de abertura da janela da aplicação, conforme descrito na tabela a seguir.
Opções disponíveis para o parâmetro CmdShow
OPÇÃO DESCRIÇÃO
0 Esconde a janela e ativa outra janela

1 Ativa e mostra a janela. Se a janela estiver maximizada ou


minimizada, ela é restaurada para o tamanho e posição
originais. Uma aplicação deve especificar este valor
quando estiver mostrando uma janela pela primeira vez

2 Ativa a janela e mostra-a minimizada

3 Ativa a janela e mostra-a maximizada

4 Mostra a janela com seu tamanho e posição mais


recentes. A janela ativa permanece ativa

Visualização 62
OPÇÃO DESCRIÇÃO
5 Ativa a janela e mostra-a com seu tamanho e posição
atuais

6 Minimiza a janela e ativa a próxima janela de nível


superior

7 Mostra a janela minimizada. A janela ativa permanece


ativa

8 Mostra a janela em seu estado atual. A janela ativa


permanece ativa

9 Ativa e mostra a janela. Se a janela estiver maximizada ou


minimizada, ela é restaurada para o tamanho e posição
originais. Uma aplicação deve especificar este valor
quando estiver restaurando uma janela que estava
minimizada

Exemplo:
Sub CommandButton1_Click()
Dim ret
Application.ExecuteExternalApp "calc.exe", "", "", 1, ret
Application.GetObject("Dados.TagInterno1").Value = ret
End Sub

NOTA
O parâmetro retornado em ProcessID pode ser 0 (zero), caso nenhum processo tenha sido iniciado. Por exemplo, se
um documento aberto é uma URL e uma instância do Internet Explorer já estiver executando, esta instância mostra o
documento. Nenhum processo novo é iniciado, portanto ProcessID é 0 (zero).

4.1.2.7 Exit
Exit()
Este método fecha a janela do E3 Viewer. Exemplo:
Sub_Botao1.Click()
Application.Exit()
EndSub

4.1.2.8 GetFormulaUnitDataObj
GetFormulaUnitDataObj(FormulaName)
Este método obtém a configuração das Unidades existentes em uma determinada Fórmula. As Unidades são o destino
dos dados salvos na Fórmula, ou valores. Este método possui o parâmetro FormulaName, que é o nome da Fórmula.
Utilize este método para obter uma coleção das Unidades de uma Fórmula. Este método retorna Verdadeiro se
conseguir realizar a operação ou Falso, caso não consiga. Exemplo:
Sub Botao1_Click()
Dim val
' Quando clica no botão, mostra uma caixa de
' mensagem(MessageBox) com o número de Units
' e o nome da primeira Unit
Set obj = Application.GetFormulaUnitDataObj("Formula1")
MsgBox CStr(obj.Count)
MsgBox CStr(obj.Name(1))
End Sub

4.1.2.9 GetFormulaValueDataObj
GetFormulaValueDataObj(FormulaName)
Este método obtém a configuração dos valores existentes em uma determinada Fórmula. Os valores são o conjunto
de dados salvos na Fórmula. Este método possui o parâmetro FormulaName, que é o nome da Fórmula.
Utilize este método para obter uma coleção de valores na Fórmula. Este método retorna Verdadeiro se conseguir
realizar a operação ou Falso, caso não consiga. Exemplo:

63 Visualização
Sub Botao1_Click()
Dim val
' Quando clica no botão, mostra uma caixa de mensagem
' (MessageBox) com o número de Conjuntos
' e o nome do Primeiro Conjunto.
Set obj = Application.GetFormulaValueDataObj("Formula1")
MsgBox CStr(Obj.Count)
MsgBox CStr(obj.Name(1))
End Sub

4.1.2.10 GetFrame
GetFrame([FrameName], [CreateNew])
Este método procura por um objeto Divisor que já esteja aberto no E3 Viewer atual. Este método possui os
parâmetros FrameName, que é opcional e determina o nome do Quadro a ser buscado, e CreateNew, que também é
opcional e determina se é necessário criar uma nova janela caso o Quadro não seja encontrado. Caso o valor
especificado em FrameName seja omitido ou uma String vazia, retorna um Quadro que contém todos os Divisores ou
a Tela ativa no momento. Caso o parâmetro CreateNew seja omitido ou configurado como Verdadeiro, uma nova
janela é criada. Com o retorno deste método, utilize os métodos do Divisor, como por exemplo o método
OpenScreen, para abrir uma outra Tela. Exemplo:
Sub Botao1_Click()
' Ao clicar neste Botão, recebe o Quadro 'Menu'
' e substitui a Tela atual deste Quadro pela Tela 'Opções'
Set novoQuadro = Application.GetFrame("Menu")
' novoQuadro possui um objeto do tipo Divisor
novoQuadro.OpenScreen "Opções", 0
End Sub

NOTA
Caso o nome passado no parâmetro FrameName se refira a um Quadro não existente e o parâmetro CreateNew seja
configurado como Falso, este método retorna Nothing, ou seja, não retorna nenhum Quadro.

4.1.2.11 GetFullUserName
GetFullUserName()
Este método retorna o nome completo do usuário logado no E3. Caso não haja nenhum usuário logado, retorna uma
String vazia.

4.1.2.12 GetKeyPad
GetKeyPad()
Retorna uma referência para o objeto Elipse KeyPad, permitindo manipular um teclado virtual flutuante em aplicações
desenvolvidas com o E3. Consulte o Manual do Usuário do E3 para mais informações sobre este objeto. Os métodos
e propriedades do Elipse KeyPad estão descritos no capítulo ActiveX - Elipse KeyPad.

4.1.2.13 GetMouseX
GetMouseX()
Retorna a coordenada X do ponteiro do mouse, em pixels, referente à área total da tela do computador.

NOTA
Este método falha em um script se a posição atual do ponteiro do mouse não puder ser determinada. Uma das
situações onde esta falha pode ser verificada é o caso de estar aberta a janela de Logon do Windows, ou seja, ao
pressionar o atalho de teclado CTRL + ALT + DEL. Este comportamento de impedir o acesso à posição atual do
ponteiro do mouse é padrão do Windows em algumas situações e não pode ser contornado. Sugere-se utilizar o
comando On Error Resume Next antes da utilização deste método, para evitar erros de script.

4.1.2.14 GetMouseY
GetMouseY()
Retorna a coordenada Y do ponteiro do mouse, em pixels, referente à área total da tela do computador.

Visualização 64
NOTA
Este método falha em um script se a posição atual do ponteiro do mouse não puder ser determinada. Uma das
situações onde esta falha pode ser verificada é o caso de estar aberta a janela de Logon do Windows, ou seja, ao
pressionar o atalho de teclado CTRL + ALT + DEL. Este comportamento de impedir o acesso à posição atual do
ponteiro do mouse é padrão do Windows em algumas situações e não pode ser contornado. Sugere-se utilizar o
comando On Error Resume Next antes da utilização deste método, para evitar erros de script.

4.1.2.15 GetScreen
GetScreen(ScreenName)
Este método retorna um objeto Tela, cujo nome deve ser especificado no parâmetro ScreenName. O valor de retorno
deste método pode ser utilizado no método ShowScreen do objeto Divisor.

4.1.2.16 GetTrendAnalysis
GetTrendAnalysis([Title])
Retorna um objeto que permite configurar a janela do TrendAnalysis. O parâmetro Title indica um título, opcional, para
a janela do TrendAnalysis. Caso este parâmetro seja omitido, a janela do TrendAnalysis recebe a expressão
"TrendAnalysis". Em um script, deve-se utilizar este método da seguinte forma:
Sub
Set TA = Application.GetTrendAnalysis("TrendAnalysis Window")
End Sub

Para mais informações sobre propriedades e métodos deste objeto, consulte o tópico TrendAnalysis.

4.1.2.17 GetValue
GetValue(TagName)
Este método busca pelo valor de um objeto especificado no parâmetro TagName. Se TagName apontar para uma
propriedade, este método retorna o valor da propriedade. Se por outro lado o parâmetro TagName especificar um
objeto, o método retorna o valor da propriedade Value do objeto. Exemplo:
Sub Botao1_Click()
' Ao clicar no Botão,
' recupera o valor de um Tag
' sendo executado em um Servidor de Dados
X = Application.GetValue("Dados1.TagInterno1")
End Sub

4.1.2.18 IsAppRunning
IsAppRunning(ProcessId)
Indica se uma aplicação iniciada pelo método ExecuteExternalApp está em execução. Retorna Verdadeiro se a
aplicação identificada no sistema operacional por ProcessId está em execução. Caso contrário, retorna Falso. Exemplo:
Sub CommandButton1_Click()
Application.ExecuteExternalApp _
"www.elipse.com.br", "", "", 1, processID
While Application.IsAppRunning(processID)
' Espera pelo final da aplicação
Wend
MsgBox "Terminou a aplicação!"
End Sub

NOTA
O parâmetro ProcessId é o mesmo valor que aparece no Gerenciador de Tarefas do Windows, na coluna PID.

4.1.2.19 IsUserMemberOfGroup
IsUserMemberOfGroup(GroupName, [UserName])
Este método verifica se um usuário pertence a um determinado grupo. Possui os seguintes parâmetros:
· GroupName: Nome do grupo de usuários que se quer verificar
· UserName: Nome do usuário que se quer verificar. Se este parâmetro é omitido ou é igual a uma String vazia, o
método considera o usuário atualmente logado no E3 Viewer

65 Visualização
Este método retorna Verdadeiro se o usuário pertencer ao grupo indicado por GroupName ou Falso caso contrário.

4.1.2.20 IsWebViewer
IsWebViewer()
Verifica se a aplicação está sendo visualizada pelo WebViewer. O método retorna Verdadeiro se a aplicação estiver
sendo executada no WebViewer. Caso contrário, retorna Falso.

4.1.2.21 LoadFormulaDlg
LoadFormulaDlg(FormulaName, [UnitName], [ValueName])
Este método abre uma caixa de diálogo que exibe as Unidades e os Conjuntos de Valores configurados em uma
Fórmula (FormulaName), permitindo ao usuário selecionar o Conjunto de Valores e a Unidade em que este Conjunto é
carregado.
Os parâmetros opcionais UnitName e ValueName são variáveis que recebem, respectivamente, o nome da Unidade e
o nome do Conjunto de Valores carregados na Fórmula. A caixa de diálogo da figura a seguir é mostrada como
resultado da chamada a este método no código de exemplo que segue. Este método retorna um valor Booleano
indicando se foi executado com sucesso ou não.

Caixa de diálogo do método LoadFormulaDlg


Sub Botao1_Click()
NomeFormula = "Formula1"
If Application.LoadFormulaDlg(NomeFormula, NomeUnidade, ConjuntoValores) Then
MsgBox "O Conjunto de Valores " & ConjuntoValores & " foi carregado na Unidade " &
NomeUnidade
Else
MsgBox "Falha ao carregar a Fórmula " & NomeFormula
End If
End Sub

4.1.2.22 LoadFormulaValues
LoadFormulaValues(FormulaName, UnitName, ValueName)
Este método carrega automaticamente um Conjunto de Valores para uma Unidade de destino, apresentando uma
caixa de diálogo que permite ao usuário informar valores diferentes daqueles definidos na Fórmula. Este método
possui os parâmetros FormulaName, que determina o nome da Fórmula, UnitName, que determina o nome da
Unidade e ValueName, que determina o nome do Conjunto de Valores.
Uma caixa de mensagem aparece permitindo ao usuário informar valores diferentes daqueles definidos para cada um
dos valores da Fórmula.

NOTA
O método retorna um valor lógico, ou seja, retorna Verdadeiro quando é executada com sucesso e Falso quando
falha, o que não significa que houve um erro no script.

Visualização 66
Exemplo:
Sub Botao1_Click()
Application.LoadFormulaValues "Formula1",
"Unidade1", "Valor1"
End Sub

4.1.2.23 LoadFormulaValuesQuiet
LoadFormulaValuesQuiet(FormulaName, UnitName, ValueName)
Carrega um Conjunto de Valores para uma Unidade de destino, sem apresentar nenhuma mensagem. Este método
possui os parâmetros FormulaName, que determina o nome da Fórmula, UnitName, que determina o nome da
Unidade e ValueName, que determina o nome do Conjunto de Valores. Exemplo:
Sub Botao1_Click()
Application.LoadFormulaValuesQuiet "Formula1",_
"Unidade3", "Valor1"
End Sub

NOTA
Este método também está acessível através do objeto Fórmula.

4.1.2.24 LoadReport
LoadReport(ReportName)
Carrega um modelo de Relatório. O parâmetro ReportName é o nome do Relatório a ser carregado. Exemplo:
Sub Rect_Click()
' Carregando o relatório pré-definido
Set strRep = Application.LoadReport("[Relatório3]")
strRep.PrintPreview ' Visualizando a impressão
End Sub

4.1.2.25 Login
Login([Mode], [PosX], [PosY], [WindowsShowLastCredentials])
Abre uma caixa de diálogo para o login, ou autenticação de usuário, na aplicação. O usuário logado permanece na
memória até que seja realizado outro login ou logout, ou saída do usuário da aplicação. Os parâmetros deste método,
todos opcionais, são os seguintes:
· Mode: Um Booleano que determina se uma mensagem de confirmação ou falha da operação deve ser mostrada.
Se este parâmetro é omitido, a mensagem de confirmação ou falha de operação não é mostrada. Quando uma
Tela estiver para ser aberta, através do método OpenScreen, este método verifica se existe alguma configuração
de segurança. Caso exista, a Tela só é aberta se o usuário logado tem permissão. Caso não tenha permissão,
abre-se uma caixa de diálogo para o login
· PosX: Indica a posição, em pixels, da caixa de diálogo em relação à margem esquerda da janela. Caso este
parâmetro seja omitido, a respectiva coordenada da caixa de diálogo é centralizada na janela
· PosY: Indica a posição, em pixels, da caixa de diálogo em relação à margem superior da janela. Caso este
parâmetro seja omitido, a respectiva coordenada da caixa de diálogo é centralizada na janela
· WindowShowLastCredentials: Um Booleano que indica se, ao selecionar a autenticação pelo Windows, os
campos de usuário e senha são completados com o usuário atualmente logado no Windows. Se este parâmetro é
omitido, os campos de usuário e senha são completados

NOTA
Caso ambos os parâmetros PosX e PosY sejam omitidos, a caixa de diálogo é centralizada na janela.

4.1.2.26 LoginUser
LoginUser(Username, UserPassword, [OpStatus], [WarnDaysToExpire])
Executa uma operação de login de um usuário específico sem mostrar nenhuma mensagem. O parâmetro Username é
o nome do usuário e o parâmetro UserPassword é a senha deste usuário. O parâmetro opcional de retorno OpStatus é
um mapa de bits que indica o status desta operação e o parâmetro opcional de retorno WarnDaysToExpire indica o
número de dias para que a senha em UserPassword expire. Este método retorna um Booleano indicando se a

67 Visualização
operação falhou ou não. Consulte as tabelas a seguir para mais informações sobre os valores possíveis em caso de
falha.

NOTA
Este método só está disponível se o usuário logado é um usuário do Domínio do E3.

Valores de retorno possíveis para o parâmetro OpStatus


VALOR DESCRIÇÃO
0x000000 Nenhum erro

0x000001 Erro não especificado

0x000002 Usuário ou senha incorretos

0x000004 A senha atual deve ser alterada

0x000008 A senha atual expirou

0x000010 A conta deste usuário está bloqueada

0x000020 A conta deste usuário está desabilitada

0x000040 O servidor RPC não está disponível

0x000080 Modo de autenticação não suportado

0x001000 Senha não informada

0x002000 Este usuário não tem permissão para alterar a senha

0x004000 A senha informada não é alfanumérica

0x008000 A senha informada não possui letras maiúsculas e


minúsculas

0x010000 A senha informada é muito curta

0x020000 A senha informada não possui a quantidade mínima de


números

0x040000 A senha informada não possui a quantidade mínima de


letras

0x080000 A senha informada não possui a quantidade mínima de


caracteres especiais

0x100000 A senha informada é igual ao nome do usuário

0x200000 A senha informada foi utilizada recentemente

0x400000 A senha atual não atingiu a idade mínima

Valores de retorno possíveis para o parâmetro WarnDaysToExpire


VALOR DESCRIÇÃO
-1 (menos um) A senha está fora do intervalo de expiração ou nunca
expira

0 (zero) A senha expira hoje

n A senha expira daqui a n dias dentro do intervalo de


expiração configurado

4.1.2.27 LoginWindowsUser
LoginWindowsUser([UserName], [UserPassword], [OpStatus])
Este método executa uma operação de login utilizando um usuário do Windows sem mostrar nenhuma mensagem. O
parâmetro opcional UserName é o nome do usuário e o parâmetro opcional UserPassword é a senha deste usuário. O
parâmetro de retorno opcional OpStatus é um mapa de bits que indica o status desta operação. Este método retorna

Visualização 68
um Booleano indicando se a operação falhou ou não. Consulte a tabela Valores de retorno possíveis para o
parâmetro OpStatus no método LoginUser para mais informações sobre os valores possíveis em caso de falha. Caso
o nome do usuário seja omitido, a operação de login é executada com o usuário corrente do Windows.

4.1.2.28 Logout
Logout([Mode])
Executa o logout, ou saída do usuário atual da aplicação, do E3 Viewer. Caso não haja um usuário logado, este
método não tem efeito. A partir deste momento, considera-se que um usuário anônimo está utilizando a aplicação.
Pode-se utilizar o evento OnLogout para executar um script para ir para a Tela inicial ou finalizar a aplicação. Este
método possui o parâmetro opcional Mode, que é um Booleano que determina se uma mensagem de confirmação ou
falha da operação deve ser mostrada. Se este parâmetro é omitido, a mensagem de confirmação ou falha de
operação não é mostrada.

4.1.2.29 PasswordConfirm
PasswordConfirm([Mode], [PosX], [PosY])
Este método abre uma caixa de diálogo solicitando a reconfirmação da senha do usuário atualmente logado. Retorna
Verdadeiro se a senha é confirmada ou Falso caso contrário. O parâmetro opcional Mode determina se deve ser
executado um logout em caso de falha na confirmação (Verdadeiro) ou não (Falso). Se omitido, não é executado um
logout em caso de falha de confirmação. O parâmetro opcional PosX indica a posição, em pixels, da caixa de diálogo
em relação à margem esquerda da janela. Caso este parâmetro seja omitido, a respectiva coordenada da caixa de
diálogo é centralizada na janela. O parâmetro opcional PosY indica a posição, em pixels, da caixa de diálogo em
relação à margem superior da janela. Caso este parâmetro seja omitido, a respectiva coordenada da caixa de diálogo
é centralizada na janela. Caso os valores indicados nos parâmetros PosX e PosY posicionem a caixa de diálogo fora da
área visível da janela, estes valores são ajustados automaticamente para garantir que a caixa de diálogo esteja visível.

Confirmação de senha
Se a caixa de diálogo é fechada clicando em Cancelar, este método retorna Falso. Caso não haja usuário logado, este
método retorna Falso, mas sem abrir a caixa de diálogo. Caso a senha digitada não esteja correta, a solicitação é
repetida até no máximo três vezes. Se o usuário digitar a senha incorreta nestas três vezes, a caixa de diálogo é
fechada e este método retorna Falso.

NOTA
Este método só está disponível se o usuário logado é um usuário do Domínio do E3.

4.1.2.30 Playsound
Playsound(FileName)
Executa um arquivo de som cujo caminho e nome estão indicados no parâmetro FileName. O arquivo deve ter as
seguintes especificações:
· Deve estar no formato de som do Windows, com a extensão .wav
· Se o arquivo estiver no projeto, adicionado através do comando Inserir recurso, o nome do arquivo deve estar
entre colchetes
· Se foi criada uma pasta no projeto e o arquivo foi adicionado através do comando Inserir recurso, o caminho
deve ser especificado entre aspas, como por exemplo "c:\som\ding.wav". Se o arquivo estiver no diretório local, o
nome não precisa de aspas, apenas o caminho, como por exemplo c:\som\ding.wav

69 Visualização
Exemplo:
Sub TelaInicial_OnAlarm()
' Se existir um alarme ativo, executa um som de alerta.
' Quando o alarme é reconhecido, o som para.
Set Alarme = Application._
GetObject("ConfigAlarmes1.Area1.FonteAlarme1")
If Alarme.ActiveNACKAlarms = True Then
Application.PlaySound("[ringin.wav]")
End If
End Sub

4.1.2.31 SelectMenu
SelectMenu(Menu, [Left], [Top])
Este método mostra um menu contextual conforme especificado pelo parâmetro Menu. Este parâmetro é um texto que
consiste em várias opções delimitadas pela barra vertical (|), sendo que cada uma destas Strings é uma opção do
menu. Caso haja um conjunto de dois delimitadores sucessivos (||), um separador é inserido. Use os caracteres de
abre e fecha chaves para criar um submenu. Um asterisco na frente de uma String indica que a opção está marcada.
Já um sinal de exclamação indica que a opção está desabilitada.
A posição da caixa de diálogo pode ser configurada através dos parâmetros opcionais Left e Top, que indicam a
distância da margem esquerda e do topo da Tela em pixels, respectivamente. Caso estes parâmetros não sejam
informados, o menu é posicionado de acordo com o local onde o clique do mouse foi acionado.
Este método retorna 0 (zero) se nenhuma opção foi selecionada, ou o número da opção, sendo 1 (um) a primeira
opção contida no texto, 2 (dois) a segunda opção, e assim por diante. Exemplo:
Sub Botao1_Click()
op = _
Application.SelectMenu(_
"Opção1||Opção2{*Opção2|Opção3}|Opção4|!Opção5")
If op = 1 Then
MsgBox "Opção 1 foi escolhida"
ElseIf op = 2 Then
MsgBox "Opção 2 foi escolhida"
ElseIf op = 3 Then
MsgBox "Opção 3 foi escolhida"
ElseIf op = 4 Then
MsgBox "Opção 4 foi escolhida"
ElseIf op = 0 Then
MsgBox "Nenhuma opção foi escolhida"
End If
End Sub

4.1.2.32 SetValue
SetValue(TagName, NewVal)
Este método configura o valor de um objeto dentro do servidor. Este método procura por um objeto ou propriedade
em execução no servidor e atribui o valor especificado no parâmetro definido em TagName. O tipo e o valor do
parâmetro NewVal devem ser suportados pelo objeto especificado em TagName. Exemplo:
Sub Botao1_Click()
' Ao clicar em Botao1, atribui o valor 20
' para a propriedade Value do Tag
Application.SetValue "Dados1.TagInterno1", 20
End Sub

4.1.2.33 ShowDatePicker
ShowDatePicker(DateValue, [Left], [Top], [DefaultDate])
Abre uma caixa de diálogo para a alteração da data e da hora. Este método retorna Verdadeiro se o usuário
confirmar a data ou Falso se o usuário cancelar a edição. A nova data é retornada no parâmetro DateValue. A posição
da caixa de diálogo pode ser configurada através dos parâmetros opcionais Left e Top, que indicam a distância da
margem esquerda e do topo da tela em pixels, respectivamente. Caso estes parâmetros não sejam informados, a
caixa de diálogo é centralizada. O valor do parâmetro opcional DefaultDate é a data e a hora do momento em que a
caixa de diálogo é aberta. Se não é informada a data, assume a data atual. Se não é informada a hora, inicia como
"00:00:00". Se nem a data nem a hora são informadas, inicia com a data e a hora atuais. Exemplo:
Sub Texto2_Click()
Dim novaHora
Application.ShowDatePicker novaHora, 300, 300

Visualização 70
MsgBox "A hora é: " & novaHora
End Sub

4.1.2.34 ShowFilePicker
ShowFilePicker(Open, Filename, [Extension], [Flags], [Filter])
Exibe as caixas de diálogo Salvar e Abrir Arquivo do Windows. O parâmetro Open indica o tipo de caixa de diálogo a
ser aberta. Se Verdadeiro, abre a caixa de diálogo Abrir Arquivo. Se Falso, abre a caixa de diálogo Salvar. O
parâmetro FileName indica a variável onde é armazenado o nome do arquivo a ser salvo ou carregado, caso o
método retorne Verdadeiro. Este parâmetro deve ser obrigatoriamente uma variável. O parâmetro Extension é
opcional e informa a extensão do arquivo padrão a ser anexada ao nome do arquivo na caixa de entrada, quando a
extensão não é informada. Caso seja omitido ou seja uma String vazia, nenhuma extensão é concatenada ao final do
nome do arquivo. Extensões múltiplas podem ser especificadas usando-se o caractere de ponto e vírgula como
delimitador. A String deve terminar com barras duplas verticais (||).
O parâmetro Flags é opcional e define o comportamento da caixa de diálogo. É um número inteiro correspondendo à
soma dos valores da tabela a seguir. Se omitido, assume o valor 2 (dois, FILEMUSTEXIST). O parâmetro Filter é
opcional e define um conjunto de pares de Strings que especificam filtros que podem ser aplicados aos arquivos. A
primeira String descreve o filtro e a segunda String indica o tipo de extensão a ser utilizada. Se omitido, nenhum filtro
é aplicado aos arquivos.
Combinações possíveis para o parâmetro Flags
VALOR DESCRIÇÃO
1 CREATEPROMPT: Se o usuário especificar um arquivo
que não existe, este flag permite que seja questionado
sobre a criação do arquivo. Se selecionar criar o arquivo,
a caixa de diálogo é fechada e o nome do arquivo é
retornado no parâmetro Filename. Caso contrário, a caixa
de diálogo permanece aberta

2 FILEMUSTEXIST: Especifica que o usuário só pode


digitar nomes de arquivos existentes. Caso contrário, a
caixa de diálogo mostra um aviso na caixa de mensagens

4 NOCHANGEDIR: Recupera o diretório atual para o valor


original caso o usuário tenha mudado de diretório
enquanto buscava o arquivo

8 NODEREFERENCELINKS: Configura a caixa de diálogo


para retornar o arquivo de atalho (.lnk) selecionado. Se
este flag não é especificado, a caixa de diálogo retorna o
caminho e nome de arquivo referenciados pelo arquivo
de atalho

16 NOREADONLYRETURN: Determina que o arquivo


retornado não seja somente para leitura, e o diretório
não é protegido contra gravação

32 PATHMUSTEXIST: Especifica que o usuário pode


informar apenas arquivos e diretórios válidos, caso
contrário uma caixa de mensagem é mostrada para
avisar o usuário

64 READONLY: Permite que a opção Somente Leitura seja


selecionada inicialmente quando a caixa de diálogo é
criada

128 OVERWRITEPROMPT: Permite que a caixa de diálogo


Salvar Como gere uma mensagem informando da
existência do arquivo, e pede confirmação para
sobrescrever o arquivo

Exemplo de filtro:
"Arquivos de Chart (*.xlc)|*.xlc|Planilhas Excel (*.xls)_
|*.xls|Arquivos de Dados (*.xlc;*.xls)|*.xlc; *.xls
|Todos os arquivos (*.*)|*.*||"

71 Visualização
4.1.2.35 ShowPickColor
ShowPickColor(ColorValue, [Color], [Left], [Top])
Abre a caixa de diálogo Cores do Windows para selecionar uma cor. O valor decimal da cor selecionada é retornado
no parâmetro ColorValue. O parâmetro opcional Color indica uma cor previamente selecionada na paleta de cores. Se
este parâmetro não é informado, assume o valor 0 (zero, preto). A posição da caixa de diálogo pode ser configurada
através dos parâmetros opcionais Left e Top, que indicam respectivamente a distância da margem esquerda e do topo
da tela, em pixels. Caso estes parâmetros não sejam informados, a caixa de diálogo é centralizada. Exemplo:
Sub CommandButton_Click()
Dim novaCor
Dim corPadrao
corPadrao = 65280 ' Verde Claro
If Application.ShowPickColor(novaCor, corPadrao, 90, 90) Then
Screen.Item("Retangulo1").ForegroundColor = novaCor
Screen.Item("Texto1").Value = novaCor
End If
End Sub

4.1.2.36 ShowTrendAnalysis
ShowTrendAnalysis([Title], [Left], [Top], [Configuration], [ConfigStatus], [ErrorDetails])
Mostra uma janela do TrendAnalysis. Este método retorna Verdadeiro se a janela foi mostrada corretamente ou Falso
em caso de erro. Os parâmetros deste método estão listados na tabela a seguir.
Parâmetros do método ShowTrendAnalysis
PARÂMETRO DESCRIÇÃO
Title Determina o título da janela. Corresponde à propriedade
Title do objeto TrendAnalysis. Se omitido ou informada
uma String vazia, o título da janela é configurado para
"TrendAnalysis"

Left Coordenada horizontal da janela, em pixels. Consulte o


método SetWindowPlacement do objeto TrendAnalysis
para mais informações sobre o comportamento deste
parâmetro, caso seja omitido

Top Coordenada vertical da janela, em pixels. Consulte o


método SetWindowPlacement do objeto TrendAnalysis
para mais informações sobre o comportamento deste
parâmetro, caso seja omitido

Configuration Informa o conteúdo de uma configuração salva pelo


método Save do objeto TrendAnalysis. Se omitido ou
informada uma String vazia, não carrega nenhuma
configuração previamente salva

ConfigStatus Parâmetro opcional de retorno que informa o resultado


do carregamento da janela do TrendAnalysis. Se este
método retorna Verdadeiro, este parâmetro contém o
valor 0 (zero), ou seja, a configuração foi carregada com
sucesso. Se este método retorna Falso, este parâmetro
pode conter os valores 1: A configuração não carregou
corretamente, 2: O conteúdo da configuração é inválido
ou 3: Esta configuração requer uma versão mais recente

ErrorDetails Parâmetro opcional de retorno contendo uma String


detalhando o erro no carregamento da janela do
TrendAnalysis

Exemplo de uso:
Sub Botao1_Click()
Dim showResult, errorMsg, errorDetails
showResult = Application.ShowTrendAnalysis("TrendAnalysis", 100, 100, "", ConfigStatus,
errorDetails)
If showResult = False Then

Visualização 72
If ConfigStatus <> 0 Then
Select Case ConfigStatus
Case 1
errorMsg = "Erro (1): A configuração não foi carregada corretamente."
Case 2
errorMsg = "Erro (2): O conteúdo da configuração é inválido."
Case 3
errorMsg = "Erro (3): Esta configuração requer uma versão mais recente."
End Select
errorMsg = errorMsg & vbCrLf & "Detalhes: " & errorDetails
MsgBox errorMsg
End If
End If
End Sub

NOTA
As propriedades do objeto TrendAnalysis podem ser configuradas no objeto retornado pelo método
GetTrendAnalysis.

4.1.2.37 Stopsound
Stopsound()
Para um som que esteja executando.

4.1.2.38 ToggleValue
ToggleValue(TagName, ValA, ValB)
Este método busca o valor do objeto ou propriedade em execução no servidor e compara com os parâmetros ValA e
ValB. Se o valor buscado é igual a ValB, o objeto ou propriedade especificado em TagName recebe o valor de ValA.
Caso contrário, recebe o valor de ValB. Caso o valor de TagName não seja nem ValA nem ValB, este método atribui o
valor especificado em ValA. Exemplo:
Sub Botao1_Click()
' Ao clicar no Botão, atribui o valor
' a um Tag sendo executado em um Servidor de Dados.
' Atribui o valor 20 para o Tag.
Application.SetValue "Dados1.TagInterno1", 20
' Já que o valor do TagInterno1 já é 20,
' o método ToggleValue alterna o valor para 30.
Application.ToggleValue "Dados1.TagInterno1", 30, 20
End Sub

4.1.2.39 Trace
Trace(MessageText, [LogTimeStamp], [BreakLine])
Este método permite registrar mensagens no log do E3. Este método pode ser usado, por exemplo, para registrar
mensagens de depuração de scripts executados no Viewer.
Parâmetros do método Trace
PARÂMETRO DESCRIÇÃO
MessageText Mensagem definida pelo usuário

LogTimeStamp Booleano que indica se cada registro deve ter a data e a


hora (timestamp). Este parâmetro é opcional e é
ignorado no E3 Viewer

BreakLine Booleano que indica a presença ou não de uma quebra


de linha ao final de cada mensagem. Este parâmetro é
opcional e é ignorado no E3 Viewer

4.1.2.40 TrackEvent
TrackEvent(EventMessage, [Comment], [EventTimeStamp])
Este método permite gerar eventos via script manualmente. Estes eventos podem ser gerados tanto no E3 Viewer
quanto no Servidor, e são registrados em uma tabela no banco de dados da aplicação.

73 Visualização
Parâmetros do método TrackEvent
NOME DESCRIÇÃO
EventMessage Contém a mensagem do evento, com um máximo de 200
caracteres

Comment Contém comentários adicionais sobre o evento, com um


máximo de 200 caracteres. Este parâmetro é opcional e,
se omitido, assume uma String vazia

TimeStamp Indica a data e hora em que o evento ocorreu. Este


parâmetro é opcional e, se omitido, o E3 assume a data
e a hora atuais

Este método só registra os eventos caso a opção de Registro de Eventos nas Opções do Domínio esteja habilitada.
Os eventos são registrados em uma tabela de um banco de dados, que é definida também nas configurações de
Registro de Eventos.
Para mais informações sobre o Registro de Eventos do Domínio, consulte o Manual do Usuário do E3. Exemplo:
Sub Button1_Click()
Dim Tag, User, Comment
Set Tag = Application.GetObject("IO.Inputs.I001")
If Application.ESign(Tag.PathName, , "Alteração do Valor", _
Tag.Value, 1, User, Comment) Then
If Tag.WriteEx(1) Then
Application.TrackEvent _
"Tag IO.Inputs.I001 alterado para 1 " &_
"pelo usuário" & User, Comment
End If
End If
End Sub

4.1.2.41 UserAdministration
UserAdministration([PosX], [PosY], [ShowMergeErrorsOnExit], [MergeDetails])
Este método abre uma caixa de diálogo que permite editar a lista de usuários do Servidor. As funções disponíveis são
as seguintes:
· Mostrar a lista de todos os usuários
· Excluir usuários (não é possível excluir o usuário atual)
· Adicionar e editar usuários
· Editar as configurações de um usuário
· Alterar a senha de um usuário
· Alterar os demais dados de um usuário, tais como login e nome

Este método possui os seguintes parâmetros:


· PosX: Parâmetro opcional que indica a posição, em pixels, da caixa de diálogo em relação à margem esquerda
da janela
· PosY: Parâmetro opcional que indica a posição, em pixels, da caixa de diálogo em relação à margem superior da
janela
· ShowMergeErrorsOnExit: Parâmetro Booleano opcional que indica se deve ser mostrada uma janela com os
erros durante a execução deste método. Caso este parâmetro seja omitido, nenhuma janela é mostrada ao final
da execução
· MergeDetails: Parâmetro opcional de saída contendo uma String com os erros acontecidos durante a execução
deste método

Caso os parâmetros PosX e PosY sejam omitidos, a respectiva coordenada da caixa de diálogo é centralizada na
janela, e caso algum dos valores destes parâmetros posicionem a caixa de diálogo fora da área visível da janela, os
valores são automaticamente ajustados para garantir que a caixa de diálogo esteja visível.
Este método retorna Verdadeiro se não houve nenhum problema na edição e Falso caso contrário. O código a seguir
contém um exemplo de uso deste método.
Sub CommandButton_Click()
'Variáveis para receber o resultado

Visualização 74
'e os erros de execução
Dim retorno, erro
retorno = Application.UserAdministration( , , False, erro)
If Not retorno Then
MsgBox "Erros na edição de usuários: " & erro
End If
End Sub

IMPORTANTE
Apenas o Administrador pode ter acesso a este método. A caixa de diálogo de configuração dos usuários é
acessível somente ao usuário habilitado como Administrador.

4.1.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Viewer.

4.1.3.1 AllowContextMenu
Se configurada em Verdadeiro, esta propriedade habilita a exibição do menu contextual das Telas através do botão
direito do mouse em tempo de execução, exceto quando algum script estiver configurado com informação divergente
nos eventos MouseDown ou MouseUp. Caso contrário, o menu contextual não é mostrado. O valor padrão desta
propriedade é Verdadeiro.

NOTA
Em aplicações anteriores à versão 5.1, o comportamento desta propriedade é configurado pela propriedade
EnableZoomMenu, que foi descontinuada. Ao abrir estas aplicações na versão atual, o comportamento anterior é
atualizado para esta propriedade.

4.1.3.2 AllowZoomChange
Esta propriedade habilita a exibição ou não das opções de alteração do nível de zoom no menu contextual das
Telas. O valor padrão desta propriedade é Verdadeiro.

4.1.3.3 BlinkTime
Define o tempo, em milissegundos, entre cada mudança de estado quando um objeto tem que piscar, ou seja, toda
vez que algum objeto de Tela tem uma Associação e é selecionada a opção Piscar. O valor padrão desta propriedade
é 200 ms.

NOTA
O tempo mínimo de atualização da Tela é 55 ms. Portanto, se esta propriedade é configurada com um tempo
inferior, esta configuração não tem efeito algum.

4.1.3.4 CacheEnable
Mantém em memória as Telas já abertas instanciadas no E3 Viewer, permitindo uma troca mais rápida entre estas
Telas. Se esta propriedade está habilitada, então o cache de Telas também é habilitado.

4.1.3.5 Caption
Determina o nome da aplicação que está utilizando o E3 Viewer. O valor padrão desta propriedade é uma String
vazia.

4.1.3.6 CenterWindow
Quando habilitada, determina que a janela de visualização do E3 Viewer deve iniciar centralizada. Caso contrário, é
utilizada a configuração padrão. O valor padrão desta propriedade é Verdadeiro.

4.1.3.7 CloseButton
Se esta propriedade estiver configurada como Verdadeiro, o botão Fechar é habilitado no E3 Viewer, e é possível
utilizar este botão. Caso contrário, este botão não aparece na janela. O valor padrão desta propriedade é Verdadeiro.

75 Visualização
4.1.3.8 CommErrorBkColor
Propriedade utilizada para definir a cor de fundo de um SetPoint quando uma Associação ou Conexão falha. O valor
padrão desta propriedade é vermelho (RGB(255, 0, 0)). Consulte a propriedade EnableCommError para mais
informações. Esta propriedade não pode ser alterada em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.9 CommErrorText
Propriedade utilizada para definir o texto de alerta quando uma Associação ou Conexão falha. O valor padrão desta
propriedade é "???". Consulte a propriedade EnableCommError para mais informações. Esta propriedade não pode
ser alterada em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.10 CommErrorTextColor
Propriedade utilizada para definir a cor do texto de um SetPoint quando uma Associação ou Conexão falha. O valor
padrão desta propriedade é amarelo (RGB(255, 255, 0)). Consulte a propriedade EnableCommError para mais
informações. Esta propriedade não pode ser alterada em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.11 DisableTaskSwitching
Se estiver configurada para Verdadeiro, desabilita a troca de janelas no E3 Viewer. Caso contrário, a troca de
janelas é habilitada. O valor padrão desta propriedade é Falso. Esta propriedade pode ser modificada em tempo de
execução utilizando o método SetDisableTaskSwitching.

4.1.3.12 EnableCommError
Habilita ou desabilita a visualização dos erros de comunicação. Por exemplo, caso haja na Tela um SetPoint
associado a um Tag de Comunicação, e a comunicação do E3 com este Tag falhe, é mostrado no SetPoint o texto
configurado na propriedade CommErrorText, com a cor informada na propriedade CommErrorTextColor e a cor de
fundo do SetPoint definida na propriedade CommErrorBkColor. O valor padrão desta propriedade é Verdadeiro. Esta
propriedade não pode ser alterada em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.13 EnableHeartbeat
Habilita ou desabilita o envio de uma mensagem de heartbeat (enviada em intervalos fixos, que indica que o
servidor está ativo) entre o E3 Viewer e o servidor. Caso o E3 Viewer pare de receber as mensagens de heartbeat, é
sinal de que algum problema ocorreu, portanto a conexão deve ser abortada. O valor padrão desta propriedade é
Falso.

4.1.3.14 EnableInactivity
Habilita ou desabilita a verificação do período de inatividade de um usuário. Para mais informações, consulte o
evento OnInactive do objeto Viewer. O valor padrão desta propriedade é Falso. Esta propriedade não pode ser
alterada com o objeto ativo.

4.1.3.15 HeartbeatPeriodMs
Indica o intervalo, em milissegundos, entre as mensagens de heartbeat enviadas pelo Servidor. A mensagem de
heartbeat sempre é enviada quando o servidor permanece pelo período indicado por esta propriedade sem enviar
nenhuma mensagem para o E3 Viewer. O valor padrão desta propriedade é 2000 (dois segundos).

4.1.3.16 HeartbeatTimeoutMs
Indica o tempo, em milissegundos, que o E3 Viewer tolera sem receber nenhuma mensagem do Servidor. Se este
tempo passar e nenhuma mensagem for recebida, o E3 Viewer assume que a conexão foi perdida e inicia o processo
de reconexão. Este tempo deve ser maior que o tempo determinado na propriedade HeartbeatPeriodMs, de
preferência maior que o dobro. O valor padrão desta propriedade é 5000 (cinco segundos).

4.1.3.17 InactivityTime
Define o tempo máximo de espera por um evento de mouse ou de teclado antes do período de inatividade, em
minutos. Para mais informações, consulte o evento OnInactive do objeto Viewer. O valor padrão desta propriedade é
5 (cinco) minutos. Exemplo:
Sub CommandButton3_Click()
MsgBox "A aplicação ficará inativa em " & _

Visualização 76
Application.InactivityTime & " minuto(s)."
End Sub

4.1.3.18 InitialScreen
Indica a Tela ou Quadro inicial que deve ser mostrado quando o E3 Viewer é aberto. Através da propriedade
WindowStyle é possível determinar se a janela deve iniciar maximizada, janelada ou minimizada. O valor padrão
desta propriedade é "TelaInicial". Para utilizar esta propriedade em scripts, consulte a propriedade SplitLink do
Divisor para mais informações sobre o formato para especificar uma Tela nesta propriedade.

4.1.3.19 IsPlaybackMode
Se Verdadeiro, indica que o E3 Viewer está em execução dentro de um E3Playback, em modo playback. Esta
propriedade é somente de leitura.

4.1.3.20 IsReadOnly
Se ajustada para Verdadeiro, indica que o E3 Viewer está no modo Somente Leitura (acesso restrito). Esta
propriedade é somente de leitura.

4.1.3.21 LoginRetries
Especifica o número de retentativas de login do E3 Viewer, isto é, quantas vezes a caixa de diálogo de login é
exibida além da primeira vez. O valor padrão desta propriedade é 2 (dois).

4.1.3.22 MaximizeButton
Se esta propriedade estiver configurada como Verdadeiro, o botão Maximizar é habilitado no E3 Viewer e é
possível utilizar este botão. Caso contrário, este botão não aparece na janela. O valor padrão desta propriedade é
Verdadeiro.

4.1.3.23 MinimizeButton
Se esta propriedade estiver configurada como Verdadeiro, o botão Minimizar é habilitado no E3 Viewer e é
possível utilizar este botão. Caso contrário, este botão não aparece na janela. O valor padrão desta propriedade é
Verdadeiro.

4.1.3.24 Params
Esta propriedade é um vetor de pares chave-valor, que retorna os parâmetros passados para o E3 Viewer através
da opção de linha de comando -params. Todos os valores são retornados como Strings. Por exemplo, se a linha de
comando do E3 Viewer contiver os seguintes parâmetros:
Viewer -params Idioma=PTB

Pode-se utilizar o seguinte código para verificar qual o idioma de inicialização do E3 Viewer.
Sub TelaInicial_OnStartRunning()
Select Case Application.Params("Idioma")
Case "PTB"
Item("Texto1").Value = "Português do Brasil"
Case Else
Item("Texto1").Value = "Idioma não reconhecido"
End Select
End Sub

NOTA
A String da chave não diferencia entre maiúsculas e minúsculas, pode ser tanto "idioma" quanto "Idioma", mas os
valores retornados, principalmente se utilizados com um comado Select, diferenciam entre maiúsculas e minúsculas.

4.1.3.25 ProductString
Esta propriedade contém uma String com o nome do produto e a versão do E3 Viewer, como por exemplo "E3
6.1.101". Esta propriedade é somente de leitura.
Note que o E3 Viewer pode acessar um objeto no Servidor e recuperar a propriedade ProductString daquele
Servidor, conforme o exemplo a seguir.
Set servidor = Application.GetObject("ServidorDados").Application
MsgBox "Versão do Servidor: " & servidor.ProductString

77 Visualização
No exemplo anterior, considerando-se que o objeto ServidorDados está em um Servidor, o texto mostrado na caixa
de diálogo é "Versão do Servidor: E3 6.1.101" ou "Versão do Servidor: E3 (64-bits) 6.1.101".

4.1.3.26 ProductVersionBuild
Esta propriedade contém o número de build da versão do E3 Viewer. Por exemplo, se a versão instalada é a 6.1.101,
esta propriedade contém o valor 101. Esta propriedade é somente de leitura.

4.1.3.27 ProductVersionMajor
Esta propriedade contém o número principal da versão do E3 Viewer. Por exemplo, se a versão instalada é a
6.1.101, esta propriedade contém o valor 6. Esta propriedade é somente de leitura.

4.1.3.28 ProductVersionMinor
Esta propriedade contém o número secundário da versão do E3 Viewer. Por exemplo, se a versão instalada é a
6.1.101, esta propriedade contém o valor 1. Esta propriedade é somente de leitura.

4.1.3.29 ReconnectDialogDelaySec
Indica o número de segundos que o E3 Viewer espera durante uma possível reconexão ao servidor antes de
mostrar uma mensagem avisando o usuário desta ação (esta propriedade não afeta a primeira conexão). Se for igual
a 0 (zero), a mensagem de reconexão sempre é mostrada. Para evitar que a mensagem seja mostrada, é
recomendável colocar um número muito grande, como por exemplo um bilhão.

NOTA
Quando a reconexão ocorre em silêncio, todas as janelas do E3 Viewer ativo são desabilitadas e uma ampulheta é
mostrada, indicando que o aplicativo está indisponível. Durante o tempo da reconexão, não é permitido ao usuário
cancelar o processo.

4.1.3.30 RenderQuality
Controla a qualidade de desenho de todas as Telas, somente se o valor da propriedade RenderQuality das Telas
é igual a 0 - rqDefault. Os valores possíveis para esta propriedade são os seguintes:
· 0 - rqDefault: Utiliza o modo de qualidade normal, GDI (Graphics Device Interface). Corresponde ao item Utilizar
Padrão do menu contextual Qualidade (todas as telas) do E3 Viewer, em tempo de execução. Este é o valor
padrão para aplicações criadas em versões anteriores à 4.0
· 1 - rqNormal: Força o modo de qualidade normal (GDI) para o desenho de todas as Telas. Corresponde ao item
Forçar Qualidade Normal do menu contextual Qualidade (todas as telas) do E3 Viewer, em tempo de execução
· 2 - rqHighQuality: Força o modo de alta qualidade (GDI+) para o desenho de todas as Telas. Corresponde ao
item Forçar Alta Qualidade do menu contextual Qualidade (todas as telas) do E3 Viewer, em tempo de
execução. Este é o valor padrão para aplicações criadas a partir da versão 4.0

A figura a seguir mostra o menu contextual do E3 Viewer em tempo de execução, com as respectivas opções de
configuração desta propriedade.

Visualização 78
Menu contextual do E3 Viewer em tempo de execução

4.1.3.31 ScreenAlignment
Controla o alinhamento, dado pelo E3 Viewer, para as Telas que não especificam um valor diferente do padrão.
Os valores possíveis para esta propriedade são os seguintes:
· 1 - paTopLeft: Ajusta a Tela ao canto superior esquerdo em relação à área visível. Corresponde à opção Forçar
Superior Esquerdo do menu contextual Alinhamento (Esta Tela) da Tela, em tempo de execução
· 2 - paCenter: Ajusta a Tela ao centro em relação à área visível. Corresponde à opção Forçar Centralizado do
menu contextual Alinhamento (Esta Tela) da Tela, em tempo de execução

A figura a seguir mostra o menu contextual do E3 Viewer em tempo de execução, com as respectivas opções de
configuração desta propriedade.

79 Visualização
Opções da propriedade ScreenAlignment do E3 Viewer em tempo de execução

4.1.3.32 ShowKeyPadOnEdit
Esta propriedade automaticamente habilita a exibição do Elipse KeyPad, sempre que um objeto de Tela que permita
edição receba o foco.

4.1.3.33 TargetDPIX
Define o valor de pontos por polegada, na horizontal, do monitor do computador de destino. O valor padrão desta
propriedade é -1 (menos um), que assume o valor do computador atual. Esta propriedade não pode ser alterada em
tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.34 TargetDPIY
Define o valor de pontos por polegada, na vertical, do monitor do computador de destino. O valor padrão desta
propriedade é -1 (menos um), que assume o valor do computador atual. Esta propriedade não pode ser alterada em
tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.35 TargetMarginX
Define o número de pixels que devem ser descontados da resolução horizontal da Tela (a área útil do E3 Viewer). O
valor padrão da propriedade é -1 (menos um), que assume a configuração da janela do E3 Viewer (com ou sem a
barra de título, com ou sem borda) em conjunto com a configuração do computador atual (largura de borda e barra
de título definidas pelo Windows). Esta propriedade não pode ser alterada em tempo de execução, mesmo que o E3
Viewer esteja inativo.

Visualização 80
4.1.3.36 TargetMarginY
Define o número de pixels que devem ser descontados da resolução vertical da Tela (a área útil do E3 Viewer). O
valor padrão da propriedade é -1 (menos um), que assume a configuração da janela do E3 Viewer (com ou sem a
barra de título, com ou sem borda) em conjunto com a configuração do computador atual (largura de borda e barra
de título definidas pelo Windows). Esta propriedade não pode ser alterada em tempo de execução, mesmo que o E3
Viewer esteja inativo.

4.1.3.37 TargetResolutionX
Define a resolução horizontal da Tela para a qual esta aplicação está destinada, em pixels. O valor padrão desta
propriedade é -1 (menos um), que assume a resolução do computador atual. Esta propriedade não pode ser alterada
em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.38 TargetResolutionY
Define a resolução vertical da Tela para a qual esta aplicação está destinada, em pixels. O valor padrão desta
propriedade é -1 (menos um), que assume a resolução do computador atual. Esta propriedade não pode ser alterada
em tempo de execução, mesmo que o E3 Viewer esteja inativo.

4.1.3.39 TitleBar
Se esta propriedade estiver habilitada, a barra de título do E3 Viewer é mostrada, conforme as especificações da
propriedade Caption. Do contrário, a barra de título é escondida. O valor padrão desta propriedade é Verdadeiro.

4.1.3.40 User
Contém o nome do usuário que está utilizando o E3 Viewer. Esta propriedade é somente de leitura.

4.1.3.41 ViewerLanguageId
Retorna o código do idioma do E3 Viewer em execução. Os valores possíveis para esta propriedade estão descritos
na tabela a seguir. Esta propriedade é somente de leitura.
Valores disponíveis para a propriedade ViewerLanguageId
DECIMAL HEXADECIMAL IDIOMA
4 0x0004 Chinês Simplificado
1031 0x0407 Alemão
1033 0x0409 Inglês Americano
1046 0x0416 Português do Brasil
11274 0x2C0A Espanhol da Argentina

NOTA
Esta propriedade NÃO corresponde ao idioma de instalação do Windows e nem ao idioma configurado no painel
de controle Opções Regionais e de Idioma (Relógio, Idioma e Região no Windows 7) do Windows.

4.1.3.42 WindowBorder
Habilita ou desabilita uma borda na janela do E3 Viewer. O valor padrão desta propriedade é Verdadeiro. Esta
propriedade é de leitura e escrita, mas alterar seu valor em tempo de execução não altera a configuração do E3
Viewer já aberto, apenas das janelas que forem abertas utilizando a configuração do E3 Viewer.

4.1.3.43 WindowHeight
Determina a altura da janela do E3 Viewer, em pixels. O valor padrão desta propriedade é 300.

4.1.3.44 WindowMovable
Indica se a janela pode ser movida. O valor padrão desta propriedade é Verdadeiro. Esta propriedade é de leitura
e escrita, mas alterar seu valor em tempo de execução não altera a configuração do E3 Viewer já aberto, apenas das
janelas que forem abertas utilizando a configuração do E3 Viewer.

81 Visualização
4.1.3.45 WindowResizable
Indica se a janela pode ser redimensionada. Esta propriedade só tem efeito se a propriedade WindowBorder for
Verdadeira. O valor padrão desta propriedade é Verdadeiro. Esta propriedade é de leitura e escrita, mas alterar seu
valor em tempo de execução não altera a configuração do E3 Viewer já aberto, apenas das janelas que forem abertas
utilizando a configuração do E3 Viewer.

4.1.3.46 WindowSmallTitle
Indica se a janela do E3 Viewer deve ter a barra de título pequena. Esta propriedade só tem efeito se a
propriedade TitleBar for Verdadeira. O valor padrão desta propriedade é Falso. Esta propriedade é de leitura e
escrita, mas alterar seu valor em tempo de execução não altera a configuração do E3 Viewer já aberto, apenas das
janelas que forem abertas utilizando a configuração do E3 Viewer.

4.1.3.47 WindowStayOnTop
Indica se a janela do E3 Viewer deve sempre se sobrepor às outras janelas. O valor padrão desta propriedade é
Falso. Esta propriedade é de leitura e escrita, mas alterar seu valor em tempo de execução não altera a configuração
do E3 Viewer já aberto, apenas das janelas que forem abertas utilizando a configuração do E3 Viewer.

4.1.3.48 WindowStyle
Define o estilo inicial de janela do E3 Viewer. As opções disponíveis para esta propriedade são 0 - Maximized:
Inicia o E3 Viewer maximizado (padrão), 1 - Windowed: Inicia o E3 Viewer janelado ou 2 - Minimized: Inicia o E3
Viewer minimizado.

4.1.3.49 WindowWidth
Determina a largura da janela do E3 Viewer, em pixels. O valor padrão desta propriedade é 400.

4.2 Quadros e Divisores


Esta seção contém informações sobre métodos e propriedades do objeto Divisor (FrameSet) e sobre as
propriedades do objeto Quadro (Frame). O objeto Divisor não possui eventos associados e o objeto Quadro não
possui eventos nem métodos associados.

4.2.1 Métodos do Divisor


Esta seção contém informações sobre os métodos do objeto Divisor (FrameSet).

4.2.1.1 BringToFront
BringToFront()
Traz para a frente um Divisor que esteja escondido ou abaixo de outro.

4.2.1.2 CaptureScreen
CaptureScreen(Filename)
Captura o conteúdo de um Divisor, gravando-o no arquivo de nome e caminho Filename, no formato BMP. Exemplo:
Sub CommandButton1_Click()
' Quando o botão é clicado, copia o conteúdo
' do Divisor para o arquivo Frame.bmp.
Screen.Frame.CaptureScreen("c:\temp\frame.bmp")
End Sub

4.2.1.3 Close
Close(Code)
Utilize o método Close para fechar a janela do Quadro. O parâmetro Code tem o valor de retorno para o método
DoModal, se a janela em questão é chamada por este método. Exemplo:
Sub BotaoFecha_Click()
' Ao clicar em BotaoFecha, fecha a janela.
Screen.Close(0)
End Sub

Visualização 82
4.2.1.4 FlashWindow
FlashWindow(Number, Time)
Este método permite que o ícone do E3 Viewer comece a piscar na Área de Notificações do Windows. O parâmetro
Number determina o número de vezes que o ícone deve piscar e Time determina o tempo, em milissegundos, entre
um piscar e outro. Exemplo:
Sub Texto1_Click()
Set quadro = Application.GetFrame("_top")
quadro.FlashWindow 50, 500
End Sub

4.2.1.5 MaximizeFrame
MaximizeFrame()
Maximiza um Quadro ou Tela modal.

4.2.1.6 MinimizeFrame
MinimizeFrame()
Minimiza um Quadro ou Tela modal.

4.2.1.7 MoveFrame
MoveFrame([PosX], [PosY], [SizeX], [SizeY])
Move e redimensiona um Divisor (Frame) para uma coordenada e um tamanho específicos. Os parâmetros PosX e
PosY informam a nova posição, em pixels, com relação à esquerda e ao topo, respectivamente. Os parâmetros SizeX e
SizeY informam o novo comprimento e a nova altura, respectivamente, em pixels ou em Himetric. Todos os parâmetros
são opcionais e, se omitidos, não movem (no caso dos parâmetros PosX e PosY) e nem redimensionam (no caso dos
parâmetros SizeX e SizeY) o Divisor. Exemplo:
Sub Tela2_OnPreShow(vArg)
' Quando a Tela2 é aberta no Divisor Teste, altera a posição
' e o tamanho do Divisor
Application.GetFrame("Teste").MoveFrame 100, 100, 200, 200
End Sub

NOTA
Os valores de tamanho neste método podem ser informados como números ou Strings. No caso de números, são
considerados em pixels. No caso de Strings, se vierem acompanhados da unidade "hm", são interpretados como
Himetric. Qualquer outro caso é considerado em pixels.

4.2.1.8 NavigateBack
NavigateBack()
Volta para a Tela anterior no histórico de navegação do Divisor, se a propriedade NavigateCanGoBack é Verdadeira.

4.2.1.9 NavigateForward
NavigateForward()
Avança para a Tela seguinte no histórico de navegação do Divisor, se a propriedade NavigateCanGoForward é
Verdadeira.

4.2.1.10 NavigateHistReset
NavigateHistReset()
Limpa o histórico de abertura de Telas do Divisor, indicado pela propriedade NavigateHistCount.

4.2.1.11 OpenScreen
OpenScreen(ScreenName, Arg)
Este método abre uma Tela dentro de um Divisor. O parâmetro ScreenName determina a Tela a ser aberta, além de
ser possível especificar algumas propriedades desta Tela. Consulte a propriedade SplitLink do Divisor para mais

83 Visualização
informações sobre o formato para especificar uma Tela neste parâmetro. O parâmetro Arg permite especificar um
valor a ser repassado à Tela através do evento OnPreShow, como no exemplo a seguir.
Sub Botao1_Click()
'Clicar neste botão abre a Tela2 no Frame Teste,
'zoom de 100%, sem barra de rolagem
'e alinhamento padrão em relação à área visível.
'Também passa uma String para o evento OnPreShow.
Application.GetFrame("Teste")._
OpenScreen "Tela2?100?0?0", "Isto é um teste."
End Sub

Sub Tela2_OnPreShow(vArg)
'A caixa de mensagem mostra
'a frase "Isto é um teste."
MsgBox vArg
End Sub

4.2.1.12 Refresh
Refresh([Force])
O método Refresh permite forçar o redesenho do conteúdo de uma Tela ou Divisor. Este método deve ser usado em
scripts do E3 Viewer com processamento massivo (por exemplo, laços) ou em chamadas de métodos que demandem
muito tempo e exijam indicações visuais ao usuário do progresso do processo.
Devido ao redesenho em geral ser uma operação pesada, a versão padrão do método Refresh (sem o parâmetro
Force) é otimizada de forma a ignorar pedidos de redesenho muito próximos, incluindo redesenho do próprio E3.
Este comportamento padrão é ideal para indicações de progresso em laços, onde muitos redesenhos são realizados
em sequência. O parâmetro Force desabilita esta otimização, garantindo que para cada chamada do método Refresh
seja realizado um redesenho. Porém, ao utilizar-se esta opção, o método Refresh não pode ser chamado
repetidamente, como dentro de um laço. Exemplo:
Sub CommandButton1_Click()
' Desenha uma barra de progresso de uma operação
While i < 31
Screen.Item("Retangulo2")_
.HorizontalPercentFill = (i / 30) * 100
Frame.Refresh True
' <-- alguma operação demorada -->
Wend
End Sub

4.2.1.13 RestoreFrame
RestoreFrame()
Permite restaurar a janela do Quadro para o seu tamanho original.

4.2.1.14 SetDisableTaskSwitching
SetDisableTaskSwitching(Disable)
Habilita ou desabilita a troca de janelas. O parâmetro Disable é um valor Booleano que indica se a troca de janelas é
habilitada ou não. Este método atualiza a propriedade DisableTaskSwitching do objeto Viewer.

NOTAS
· Se mais de uma instância do E3 Viewer estiver executando em uma mesma máquina, e pelo menos uma destas
instâncias utilizar o método SetDisableTaskSwitching, a alteração afeta todos os E3 Viewers desta máquina
· Caso seja necessário modificar o título ou o estilo da janela, o método SetFrameOptions deve ser utilizado após a
chamada ao método SetDisableTaskSwitching

4.2.1.15 SetForegroundWnd
SetForegroundWnd()
O método SetForegroundWnd ativa e move o foco para a janela do E3 Viewer. Este método é útil quando se deseja
chamar a atenção do operador para algum evento ocorrido, quando a janela do E3 Viewer encontra-se escondida ou
minimizada.

Visualização 84
4.2.1.16 SetFrameOptions
SetFrameOptions(Title, [Flags])
Utilizado para configurar o título do Quadro na janela e o estilo da janela. O parâmetro Title é uma String que contém
o título da janela. Este texto é mostrado se a propriedade Caption da Tela estiver vazia.
O parâmetro Flags especifica o estilo da janela. Se este parâmetro é omitido, o valor padrão é -1 (menos um). Este
valor é usado para manter a configuração anterior da janela. Quando o valor especificado não é igual a -1 (menos
um), pode-se modificar o estilo da janela especificando a soma dos valores das combinações descritas na tabela a
seguir.
Combinações possíveis para o parâmetro Flags
VALOR DESCRIÇÃO
1 Habilita a barra de título na janela

2 Habilita o botão Fechar na janela

4 Habilita o botão Minimizar na janela

8 Habilita o botão Maximizar na janela

16 Habilita a borda na janela

32 Especifica que a janela pode ser dimensionada (para isto,


é necessário que a janela tenha uma borda)

64 Especifica que a janela pode ser movida

256 Especifica que a janela fica no topo da Tela

512 Especifica que a janela é configurada no estilo Barra de


Ferramentas

1024 Desabilita os botões de objeto

2048 Centraliza a janela

Exemplo:
Sub Tela_OnPreShow()
Frame.SetFrameOptions("Tela de Alarmes", 114)
End Sub

No exemplo anterior, o valor 114 (2 + 16 + 32 + 64) indica que a janela tem o botão Fechar habilitado (2), tem uma
borda (16), pode ser dimensionada (32) e pode ser movida (64). O título da janela é "Tela de Alarmes".
Nos Picks Abrir Tela e Abrir Tela Modal também é possível configurar o estilo da janela durante a edição, através da
caixa de diálogo Estilo da Janela. Para mais informações, veja o tópico Picks.

NOTA
O método SetFrameOptions deve ser usado após a chamada ao método SetDisableTaskSwitching, caso seja
necessário modificar o título ou o estilo da janela.

4.2.1.17 ShowScreen
ShowScreen(Screen, [Zoom], [Scrollbars], [Arg], [Alignment])
Este método carrega uma Tela no Divisor, fechando a Tela ou Quadro carregado anteriormente. Os parâmetros
disponíveis neste método são os seguintes:
· Screen: O objeto Tela a ser carregado. Este objeto deve ser retornado pelo método GetScreen do Viewer
· Zoom: Percentual de zoom da Tela. Se omitido, assume o valor 100
· Scrollbars: Booleano que indica se a barra de rolagem da Tela deve ou não estar habilitada. Se omitido, não
habilita a barra de rolagem da Tela
· Arg: String cujo valor é usado no evento OnPreShow da Tela a ser carregada. Se omitido, não passa nenhum
valor para a Tela a ser carregada

85 Visualização
· Alignment: Indica se a Tela deve ter um alinhamento superior esquerdo (1, um) ou um alinhamento centralizado
(2, dois) em relação à área visível. Se este parâmetro é omitido ou se o valor informado é inválido, assume o
valor 0 (zero, comportamento padrão da Tela)

A propriedade SplitLink é atualizada após a chamada deste método.

NOTA
O parâmetro Screen somente aceita o objeto retornado pelo método GetScreen do Viewer. Este método falha caso
seja utilizado um objeto Tela obtido a partir de outro método ou propriedade, como por exemplo a propriedade
Screen, comum a todos os objetos de Tela.

4.2.2 Propriedades do Divisor


Esta seção contém informações sobre as propriedades do objeto Divisor (FrameSet).

4.2.2.1 IsHTML
Esta propriedade retorna Verdadeiro se o Divisor contém código HTML inserido no Quadro ou Falso caso
contrário. Esta propriedade é somente de leitura.

4.2.2.2 NavigateCanGoBack
Indica se é possível usar o método NavigateBack no Divisor. Esta propriedade é somente de leitura.

4.2.2.3 NavigateCanGoForward
Indica se é possível usar o método NavigateForward no Divisor. Esta propriedade é somente de leitura.

4.2.2.4 NavigateHistCount
Informa o número de Telas disponíveis no histórico de navegação do Divisor. Esta propriedade é somente de leitura.
O histórico de navegação de um Divisor tem um limite máximo de aproximadamente 100 Telas. Após atingir este
limite, as Telas mais antigas vão sendo descartadas.

4.2.2.5 SplitBorder
Habilita ou desabilita a borda do Divisor e determina se a borda entre o Divisor mandante e o Divisor restante deve
ser exibida em tempo de execução. Esta propriedade não tem efeito no Divisor restante. O valor padrão desta
propriedade é Verdadeiro.

4.2.2.6 SplitDockPosition
Indica a posição do Divisor desejado na Tela. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para SplitDockPosition
OPÇÃO DESCRIÇÃO
0 - dockRemaining Posiciona o Divisor como restante, ou seja, ele ocupa o
espaço que sobra na Divisão horizontal ou vertical
(padrão)

1 - dockTop Posiciona o Divisor como mandante, acima do restante

2 - dockBottom Posiciona o Divisor como mandante, abaixo do restante

3 - dockLeft Posiciona o Divisor como mandante, à esquerda do


restante

4 - dockRight Posiciona o Divisor como mandante, à direita do restante

Esta propriedade não pode ser alterada em tempo de execução, mesmo que o Divisor esteja inativo.

4.2.2.7 SplitLink
Esta propriedade contém um link que deve ser mostrado no Divisor. Pode-se especificar uma Tela do projeto, um
executável ou um link na Internet. No caso de Telas, é possível especificar um percentual de zoom, habilitar as barras

Visualização 86
de rolagem e alinhar a Tela na área visível usando como separador um ponto de interrogação no formato "<nome-
da-tela>?<zoom>?<barra-de-rolagem>?<alinhamento>". Os valores possíveis para os parâmetros desta
propriedade estão descritos a seguir.
· <nome-da-tela>: Este parâmetro é obrigatório e indica o nome de uma Tela, um executável ou um link na
Internet a ser aberto no Divisor
· <zoom>: Este parâmetro é opcional e indica o percentual de zoom da Tela a ser aberta no Divisor. Se este
parâmetro não é informado, assume o valor de 100%
· <barra-de-rolagem>: Este parâmetro é opcional e indica se a Tela deve habilitar (1, um) ou desabilitar (0, zero) a
barra de rolagem. Se este parâmetro não é informado, assume o valor 1 (um, habilitado)
· <alinhamento>: Este parâmetro é opcional e indica se a Tela deve ter um alinhamento superior esquerdo (1, um)
ou um alinhamento centralizado (2, dois) em relação à área visível. Se este parâmetro não é informado ou se o
valor informado é inválido, assume o valor 0 (zero, comportamento padrão da Tela, configurado na propriedade
ScreenAlignment da Tela a ser aberta)

Os parâmetros <zoom>, <barra-de-rolagem> e <alinhamento> são válidos apenas se o parâmetro <nome-da-tela> se


tratar de uma Tela. Do contrário, são ignorados.

4.2.2.8 SplitResizable
Determina se o Divisor mandante pode ser redimensionado em tempo de execução. Esta propriedade não tem
efeito no Divisor restante. O valor padrão desta propriedade é Verdadeiro.

4.2.2.9 SplitValue
A propriedade SplitValue determina o valor que é atribuído ao Divisor do Quadro. No E3 Studio, este valor pode
ser acompanhado da unidade "%" (porcentagem), "hm" (Himetric) ou "px" (pixels). Se a unidade for omitida, o valor é
considerado em Himetric. Em tempo de execução, o valor deve ser numérico e sempre é considerado como
porcentagem.

4.2.3 Propriedades do Quadro


Esta seção contém informações sobre as propriedades do objeto Quadro (Frame).

4.2.3.1 Caption
A propriedade Caption define o título do Quadro a ser mostrado na barra de título no E3 Viewer.

4.3 Telas e Objetos de Tela


Esta seção contém informações sobre eventos, métodos e propriedades de Telas e Objetos de Tela.

4.3.1 Tela
Esta seção contém informações sobre eventos, métodos e propriedades do objeto Tela (Screen).

4.3.1.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tela (Screen).

4.3.1.1.1 Click
Click()
Ocorre quando o botão esquerdo do mouse é pressionado sobre a Tela. Este evento não ocorre se a Tela não estiver
visível ou sua propriedade Enabled estiver configurada para Falso. A visibilidade da Tela depende de três fatores:
Propriedade Visible igual a Verdadeiro, objeto pai visível e propriedade Layer do objeto presente na camada da
Tela.

4.3.1.1.2 DblClick
DblClick()
Ocorre quando há um duplo-clique, ou seja, o botão esquerdo do mouse é pressionado rapidamente duas vezes
sobre a Tela. Este evento não ocorre se o objeto não estiver visível ou se sua propriedade Enabled estiver
configurada para Falso. A visibilidade do objeto depende de três fatores: Propriedade Visible igual a Verdadeiro,
objeto pai visível e propriedade Layer do objeto presente na camada da Tela.

87 Visualização
4.3.1.1.3 KeyDown
KeyDown(KeyCode, Shift)
Ocorre no momento em que uma tecla é pressionada, independente do foco na Tela.
Parâmetros do evento KeyDown
NOME DESCRIÇÃO
KeyCode Número inteiro que identifica o caractere ASCII da tecla
pressionada

Shift Mostra o atalho de teclado usado juntamente com a tecla


pressionada:
· 4: Tecla SHIFT
· 8: Tecla CTRL
· 12: Teclas CTRL + SHIFT

Exemplo:
Sub Tela1_KeyDown(KeyCode, Shift)
' Mostra uma caixa de mensagem quando
' o usuário pressiona uma tecla
MsgBox "Código da tecla: " & KeyCode
End Sub

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyCode, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.3.1.1.4 KeyUp
KeyUp(KeyCode, Shift)
Ocorre no momento em que uma tecla é solta, independente do foco na Tela.
Parâmetros do evento KeyUp
NOME DESCRIÇÃO
KeyCode Número inteiro que identifica o caractere ASCII da tecla
pressionada

Shift Mostra o atalho de teclado usado juntamente com a tecla


pressionada:
· 4: Tecla SHIFT
· 8: Tecla CTRL
· 12: Teclas CTRL + SHIFT

Exemplo:
Sub Tela1_KeyUp(KeyCode, Shift)
' Mostra uma caixa de mensagem quando o usuário
' soltar uma tecla
MsgBox "Código da tecla: " & KeyCode
End Sub

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyCode, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.3.1.1.5 MouseDown
MouseDown(Button, ShiftState, MouseX, MouseY)
Ocorre quando se pressiona qualquer botão do mouse na Tela. Utilize o evento MouseDown para determinar ações
específicas quando a Tela é clicada pelo usuário.

Visualização 88
Parâmetros do evento MouseDown
NOME DESCRIÇÃO
Button Mostra o botão do mouse pressionado:
· 1: O botão do mouse pressionado é o esquerdo
· 2: O botão do mouse pressionado é o direito
· 4: O botão do mouse pressionado é o do meio

ShiftState Mostra a tecla pressionada juntamente com o botão do


mouse:
· 4: Tecla SHIFT
· 8: Tecla CTRL
· 12: Teclas CTRL + SHIFT

MouseX Mostra a coordenada X onde o ponteiro do mouse foi


clicado na Tela

MouseY Mostra a coordenada Y onde o ponteiro do mouse foi


clicado na Tela

Exemplo:
Sub TelaInicial_MouseDown(Button, ShiftState, MouseX, MouseY)
' Encerra a aplicação quando houver um clique de mouse
' no objeto TelaInicial.
Application.Exit()
End Sub

4.3.1.1.6 MouseUp
MouseUp(Button, ShiftState, MouseX, MouseY)
Ocorre quando se solta qualquer botão do mouse previamente clicado. Utilize o evento MouseUp para especificar
ações que são disparadas somente quando o botão do mouse é solto.
Parâmetros do evento MouseUp
NOME DESCRIÇÃO
Button Mostra o botão do mouse pressionado:
· 1: O botão do mouse pressionado é o esquerdo
· 2: O botão do mouse pressionado é o direito
· 4: O botão do mouse pressionado é o do meio

ShiftState Mostra a tecla pressionada juntamente com o botão do


mouse:
· 4: Tecla SHIFT
· 8: Tecla CTRL
· 12: Teclas CTRL + SHIFT

MouseX Mostra a coordenada X onde o ponteiro do mouse foi


clicado na Tela

MouseY Mostra a coordenada Y onde o ponteiro do mouse foi


clicado na Tela

Exemplo:
Sub TelaInicial_MouseUp(Button, ShiftState, MouseX, MouseY)
' Encerra a aplicação apenas quando o usuário soltar o botão.
Application.Exit()
End Sub

89 Visualização
4.3.1.1.7 OnHide
OnHide()
Ocorre quando uma Tela está prestes a ser fechada. Utilize o evento OnHide quando for necessário efetuar alguma
operação antes do objeto Tela ser fechado. Este evento pode ocorrer de diversas maneiras:
· Quando a Tela é substituída por outra através dos métodos OpenScreen ou ShowScreen
· Quando o usuário fechar a janela onde está a Tela
· Quando for utilizado o método Close do objeto Tela
· Quando o E3 Viewer é fechado ou encerrado

4.3.1.1.8 OnPreShow
OnPreShow(Arg)
Ocorre antes da Tela ser mostrada. O parâmetro Arg recebe o conteúdo do parâmetro Arg dos métodos OpenScreen
e ShowScreen, que geram este evento. Logo após, é gerado o evento OnShow. Exemplo:
Sub Screen1_OnPreShow(Arg)
' O título da Tela Screen1 a ser mostrada
' foi passado como parâmetro na chamada do método
' OpenScreen que gerou o evento.
Caption = Arg
End Sub

4.3.1.1.9 OnShow
OnShow()
Ocorre no momento exato que uma Tela é mostrada. Utilize o evento OnPreShow para efetuar alguma operação
antes que a Tela seja exibida. Exemplo:
Sub TelaPrincipal_OnShow()
MsgBox "Seja bem-vindo ao sistema!"
End Sub

4.3.1.2 Métodos
Esta seção contém informações sobre os métodos do objeto Tela (Screen).

4.3.1.2.1 Close
Close(Code)
Utilize o método Close para fechar a Tela. Este método gera o evento OnHide antes de ser efetivamente executado. O
parâmetro Code tem o valor de retorno para o método DoModal, se a Tela em questão é chamada por este método.
Exemplo:
Sub BotaoFecha_Click()
' Ao clicar em BotaoFecha, fecha a janela
Screen.Close(0)
End Sub

4.3.1.2.2 FromPixelX
FromPixelX(XPixel)
Converte a coordenada X da Tela, indicada pelo parâmetro XPixel, de pixels para Himetric. Este método é
complementar ao método ToPixelX.

4.3.1.2.3 FromPixelY
FromPixelY(YPixel)
Converte a coordenada Y da Tela, indicada pelo parâmetro YPixel, de pixels para Himetric. Este método é
complementar ao método ToPixelY.

4.3.1.2.4 ToPixelX
ToPixelX(XHimetric)
Converte a coordenada X da Tela, indicada pelo parâmetro XHimetric, de Himetric para pixels. Este método é
complementar ao método FromPixelX.

Visualização 90
4.3.1.2.5 ToPixelY
ToPixelY(YHimetric)
Converte a coordenada Y da Tela, indicada pelo parâmetro YHimetric, de Himetric para pixels. Este método é
complementar ao método FromPixelY.

4.3.1.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tela (Screen).

NOTA
O E3 utiliza para definição de coordenadas e espessura o sistema Himetric. Neste sistema, cada unidade lógica
equivale a um milésimo de centímetro; ou seja, cada 1000 unidades equivalem a 1 centímetro. Assim, este é o padrão
adotado na descrição das propriedades do E3, quando aplicável.

4.3.1.3.1 AllowContextMenu
Se configurada em Verdadeiro, esta propriedade habilita a exibição do menu contextual de uma Tela através do
botão direito do mouse em tempo de execução, exceto quando algum script estiver configurado com informação
divergente nos eventos MouseDown ou MouseUp. Caso contrário, o menu contextual não é mostrado. O valor
padrão desta propriedade é Verdadeiro.

4.3.1.3.2 AllowZoomChange
Esta propriedade habilita a exibição ou não das opções de alteração do nível de zoom no menu contextual de uma
Tela. O valor padrão desta propriedade é Verdadeiro.

4.3.1.3.3 BackgroundColor
Especifica a cor de preenchimento do fundo da Tela. Nos scripts, utilize o método RGB do VBScript para montar a
cor a ser associada a esta propriedade. O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).

4.3.1.3.4 Caption
A propriedade Caption define o título da Tela a ser mostrado na barra de título do E3 Viewer.

4.3.1.3.5 FillStyle
Esta propriedade especifica o estilo do preenchimento da Tela. A tabela a seguir contém os valores válidos para a
propriedade FillStyle.
Opções disponíveis para a propriedade FillStyle
OPÇÃO DESCRIÇÃO
0 - Solid O preenchimento é sólido (padrão)

2 - Horizontal O preenchimento é com listras horizontais

3 - Vertical O preenchimento é com listras verticais

4 - Downward O preenchimento é com listras descendo da esquerda


para a direita em ângulo de 45 graus

5 - Upward O preenchimento é com listras subindo da esquerda


para a direita em ângulo de 45 graus

6 - Cross O preenchimento é com listras horizontais e verticais

7 - DiagonalCross O preenchimento é com listras descendo e subindo da


esquerda para a direita em ângulo de 45 graus

8 - Gradient O preenchimento é em degradê utilizando tanto


ForegroundColor quanto BackgroundColor. O efeito é
definido pela propriedade GradientStyle

11 - Background Preenche a Tela com a cor definida na propriedade


BackgroundColor

91 Visualização
OPÇÃO DESCRIÇÃO
12 - Picture Preenche a Tela com a figura selecionada na
propriedade PictureFile

4.3.1.3.6 ForegroundColor
Especifica a cor do preenchimento da frente da Tela. Nos scripts, utilize o método RGB do VBScript para montar a
cor a ser associada a esta propriedade. O valor padrão para esta propriedade é preto (RGB(0, 0, 0)). Aplicações
anteriores à introdução desta propriedade têm ambas as propriedades ForegroundColor e BackgroundColor
configuradas com a cor antes armazenada na propriedade BackgroundColor, e o estilo de preenchimento é
configurado como 11 - Background, que pinta toda a Tela com a cor de fundo (comportamento antigo, anterior à
criação dos estilos). Exemplo:
Sub Tela1_Click()
' Troca a cor de fundo da Tela para azul
ForegroundColor = RGB(0, 0, 255)
End Sub

4.3.1.3.7 GradientStyle
Esta propriedade especifica o estilo de preenchimento degradê de uma Tela. Esta propriedade só é utilizada
quando o valor da propriedade FillStyle estiver configurado para 8 (oito, Gradient). Os degradês consideram a
mudança partindo da cor configurada na propriedade ForegroundColor e indo para a cor configurada na
propriedade BackgroundColor.
Opções disponíveis para a propriedade GradientStyle
OPÇÃO DESCRIÇÃO
0 - LeftToRight Degradê vertical da esquerda para a direita (padrão)

1 - RightToLeft Degradê vertical da direita para a esquerda

2 - VertToCenter Degradê vertical das bordas para o centro

3 - VertFromCenter Degradê vertical do centro para as bordas

4 - TopDown Degradê horizontal de cima para baixo

5 - BottomUp Degradê horizontal de baixo para cima

6 - HorzToCenter Degradê das bordas para o centro

7 - HorzFromCenter Degradê do centro para as bordas

8 - DiagDownRight Degradê diagonal para baixo com cor de frente na


direita

9 - DiagUpLeft Degradê diagonal para cima com a cor de frente na


esquerda

10 - DiagUpToCenter Degradê diagonal para cima das bordas para o centro

11 - DiagUpFromCenter Degradê diagonal para cima do centro para as bordas

12 - DiagDownLeft Degradê diagonal para baixo com cor de frente na


esquerda

13 - DiagUpRight Degradê diagonal para cima com a cor de frente na


direita

14 - DiagDownToCenter Degradê diagonal para baixo das bordas para o centro

15 - DiagDownFromCenter Degradê diagonal para baixo do centro para as bordas

16 - SpotBottomRight Degradê com cor de frente partindo do canto inferior


direito

17 - SpotBottomLeft Degradê com cor de frente partindo do canto inferior


esquerdo

18 - SpotTopLeft Degradê com cor de frente partindo do canto superior


esquerdo

Visualização 92
OPÇÃO DESCRIÇÃO
19 - SpotTopRight Degradê com cor de frente partindo do canto superior
direito

20 - SpotFromCenter Degradê com cor de fundo do centro para as bordas

21 - SpotToCenter Degradê com cor de fundo das bordas para o centro

4.3.1.3.8 Layer
Esta propriedade define, para a Tela, quais camadas estão visíveis. Para os objetos de Tela, esta propriedade define
se aquele objeto de Tela está visível naquela camada. O valor desta propriedade representa uma máscara de 32 bits,
um bit para cada camada. Portanto, podem ser definidas até 32 camadas individuais. Assim, objetos podem ser
agrupados logicamente e mostrados ou escondidos apenas com a modificação da máscara desta propriedade.

Opções da propriedade Layer

NOTA
A visibilidade de um objeto de Tela depende de três fatores: A sua propriedade Visible tem de estar configurada
para Verdadeiro, seu objeto pai tem de estar visível e sua propriedade Layer tem de estar habilitada para a Tela.

4.3.1.3.9 PictureFile
Contém o nome do arquivo da figura que é utilizada como fundo da Tela. Pode ser qualquer formato já suportado
no E3 pelo objeto DrawPicture (*.bmp, *.gif, *.jpg, *.cur, *.ico, *.emf, *.wmf, *.png e *.tif). O valor padrão desta
propriedade é uma String em branco. Esta propriedade só é válida se a propriedade FillStyle estiver selecionada
como 12 - Picture.

4.3.1.3.10 PicturePosition
Indica a posição da figura selecionada na propriedade PictureFile na Tela. Esta propriedade só é válida se a
propriedade FillStyle estiver selecionada como 12 - Picture. As opções válidas estão descritas na tabela a seguir.
Opções disponíveis para PicturePosition
OPÇÃO DESCRIÇÃO
0 - Center Figura no tamanho original, centralizada na Tela (padrão)

1 - Tile Figura no tamanho original, repetida tantas vezes


quantas forem necessárias para preencher a Tela

93 Visualização
OPÇÃO DESCRIÇÃO
2 - Stretch Figura redimensionada para preencher a Tela

3 - TopLeft Figura no tamanho original, no canto esquerdo superior


da Tela

4 - BottomLeft Figura no tamanho original, no canto esquerdo inferior


da Tela

5 - BottomRight Figura no tamanho original, no canto direito inferior da


Tela

6 - TopRight Figura no tamanho original, no canto direito superior da


Tela

4.3.1.3.11 RenderQuality
Controla a qualidade do desenho de uma Tela. Os valores possíveis para esta propriedade são os seguintes:
· 0 - rqDefault: A qualidade do desenho da Tela utiliza o valor definido na propriedade RenderQuality do Viewer.
Este é o valor padrão desta propriedade, mesmo em aplicações criadas em versões anteriores à 4.0
· 1 - rqNormal: Força o modo de qualidade normal (GDI, Graphics Device Interface) para o desenho da Tela
· 2 - rqHighQuality: Força o modo de alta qualidade (GDI+) para o desenho da Tela

A figura a seguir mostra o menu contextual de uma Tela em tempo de execução, com as respectivas opções de
configuração desta propriedade.

Visualização 94
Menu contextual da Tela em tempo de execução

4.3.1.3.12 ScreenAlignment
Controla o alinhamento da Tela em relação à area visível. Os valores possíveis para esta propriedade são os
seguintes:
· 0 - paDefault: Ajusta a Tela a seguir o valor definido pela propriedade ScreenAlignment do Viewer.
Corresponde à opção Utilizar Padrão do menu contextual Alinhamento (Esta Tela) da Tela, em tempo de
execução
· 1 - paTopLeft: Ajusta a Tela ao canto superior esquerdo em relação à área visível. Corresponde à opção Forçar
Superior Esquerdo do menu contextual Alinhamento (Esta Tela) da Tela, em tempo de execução
· 2 - paCenter: Ajusta a Tela ao centro em relação à área visível. Corresponde à opção Forçar Centralizado do
menu contextual Alinhamento (Esta Tela) da Tela, em tempo de execução

A figura a seguir mostra o menu contextual de uma Tela em tempo de execução, com as respectivas opções de
configuração desta propriedade.

95 Visualização
Opções da propriedade ScreenAlignment de uma Tela em tempo de execução

4.3.2 Objetos de Tela


Esta seção contém informações sobre eventos, métodos e propriedades dos Objetos de Tela.

4.3.2.1 Eventos Comuns


Esta seção contém informações sobre os eventos comuns a todos os Objetos de Tela.

4.3.2.1.1 Click
Click()
Ocorre quando o botão esquerdo do mouse é pressionado sobre um objeto. Este evento não ocorre se o objeto não
está visível ou se a propriedade Enabled está configurada para Falso. A visibilidade de um objeto depende de três
fatores: propriedade Visible igual a Verdadeiro, objeto pai visível e propriedade Layer do objeto presente na camada
da Tela.

4.3.2.1.2 DblClick
DblClick()
Ocorre quando há um duplo-clique, ou seja, o botão esquerdo do mouse é pressionado rapidamente duas vezes
sobre um objeto. Este evento não ocorre se o objeto não está visível ou se a propriedade Enabled está configurada
para Falso. A visibilidade do objeto depende de três fatores: propriedade Visible igual a Verdadeiro, objeto pai
visível e propriedade Layer do objeto presente na camada da Tela.

Visualização 96
4.3.2.1.3 KeyDown
KeyDown(KeyCode, Shift)
Ocorre no momento em que uma tecla é pressionada e o objeto está com o foco do teclado. Note que este evento
não é gerado se o objeto não está habilitado, ou seja, a propriedade Enabled igual a Falso, ou este objeto não
possui o foco do teclado.
Parâmetros do evento KeyDown
NOME DESCRIÇÃO
KeyCode Número inteiro que identifica o caractere ASCII da tecla
pressionada

Shift Mostra o atalho de teclado usado juntamente com a


tecla pressionada. Os valores possíveis são 4: Tecla
SHIFT, 8: Tecla CTRL ou 12: Teclas CTRL + SHIFT

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyCode, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.3.2.1.4 KeyUp
KeyUp(KeyCode, Shift)
Ocorre no momento em que uma tecla é solta e o objeto está com o foco do teclado. Note que este evento não é
gerado se o objeto não está habilitado, ou seja, propriedade Enabled igual a Falso, ou se este objeto não possui o
foco do teclado.
Parâmetros do evento KeyUp
NOME DESCRIÇÃO
KeyCode Número inteiro que identifica o caractere ASCII da tecla
pressionada

Shift Mostra o atalho de teclado usado juntamente com a


tecla pressionada. Os valores possíveis são 4: Tecla
SHIFT, 8: Tecla CTRL ou 12: Teclas CTRL + SHIFT

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyCode, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.3.2.1.5 MouseDown
MouseDown(Button, ShiftState, MouseX, MouseY)
Ocorre quando se pressiona qualquer botão do mouse sobre um objeto.
Parâmetros do evento MouseDown
NOME DESCRIÇÃO
Button Mostra o botão do mouse pressionado. Os valores
possíveis são 1: O botão do mouse pressionado é o
esquerdo, 2: O botão do mouse pressionado é o direito
ou 4: O botão do mouse pressionado é o do meio

ShiftState Mostra a tecla pressionada juntamente com o botão do


mouse. Os valores possíveis são 4: Tecla SHIFT, 8: Tecla
CTRL ou 12: Teclas CTRL + SHIFT

MouseX Mostra a coordenada horizontal onde o botão do mouse


foi clicado na Tela

97 Visualização
NOME DESCRIÇÃO
MouseY Mostra a coordenada vertical onde o botão do mouse
foi clicado na Tela

4.3.2.1.6 MouseUp
MouseUp(Button, ShiftState, MouseX, MouseY)
Ocorre quando se solta qualquer botão do mouse previamente clicado sobre um objeto. Utilize este evento para
especificar ações que são disparadas somente quando o botão do mouse é solto.
Parâmetros do evento MouseUp
NOME DESCRIÇÃO
Button Mostra o botão do mouse pressionado. Os valores
possíveis são 1: O botão do mouse pressionado é o
esquerdo, 2: O botão do mouse pressionado é o direito
ou 4: O botão do mouse pressionado é o do meio

ShiftState Mostra a tecla pressionada juntamente com o botão do


mouse. Os valores possíveis são 4: Tecla SHIFT, 8: Tecla
CTRL ou 12: Teclas CTRL + SHIFT

MouseX Mostra a coordenada horizontal onde o botão do mouse


foi clicado na Tela

MouseY Mostra a coordenada vertical onde o botão do mouse


foi clicado na Tela

4.3.2.2 Métodos Comuns


Esta seção contém informações sobre os métodos comuns a todos os Objetos de Tela.

4.3.2.2.1 BringToFront
BringToFront()
Posiciona um objeto à frente de todos os outros objetos da Tela.

4.3.2.2.2 FitObject
FitObject([ScreenFillPercentage])
Este método enquadra um objeto no centro da Tela usando uma porcentagem relativa à Tela para preenchimento. O
parâmetro ScreenFillPercentage é opcional e, se não é informado, assume o valor 50, ou seja, o objeto ocupa 50% da
área da Tela. Os valores permitidos para este parâmetro variam entre 1 (um) e 100. Este método retorna erro nos
seguintes casos:
· O modo de alinhamento configurado na propriedade ScreenAlignment da Tela onde o objeto está inserido é
diferente de paCenter
· O objeto não está visível, ou seja, a propriedade Visible é igual a Falso
· As coordenadas X e Y do centro do objeto não estão contidas na área da Tela onde o objeto está inserido

4.3.2.2.3 SendToBack
SendToBack()
Posiciona um objeto atrás de todos os outros objetos da Tela.

4.3.2.2.4 SetFocus
SetFocus()
Move o foco do ponteiro do mouse ou do teclado para um objeto determinado.

4.3.2.3 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns a todos os objetos de Tela. As propriedades
explicadas a seguir não se aplicam aos objetos MSForms, E3Chart, E3Browser e E3Alarm. Estes são descritos
posteriormente, em capítulos específicos para estes objetos.

Visualização 98
NOTAS
· O E3 utiliza para definição de coordenadas e espessura o sistema Himetric. Neste sistema, cada unidade lógica
equivale a um milésimo de centímetro, ou seja, cada 1000 unidades equivalem a um centímetro. Assim, este é o
padrão adotado na descrição das propriedades do E3, quando aplicável.
· As propriedades listadas a seguir são comuns a todos os objetos citados anteriormente, inclusive o Grupo de
objetos e movimentos de Rotação e Translação.

4.3.2.3.1 Angle
Esta propriedade define o ângulo de rotação em graus, no sentido anti-horário, que um objeto deve ser
rotacionado. Isto também se aplica aos filhos que este objeto tenha, respeitando as limitações de rotação de cada
objeto filho. O objeto rotaciona de acordo com o centro, que pode ser editado durante a operação de rotação. O
valor padrão desta propriedade é 0 (zero, sem rotação).

4.3.2.3.2 BackgroundColor
Esta propriedade especifica a cor de preenchimento do fundo de um objeto. Esta cor é utilizada quando a
propriedade BackgroundStyle está configurada para 1 (um, opaco) e umas das propriedades VerticalPercentFill ou
HorizontalPercentFill está com valores diferentes de 100. Outro uso desta cor é quando a propriedade FillStyle está
configurada entre os valores 2 (dois) e 8 (oito). Isto permite que a área restante utilize a cor de fundo para
preenchimento. Nos scripts, utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade.
O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).

4.3.2.3.3 BackgroundStyle
Esta propriedade especifica o modo do preenchimento do fundo de um objeto. Esta propriedade habilita a
utilização das propriedades VerticalPercentFill e HorizontalPercentFill com valores diferentes de 100 e também da
propriedade FillStyle configurada entre os valores 2 (dois) e 8 (oito). Isto permite que a área restante utilize a cor de
fundo configurada em BackgroundColor para preenchimento. A tabela a seguir contém os valores válidos para esta
propriedade.
Opções disponíveis para a propriedade BackgroundStyle
OPÇÃO DESCRIÇÃO
0 - Transparent Nenhum fundo deste objeto é desenhado

1 - Opaque Caso visível, o fundo é desenhado (padrão)

4.3.2.3.4 BorderColor
Especifica a cor da borda ou a cor da linha de um objeto. Esta propriedade só é utilizada quando a propriedade
BorderStyle não está configurada para o valor 5 (cinco, Null), onde o objeto permanece sem borda. Nos scripts,
utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta
propriedade é branco (RGB(255, 255, 255)), exceto para os objetos Display e SetPoint, cujo valor padrão desta
propriedade é cinza escuro (RGB(128,128,128)).

4.3.2.3.5 BorderStyle
Esta propriedade determina o estilo de borda que é aplicada a um objeto. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade BorderStyle
OPÇÃO DESCRIÇÃO
0 - Normal Aplica uma borda sólida ao objeto (padrão)

1 - Dash Aplica uma borda com linha tracejada ao objeto

2 - Dot Aplica uma borda pontilhada ao objeto

3 - DashDot Aplica uma borda com traço-ponto ao objeto

4 - DashDotDot Aplica uma borda com traço-ponto-ponto ao objeto

5 - Null O objeto não tem uma borda

99 Visualização
4.3.2.3.6 BorderWidth
Define a espessura, em unidades Himetric, da linha ou da borda de um objeto. Só é utilizada se a propriedade
BorderStyle não está configurada para o valor 5 (Null). O valor padrão desta propriedade é 0 (zero). Esta é uma
exceção no sistema de medidas do E3, pois quando o valor é 0 (zero), a espessura da linha ou da borda não é
definida em unidades Himetric, mas sim em pixels. Configurar esta propriedade com o valor 0 (zero) indica a
espessura de um pixel.

4.3.2.3.7 Effect3D
Determina a aplicação de um efeito 3D no objeto selecionado. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade Effect3D
OPÇÃO DESCRIÇÃO
0 - No3D Transparente (padrão)

1 - Raised Aplica um efeito 3D em alto relevo

2 - Sunken Aplica um efeito 3D em baixo relevo

4.3.2.3.8 Effect3D_X
Especifica a dimensão do efeito 3D no eixo horizontal de um objeto (eixo X). O valor padrão desta propriedade é
30.

4.3.2.3.9 Effect3D_Y
Especifica a dimensão do efeito 3D no eixo vertical de um objeto (eixo Y). O valor padrão desta propriedade é 30.

4.3.2.3.10 Effect3DColorBase
Determina a cor da base do efeito 3D em um objeto. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.3.2.3.11 Effect3DColorTop
Determina a cor do topo do efeito 3D em um objeto. O valor padrão desta propriedade é branco (RGB(255, 255,
255)).

4.3.2.3.12 Enabled
Habilita ou desabilita um objeto, isto é, o foco e a resposta aos eventos gerados pelo usuário. Se esta propriedade
está configurada para Verdadeiro, o objeto pode receber o foco, responder a eventos gerados pelo usuário e está
acessível através de scripts (padrão). Caso contrário, o usuário não pode interagir com o objeto usando o ponteiro
do mouse, pressionando teclas ou atalhos de teclado e o objeto aparece esmaecido. Além disto, se o objeto exibir
um bitmap, este bitmap permanece esmaecido sempre que este objeto está desabilitado.
Esta propriedade e a propriedade Locked, presente nos objetos Caixa de Seleção, Botão de Opção, Lista de
Seleção, Botão de Comando, Lista, Botão Liga-Desliga e Editor de Texto, são interligadas. Quando esta
propriedade e a propriedade Locked estão ambas configuradas em Verdadeiro, um objeto pode receber foco e
aparecer normalmente na Tela, e os dados podem ser copiados mas não editados. Quando esta propriedade é igual
a Verdadeiro, mas a propriedade Locked é igual a Falso, os dados podem ser não só copiados mas também
editados. No entanto, quando esta propriedade é igual a Falso, o objeto não recebe foco e permanece esmaecido na
Tela, independente do status da propriedade Locked. Além disto, os dados não podem ser copiados nem tampouco
editados.
É possível combinar as configurações desta propriedade e da propriedade TabStop para impedir que o usuário
selecione um Botão de Comando com a tecla TAB, embora ainda seja permitido ao usuário clicar neste botão. Definir
a propriedade TabStop como Falso significa que o Botão de Comando não aparece na ordem de tabulação.
Entretanto, se esta propriedade é igual a Verdadeiro, o usuário ainda pode clicar no Botão de Comando, desde que a
propriedade TakeFocusOnClick esteja definida como Verdadeiro.

NOTA
Configurar esta propriedade no objeto Texto, Display e SetPoint para Falso em tempo de execução cancela a
edição corrente e descarta o conteúdo daquele objeto.

Visualização 100
4.3.2.3.13 FillStyle
Esta propriedade especifica o estilo do preenchimento dos objetos de Tela. A tabela a seguir contém os valores
válidos para esta propriedade.
Opções disponíveis para a propriedade FillStyle
OPÇÃO DESCRIÇÃO
0 - Solid O preenchimento é sólido (padrão)

1 - Hollow Não há preenchimento

2 - Horizontal O preenchimento é com listras horizontais

3 - Vertical O preenchimento é com listras verticais

4 - Downward O preenchimento é com listras descendo da esquerda


para a direita em ângulo de 45 graus

5 - Upward O preenchimento é com listras subindo da esquerda


para a direita em ângulo de 45 graus

6 - Cross O preenchimento é com listras horizontais e verticais

7 - DiagonalCross O preenchimento é com listras descendo e subindo da


esquerda para a direita em ângulo de 45 graus

8 - Gradient O preenchimento é em degradê utilizando tanto o valor


da propriedade ForegroundColor quanto o valor da
propriedade BackgroundColor. O efeito é definido pela
propriedade GradientStyle

9 - SemiTransparent Deixa o objeto de Tela translúcido

10 - MouseArea Não há preenchimento, mas o objeto de Tela continua


sensível aos eventos

11 - Background Preenche o objeto de Tela com a cor definida na


propriedade BackgroundColor

NOTA
Esta propriedade não está disponível para os objetos Figura, Animação com Translação e Animação com Rotação.

4.3.2.3.14 ForegroundColor
Esta propriedade especifica a cor do preenchimento da frente de um objeto. Esta cor é utilizada quando a
propriedade FillStyle está configurada para 0 (zero, sólido) ou entre 2 (dois) e 9 (nove). Nos scripts, utilize o método
RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão para esta propriedade é azul
(RGB(0, 0, 255)), exceto para os objetos Display e SetPoint, cujo valor padrão para esta propriedade é branco
(RGB(255, 255, 255)).

4.3.2.3.15 Frame
Retorna o Quadro pai de um objeto. Esta propriedade é somente de leitura.

4.3.2.3.16 GradientStyle
Esta propriedade especifica o estilo de preenchimento degradê de um objeto de Tela. Esta propriedade só é
utilizada quando o valor da propriedade FillStyle está configurado para 8 (oito, Gradient). Os degradês consideram
a mudança partindo da cor configurada na propriedade ForegroundColor e indo para a cor configurada na
propriedade BackgroundColor. Os valores possíveis para esta propriedade são os mesmos descritos na propriedade
GradientStyle da Tela.

IMPORTANTE
Um grande número de objetos mostrados com degradê, simultaneamente, acarretam uma perda de performance na
atualização da Tela. O uso de figuras no lugar pode resolver o problema.

101 Visualização
NOTA
Esta propriedade não está disponível para os objetos Figura, Animação com Translação e Animação com Rotação.

4.3.2.3.17 HasFocus
Esta propriedade determina que o objeto selecionado tem o foco. Esta propriedade é somente de leitura.

4.3.2.3.18 Height
Determina a altura de um objeto.

4.3.2.3.19 HorizontalFillStyle
Define como é o preenchimento horizontal de um objeto. Esta propriedade trabalha em conjunto com a
propriedade HorizontalPercentFill, que informa qual porcentagem de um objeto deve ser preenchida. Estas duas
propriedades permitem uma simulação de um preenchimento de nível em um objeto, como ocorre em um nível de um
tanque, por exemplo.
Opções disponíveis para a propriedade HorizontalFillStyle
OPÇÃO DESCRIÇÃO
0 - FillLeftToRight A porcentagem de preenchimento é da esquerda para a
direita (padrão)

1 - FillRightToLeft A porcentagem de preenchimento é da direita para a


esquerda

2 - FillCenterToEdgesH A porcentagem de preenchimento é do centro para as


bordas

4.3.2.3.20 HorizontalPercentFill
Utilize esta propriedade para especificar qual a porcentagem da área horizontal de um objeto deve ser preenchida.
Os valores aceitos por esta propriedade variam de 0 (zero) a 100. Esta propriedade trabalha em conjunto com a
propriedade HorizontalFillStyle, que informa como este preenchimento ocorre. O valor padrão desta propriedade é
100.

4.3.2.3.21 MouseOver
Esta propriedade informa se o ponteiro do mouse encontra-se sobre a Tela. Caso afirmativo, esta propriedade é
habilitada. Do contrário, é desabilitada. Esta propriedade é somente de leitura. O valor padrão desta propriedade é
Falso.

4.3.2.3.22 MouseOverChild
Esta propriedade informa se o ponteiro do mouse encontra-se sobre um dos objetos inseridos na Tela. Caso
afirmativo, esta propriedade é habilitada. Do contrário, é desabilitada. Esta propriedade é somente de leitura. O valor
padrão desta propriedade é Falso.

4.3.2.3.23 Screen
Retorna a Tela pai de um objeto. Esta propriedade é somente de leitura.

4.3.2.3.24 Shadow
Indica a presença do efeito de sombra em um objeto. Se configurada para Verdadeiro, o objeto possui uma
sombra, cujas coordenadas são estabelecidas pelas propriedades ShadowX e ShadowY. Do contrário, o objeto não
possui o efeito de sombra. O valor padrão desta propriedade é Falso.

4.3.2.3.25 ShadowColor
Especifica a cor do preenchimento da sombra de um objeto. Esta cor é utilizada quando a propriedade Shadow
está configurada para Verdadeiro. Nos scripts, utilize o método RGB do VBScript para montar a cor a ser associada a
esta propriedade. O valor padrão desta propriedade é cinza escuro (RGB(128, 128, 128)).

Visualização 102
4.3.2.3.26 ShadowX
Define a coordenada vertical à esquerda da sombra de um objeto, em unidades Himetric. Esta sombra é sempre
relativa à propriedade X do objeto. Valores positivos indicam que a sombra está à direita do objeto, e negativos à
esquerda. O valor padrão desta propriedade é 200.

4.3.2.3.27 ShadowY
Define a coordenada horizontal superior da sombra de um objeto, em unidades Himetric. Esta sombra é sempre
relativa à propriedade Y do objeto. Valores positivos indicam que a sombra está abaixo do objeto, e negativos acima.
O valor padrão desta propriedade é 200.

4.3.2.3.28 TabStop
Esta propriedade determina a utilização da tecla TAB na aplicação. Se esta propriedade está configurada em
Verdadeiro, é possível utilizar a tecla TAB. Caso contrário, esta tecla não pode ser utilizada.

4.3.2.3.29 Tip
Esta propriedade mostra um texto pop-up quando o ponteiro do mouse permanece por um breve momento sobre
o objeto em execução.

4.3.2.3.30 VerticalFillStyle
Define como é o preenchimento vertical de um objeto. Esta propriedade trabalha em conjunto com a propriedade
VerticalPercentFill, que informa qual porcentagem do objeto deve ser preenchida. Estas duas propriedades
permitem uma simulação de um preenchimento de nível em um objeto.
Opções disponíveis para a propriedade VerticalFillStyle
OPÇÃO DESCRIÇÃO
0 - FillBottomToTop A porcentagem de preenchimento é de baixo para cima
(padrão)

1 - FillTopToBottom A porcentagem de preenchimento é de cima para baixo

2 - FillCenterToEdgesV A porcentagem de preenchimento é do centro para as


bordas

4.3.2.3.31 VerticalPercentFill
Utilize esta propriedade para especificar qual a porcentagem da área vertical de um objeto deve ser preenchida. Os
valores aceitos por esta propriedade variam de 0 (zero) a 100. Esta propriedade trabalha em conjunto com a
propriedade VerticalFillStyle, que informa como este preenchimento ocorre. O valor padrão desta propriedade é
100.

4.3.2.3.32 Visible
Esta propriedade define a visibilidade de um objeto. Se esta propriedade está configurada como Verdadeiro, o
objeto permanece visível, desde que também sejam obedecidos os seguintes fatores: o objeto pai deste objeto
também deve estar visível e a propriedade Layer deste objeto também deve estar presente na camada da Tela.

4.3.2.3.33 Width
Determina a largura de um objeto, em unidades Himetric.

4.3.2.3.34 X
Esta propriedade define a coordenada horizontal esquerda, em unidades Himetric, de um objeto.

4.3.2.3.35 Y
Esta propriedade define a coordenada vertical superior, em unidades Himetric, de um objeto.

4.3.2.4 Animação com Rotação


Esta seção contém informações sobre propriedades do objeto Animação com Rotação (DynamicRotate). Este objeto
não possui eventos nem métodos associados.

103 Visualização
4.3.2.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Animação com Rotação (DynamicRotate).

4.3.2.4.1.1 Detents
Esta propriedade determina o número de passos do movimento deste objeto.

4.3.2.4.1.2 EnableOverrideLineColor
Esta propriedade habilita ou desabilita este objeto a sobrescrever a cor original da linha da imagem pela cor
definida na propriedade OverrideLineColor. Se esta propriedade está habilitada, isto permite que seja modificada a
cor original da linha deste objeto pela cor da propriedade OverrideLineColor. Caso contrário, este objeto exibe a cor
original. O valor padrão desta propriedade é Falso.

4.3.2.4.1.3 EnableSlider
Esta propriedade habilita o slider no movimento deste objeto.

4.3.2.4.1.4 OverrideFillColor
Quando a propriedade OverrideFillMode é configurada com os valores 2 (dois) ou 3 (três), esta propriedade é
usada para definir a cor a ser usada no preenchimento dos objetos no movimento, ao invés da cor original. Nos
scripts, utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta
propriedade é vermelho (RGB(255, 0, 0)).

4.3.2.4.1.5 OverrideFillMode
Esta propriedade especifica o modo do preenchimento dos objetos que estão em movimento e altera o modo
original de preenchimento da imagem, sem alterar a configuração original de preenchimento dos objetos. Os valores
possíveis para esta propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade OverrideFillMode
OPÇÃO DESCRIÇÃO
0 - NoOverride Preenchimento original dos objetos (padrão)

1 - Wireframe Os objetos não são preenchidos, desenham somente as


bordas

2 - SolidFill O preenchimento dos objetos contidos no grupo é


sólido com a cor especificada na propriedade
OverrideFillColor

3 - ByBrightness O preenchimento dos objetos contidos no grupo é


sólido com a cor especificada pela propriedade
OverrideFillColor, porém leva em conta qual era a
intensidade da cor original de preenchimento de cada
objeto

4.3.2.4.1.6 OverrideLineColor
Quando a propriedade EnableOverrideLineColor está configurada para Verdadeiro, esta propriedade é usada
para definir a cor a ser usada na cor da linha dos objetos em movimento, ao invés da cor original. Nos scripts, utilize
o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade
é vermelho (RGB(255, 0, 0)).

4.3.2.4.1.7 RangeMax
Esta propriedade determina o alcance máximo do movimento rotacional deste objeto.

4.3.2.4.1.8 RangeMin
Esta propriedade determina o alcance mínimo do movimento rotacional deste objeto.

Visualização 104
4.3.2.4.1.9 RotationAngle
Esta propriedade determina o ângulo de rotação do movimento deste objeto.

4.3.2.4.1.10 RotationDirection
Esta propriedade determina a direção do ângulo de rotação do movimento deste objeto. Os valores possíveis
para esta propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade RotationDirection
OPÇÃO DESCRIÇÃO
0 - Clockwise Direciona o ângulo de rotação à direita deste objeto
(padrão)

1 - Counterclockwise Direciona o ângulo de rotação à esquerda deste objeto

4.3.2.4.1.11 Value
Indica o valor inicial do movimento. Deve ser um valor entre os valores definidos nas propriedades RangeMax e
RangeMin.

4.3.2.5 Animação com Translação


Esta seção contém informações sobre propriedades do objeto Animação com Translação (DynamicMove). Este objeto
não possui eventos nem métodos associados.

4.3.2.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Animar com Translação (DynamicMove).

4.3.2.5.1.1 Detents
Esta propriedade determina o número de passos do movimento deste objeto.

4.3.2.5.1.2 EnableOverrideLineColor
Esta propriedade habilita ou desabilita este objeto a sobrescrever a cor original da linha da imagem pela cor
definida na propriedade OverrideLineColor. Se esta propriedade está habilitada, isto permite que seja modificada a
cor original da linha deste objeto pela cor definida na propriedade OverrideLineColor. Caso contrário, este objeto
exibe a cor original. O valor padrão desta propriedade é Falso.

4.3.2.5.1.3 EnableSlider
Esta propriedade habilita o slider no movimento deste objeto.

4.3.2.5.1.4 OverrideFillColor
Quando a propriedade OverrideFillMode é configurada com os valores 2 (dois) ou 3 (três), esta propriedade é
usada para definir a cor a ser usada no preenchimento dos objetos no movimento, ao invés da cor original. Nos
scripts, utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta
propriedade é vermelho (RGB(255, 0, 0)).

4.3.2.5.1.5 OverrideFillMode
Esta propriedade especifica o modo do preenchimento dos objetos que estão em movimento e altera o modo
original de preenchimento da imagem, sem alterar a configuração original de preenchimento dos objetos. Os valores
possíveis para esta propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade OverrideFillMode
OPÇÃO DESCRIÇÃO
0 - NoOverride Preenchimento original dos objetos (padrão)

1 - Wireframe Os objetos não são preenchidos, desenham somente as


bordas

105 Visualização
OPÇÃO DESCRIÇÃO
2 - SolidFill O preenchimento dos objetos contidos no grupo é
sólido com a cor especificada na propriedade
OverrideFillColor

3 - ByBrightness O preenchimento dos objetos contidos no grupo é


sólido com a cor especificada pela propriedade
OverrideFillColor, porém leva em conta qual era a
intensidade da cor original de preenchimento de cada
objeto

4.3.2.5.1.6 OverrideLineColor
Quando a propriedade EnableOverrideLineColor está configurada para Verdadeiro, esta propriedade é usada
para definir a cor a ser usada na cor da linha dos objetos em movimento, ao invés da cor original. Nos scripts, utilize
o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade
é vermelho (RGB(255, 0, 0)).

4.3.2.5.1.7 RangeMax
Esta propriedade determina o alcance máximo do movimento linear deste objeto.

4.3.2.5.1.8 RangeMin
Esta propriedade determina o alcance mínimo do movimento linear deste objeto.

4.3.2.5.1.9 Value
Indica o valor inicial do movimento. Deve ser um valor entre os valores definidos nas propriedades RangeMax e
RangeMin.

4.3.2.6 Arco de Elipse


Esta seção contém informações sobre propriedades do objeto Arco de Elipse (DrawArc). Este objeto não possui
eventos nem métodos associados.

4.3.2.6.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Arco de Elipse (DrawArc).

4.3.2.6.1.1 ArcBeginAngle
Esta propriedade configura o ângulo inicial do arco do objeto, em graus. O intervalo aceito por esta propriedade
vai de 0 (zero) até 359. O estilo e forma do arco dependem também das configurações das propriedades
ArcEndAngle e ArcStyle. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub CommandButton9_Click()
Screen.Item("Arco1").ArcBeginAngle = 12
End Sub

4.3.2.6.1.2 ArcEndAngle
Esta propriedade configura o ângulo final do arco do objeto, em graus. O intervalo aceito por esta propriedade vai
de 0 (zero) até 359. O estilo e forma do arco dependem também das configurações das propriedades ArcBeginAngle
e ArcStyle. O valor padrão desta propriedade é 270. Exemplo:
Sub CommandButton9_Click()
Screen.Item("Arco1").ArcEndAngle = 12
End Sub

4.3.2.6.1.3 ArcStyle
Esta propriedade especifica o estilo da borda ou linha do objeto. A borda do objeto é desenhada conforme o
estilo definido, utilizando a cor especificada em BorderColor com a espessura especificada em BorderWidth. A tabela
a seguir contém os valores válidos para esta propriedade.

Visualização 106
Opções disponíveis para a propriedade ArcStyle
OPÇÃO DESCRIÇÃO
0 - arc O estilo do desenho é um arco

1 - chord O estilo do desenho é uma corda, unindo o ponto inicial


e final

2 - pie O estilo do desenho é uma pizza (padrão)

Exemplo:
Sub CommandButton9_Click()
Screen.Item("Arco1").ArcStyle = 1
End Sub

4.3.2.7 Conector
Esta seção contém informações sobre propriedades do objeto Conector (DrawConnector). Este objeto não possui
eventos nem métodos associados.

4.3.2.7.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Conector (DrawConnector).

4.3.2.7.1.1 Points
Retorna o objeto Coleção de Pontos de Conexão dentro do Conector. O objeto Coleção de Pontos de Conexão é
utilizado para inserir, remover ou acessar os Pontos de Conexão disponíveis no Conector. Esta propriedade é
somente de leitura.

4.3.2.7.2 Coleção de Pontos de Conexão


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Pontos de Conexão
(DrawConnectorPoints). Este objeto não possui eventos associados.

4.3.2.7.2.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Pontos de Conexão (DrawConnectorPoints).
AddPoint
AddPoint(X, Y, [IndexAt])
Adiciona um Ponto de Conexão na Coleção de Pontos de Conexão e retorna este objeto. O objeto é inserido nas
coordenadas especificadas pelos parâmetros X e Y e no índice especificado pelo parâmetro IndexAt. Se este
parâmetro é omitido ou é igual a -1 (menos um), o Ponto de Conexão é adicionado ao final da sequência de Pontos
de Conexão. Caso contrário, o valor deste parâmetro deve ser um número entre 1 (um) e o valor da propriedade
Count menos um.
DeletePoint
DeletePoint(NameIndex)
Remove o Ponto de Conexão indicado pelo parâmetro NameIndex, que pode ser tanto o índice quanto o nome deste
Ponto de Conexão na Coleção de Pontos de Conexão. Só é possível remover Pontos de Conexão de uma Coleção de
Pontos de Conexão com mais de dois Pontos de Conexão.
Item
Item(NameIndex)
Retorna um objeto Ponto de Conexão indicado pelo parâmetro NameIndex, que tanto pode ser o índice quanto o
nome deste Ponto de Conexão na Coleção de Pontos de Conexão.

4.3.2.7.2.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Pontos de Conexão
(DrawConnectorPoints).
Count
Contém o número de Pontos de Conexão na Coleção. Esta propriedade é somente de leitura.

107 Visualização
4.3.2.7.2.3 Ponto de Conexão
Esta seção contém informações sobre métodos e propriedades do objeto Ponto de Conexão (DrawConnectorPoint).
Este objeto não possui eventos associados.
Métodos
Esta seção contém informações sobre os métodos do objeto Ponto de Conexão (DrawConnectorPoint).
ConnectTo
ConnectTo(Object, SlotNameIndex)
Conecta este Ponto de Conexão a um outro objeto de Tela, indicado no parâmetro Object, e desfaz a conexão
existente, se necessário. O parâmetro SlotNameIndex indica o índice ou o nome onde este Ponto de Conexão deve se
conectar na Coleção de Pontos de Conexão.
Delete
Delete()
Remove este Ponto de Conexão. Após utilizar este método, qualquer tentativa de acessar este objeto retorna um erro.
Disconnect
Disconnect([X], [Y])
Desconecta este Ponto de Conexão e retorna Verdadeiro se estava conectado ou Falso se não estava conectado. Os
parâmetros X e Y são opcionais e indicam as coordenadas horizontais e verticais deste Ponto de Conexão.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Ponto de Conexão (DrawConnectorPoint).
IsConnected
Indica se este Ponto de Conexão está conectado ou não a algum objeto de Tela. Caso esteja conectado, as
propriedades X e Y podem ser lidas mas não modificadas.
Name
Retorna o nome deste Ponto de Conexão. Esta propriedade é somente de leitura.

NOTA
· O nome de um Ponto de Conexão pode mudar ao inserir ou remover Pontos de Conexão da Coleção de Pontos
de Conexão.
· O primeiro e o último Ponto de Conexão na Coleção de Pontos de Conexão são nomeados, respectivamente,
como "Begin" e "End". Todos os outros Pontos são nomeados como "PlugN", onde N é o índice do Ponto na
Coleção.

X
Indica a coordenada horizontal deste Ponto de Conexão em relação à borda esquerda da Tela, em unidades
Himetric.
Y
Indica a coordenada vertical deste Ponto de Conexão em relação à borda superior da Tela, em unidades Himetric.

4.3.2.8 E2Controls
Esta seção contém informações sobre eventos, métodos e propriedades de objetos E2Controls.

4.3.2.8.1 Propriedades Comuns


Esta seção contém informações sobre propriedades comuns aos objetos E2Controls.

4.3.2.8.1.1 Frame_BorderColor
Define uma cor para a moldura de um objeto.

4.3.2.8.1.2 Frame_BorderEnabled
Habilita ou desabilita a moldura de um objeto.

Visualização 108
4.3.2.8.1.3 Frame_BorderThickness
Define a espessura da moldura de um objeto, em pixels.

4.3.2.8.1.4 Frame_Color
Define a cor de fundo da área de título de um objeto. O valor padrão desta propriedade é cinza (RGB(192, 192,
192)).

4.3.2.8.1.5 Frame_Enable
Habilita ou desabilita a exibição da moldura de um objeto. O valor padrão desta propriedade é Verdadeiro, exceto
para o objeto E2Button.

4.3.2.8.1.6 Frame_Enable3D
Habilita ou desabilita o efeito 3D para a moldura de um objeto.

4.3.2.8.1.7 Frame_Separator
Habilita ou desabilita a exibição de uma linha separadora entre o título e o objeto.

4.3.2.8.1.8 Frame_Set3DInset
Se esta propriedade estiver ajustada para Verdadeiro, a borda de um objeto aparece rebaixada. Se estiver ajustada
para Falso (valor padrão), a borda do objeto aparece ressaltada.

4.3.2.8.1.9 Frame_Thickness3D
Define a espessura da borda 3D da moldura de um objeto, em pixels.

4.3.2.8.1.10 Frame_Title
Esta propriedade define o título da moldura de um objeto.

4.3.2.8.1.11 Frame_TitleColor
Define a cor da fonte do título da moldura de um objeto. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.3.2.8.1.12 Frame_TitleEnabled
Habilita ou desabilita a exibição do título da moldura de um objeto. O valor padrão desta propriedade é
Verdadeiro.

4.3.2.8.1.13 Frame_TitleFont
Esta propriedade é utilizada para determinar a fonte do título da moldura de um objeto. Esta propriedade não
pode ser utilizada em scripts ou em Associações e é configurada unicamente via E3 Studio. Consulte o tópico Fonte
para mais informações sobre as subpropriedades desta propriedade.

4.3.2.8.2 E2Animation
Esta seção contém informações sobre propriedades do objeto E2Animation. Este objeto não possui eventos nem
métodos associados.

4.3.2.8.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Animation.
BackgroundColor
Esta propriedade define a cor de fundo do objeto E2Animation. O valor padrão desta propriedade é branco
(RGB(255, 255, 255)).
BlinkTime
Define o intervalo de tempo, em milissegundos, do efeito de piscar do objeto.
Border
Habilita ou desabilita a exibição de uma borda ao redor do objeto.

109 Visualização
DefaultZone
Define a zona padrão que é mostrada quando o Tag associado estiver fora dos limites das outras zonas definidas
para o objeto.
IsTransparent
Se o valor desta propriedade for Verdadeiro, define que o fundo do objeto é transparente, permitindo que o fundo
da Tela apareça. Caso contrário, a cor de fundo é sólida, definida em BackgroundColor.
Value
Essa propriedade define o valor que determina qual a Zona ativa. O valor padrão desta propriedade é 0 (zero).
Zones
Coleção de Zonas do objeto E2Animation. Esta propriedade é somente de leitura.

4.3.2.8.2.2 Coleção de Zonas


Esta seção contém informações sobre métodos do objeto Coleção de Zonas (AnimationZoneCollection). Este objeto
não contém eventos nem propriedades associadas.
Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Zonas (AnimationZoneCollection).
Add
Add([AxisName])
Adiciona uma nova Zona na Coleção de Zonas. O parâmetro AxisName é opcional e não tem efeito, sendo mantido
por questões de compatibilidade com versões anteriores.
Remove
Remove(Index)
Remove uma Zona. O parâmetro Index indica o índice da Zona que deve ser removida.
Zonas
As Zonas definem um conjunto de imagens de bitmap que são usadas para criar o efeito de animação no objeto. As
Zonas (AnimationZone) podem ser configuradas acessando a janela Propriedades do objeto, na aba E2Animation. As
opções desta janela estão descritas na tabela a seguir.
Opções disponíveis na aba E2Animation
OPÇÃO DESCRIÇÃO
Zonas Listagem com todas as Zonas definidas no objeto

Adicionar Adiciona uma nova Zona

Remover Apaga a Zona selecionada

Zona Padrão Define a Zona selecionada como a Zona padrão do


objeto

Pisca Define se o bitmap pisca quando o valor do objeto


estiver dentro do intervalo da Zona

Dica Mostra um texto de ajuda sobre a Zona

Mínimo Valor mínimo para a variação da Zona

Máximo Valor máximo para a variação da Zona

Arquivo de imagem Nome do arquivo de bitmap que é mostrado quando o


valor do objeto estiver dentro do intervalo da Zona

Exemplo Mostra uma prévia do arquivo de bitmap da Zona


selecionada

Propriedades
Esta seção contém informações sobre as propriedades das Zonas do objeto E2Animation (AnimationZone).
Blink
Indica que esta Zona participa do efeito de piscar. O valor padrão desta propriedade é Falso.

Visualização 110
Filename
Indica qual o nome do arquivo de imagem utilizado na Zona.
Maximum
Define o valor máximo para a Zona. O valor padrão desta propriedade é 20000.
Minimum
Define o valor mínimo para a Zona. O valor padrão desta propriedade é 0 (zero).
TipEnable
Habilita ou desabilita a dica para a Zona. O valor padrão desta propriedade é Falso.
TipText
Define o texto da dica para a Zona. O valor padrão desta propriedade é uma String em branco.

4.3.2.8.3 E2Bitmap
Esta seção contém informações sobre propriedades do objeto E2Bitmap. Este objeto não possui eventos nem
métodos associados.

4.3.2.8.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Bitmap.
Filename
Define o nome do arquivo de imagem associado ao objeto E2Bitmap. O caminho do arquivo pode ser tanto o
caminho completo do arquivo no disco, quanto o caminho relativo à aplicação (quando o arquivo de imagem é
inserido como um Recurso da aplicação). O valor padrão desta propriedade é vazio.
IsTransparent
Esta propriedade habilita ou desabilita a transparência do objeto, baseada na cor definida na propriedade
TransparentColor.
TransparentColor
Define qual cor é considerada pela propriedade IsTransparent como sendo transparente. O valor padrão desta
propriedade é branco (RBG(255, 255, 255)).

4.3.2.8.4 E2Button
Esta seção contém informações sobre eventos e propriedades do objeto E2Button. Este objeto não possui métodos
associados.

4.3.2.8.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto E2Button.
OnRelease
OnRelease()
Este evento é gerado quando o botão do mouse é solto.

4.3.2.8.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Button.
Action
Esta propriedade define o comportamento do objeto E2Button quando é clicado. Os valores possíveis para esta
propriedade são:
· 0 - MOMENTARY: Comportamento normal do botão, aparecendo rebaixado somente enquanto o mouse está
pressionado (padrão)
· 1 - TOGGLE: Possui dois estados, ligado e desligado
· 2 - JOG: Alterna entre dois valores, um quando o botão é pressionado e outro quando o botão é solto
Alignment
Determina o alinhamento do texto do botão. Os valores possíveis desta propriedade são:
· 0 - HorizontalAlignmentLeft: Alinha o texto à esquerda

111 Visualização
· 1 - HorizontalAlignmentCenter: Alinha o texto ao centro (padrão)
· 2 - HorizontalAlignmentRight: Alinha o texto à direita
BackgroundColor0
Define a cor de fundo do botão, quando não está pressionado. O valor padrão desta propriedade é cinza
(RGB(192, 192, 192)).
BackgroundColor1
Define a cor de fundo do botão, quando está pressionado. O valor padrão desta propriedade é cinza (RGB(192,
192, 192)).
Bitmap0
Define a imagem do botão, quando não está pressionado. O valor padrão desta propriedade é vazio.
Bitmap1
Define a imagem do botão, quando está pressionado. O valor padrão desta propriedade é vazio.
Text0
Define o texto do botão, quando não está pressionado. O valor padrão desta propriedade é "DESLIGADO".
Text1
Define o texto do botão, quando está pressionado. O valor padrão desta propriedade é "LIGADO".
TextColor0
Define a cor do texto do botão, quando não está pressionado. O valor padrão desta propriedade é preto (RGB(0,
0, 0)).
TextColor1
Define a cor do texto do botão, quando está pressionado. O valor padrão desta propriedade é preto (RGB(0, 0,
0)).
TextFont0
Esta propriedade é utilizada para determinar a fonte deste botão quando não está pressionado. Esta propriedade
não pode ser utilizada em scripts ou em Associações, sendo configurada unicamente via E3 Studio. Consulte o tópico
Fonte para mais informações sobre as subpropriedades desta propriedade.
TextFont1
Esta propriedade é utilizada para determinar a fonte deste botão quando está pressionado. Esta propriedade não
pode ser utilizada em scripts ou em Associações, sendo configurada unicamente via E3 Studio. Consulte o tópico
Fonte para mais informações sobre as subpropriedades desta propriedade.
Type
Define o tipo do botão. Os valores possíveis para esta propriedade são os seguintes:
· 0 - ButtonTypeKey: Comportamento normal de um botão (padrão)
· 1 - ButtonTypeSwitchH: O comportamento do botão é o de uma chave dividida horizontalmente
· 2 - ButtonTypeSwitchV: O comportamento do botão é o de uma chave dividida verticalmente
· 3 - ButtonTypeLeverH: O comportamento do botão é o de uma alavanca que se movimenta da esquerda para a
direita e vice-versa
· 4 - ButtonTypeLeverV: O comportamento do botão é o de uma alavanca que se movimenta de cima para baixo
e vice-versa
· 5 - ButtonTypeTransparent: O botão é transparente
· 6 - ButtonTypeUserBitmap: O botão alterna a exibição das imagens definidas nas propriedades Bitmap0 e
Bitmap1
· 7 - ButtonTypeCheckbox: O comportamento do botão é o mesmo de uma Caixa de Seleção
· 8 - ButtonTypeRadio: O comportamento do botão é o mesmo de um Botão de Opções
Value
Esta propriedade é um Variant que assume o valor contido na propriedade Value0 se o botão não está
pressionado, e o valor contido na propriedade Value1 se o botão está pressionado.
Value0
Define o valor da propriedade Value, quando o botão não está pressionado.

Visualização 112
Value1
Define o valor da propriedade Value, quando o botão está pressionado.

4.3.2.8.5 E2Display
Esta seção contém informações sobre propriedades do objeto E2Display. Este objeto não possui eventos nem
métodos associados.

4.3.2.8.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Display.
BackgroundColor
Esta propriedade define a cor de fundo do objeto. O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).
BackgroundStyle
Define o estilo de fundo do objeto. Os valores desta propriedade são os seguintes:
· 0 - bsTransparent: O fundo é transparente
· 1 - bsOpaque: A cor definida em BackgroundColor é vísivel (padrão)
Format
Contém um texto que representa uma máscara, dentro da qual os valores do objeto são mostrados. Esta máscara
pode representar vários tipos de valores:
· Geral: Não possui formatação específica, adaptando-se automaticamente ao valor especificado
· Número: Apresenta números com parte inteira e fracionária. O usuário pode optar por até 15 casas decimais, por
usar ou não um separador de milhares, e por apresentar números negativos com sinal ou entre parênteses. Para
números muito grandes ou muito pequenos, recomenda-se utilizar o formato Científico
· Data: Apresenta valores numéricos de data e hora (quando válidos). Para representar apenas a hora, use o
formato equivalente
· Hora: Apresenta valores numéricos de hora e data (quando válidos). Para representar apenas a data, use o
formato equivalente
· Porcentagem: Multiplica o número por 100 e adiciona o símbolo de porcentagem. Admite até 15 casas decimais
· Científico: Apresenta o número em notação de mantissa e expoente. Ideal para números de magnitude variada.
Admite até 15 casas decimais
· Especial: Permite formatar números inteiros em bases não decimais (hexadecimal, octal ou binária, por exemplo)
· Outro: Permite editar diretamente o código de formatação desejado, ou selecionar um formato criado
anteriormente
HorizontalAlignment
Define o alinhamento horizontal do texto do E2Display. Os valores desta propriedade são os seguintes:
· 0 - HorizontalAlignmentLeft: Alinha horizontalmente à esquerda
· 1 - HorizontalAlignmentCenter: Alinha horizontalmente ao centro (padrão)
· 2 - HorizontalAlignmentRight: Alinha horizontalmente à direita
MultiLine
Define se o objeto possui múltiplas linhas ou não. Esta propriedade só tem efeito se a propriedade Value for do
tipo String.
TextColor
Define a cor do texto do objeto. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
TextFont
Esta propriedade é utilizada para determinar a fonte deste objeto. Esta propriedade não pode ser utilizada em
Associações. Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.
Value
Esta propriedade contém um Variant que pode assumir valores de todo e qualquer tipo de dados, e a forma de
apresentação destes valores é definida pela propriedade Format.
VerticalAlignment
Define o alinhamento vertical do texto do E2Display. Os valores desta propriedade são os seguintes:

113 Visualização
· 0 - VerticalAlignmentTop: Alinha verticalmente com a parte superior do objeto
· 1 - VerticalAlignmentMiddle: Alinha verticalmente com o centro do objeto (padrão)
· 2 - VerticalAlignmentBottom: Alinha verticalmente com a parte inferior do objeto

4.3.2.8.6 E2Gauge
Esta seção contém informações sobre propriedades do objeto E2Gauge. Este objeto não possui eventos nem
métodos associados.

4.3.2.8.6.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Gauge.
BackgroundColor
Esta propriedade define a cor de fundo do objeto. O valor padrão desta propriedade é cinza (RGB(128, 128, 128)).
BulletsVisible
Exibe ou esconde as marcas da escala em forma de bullet.
DecimalPlaces
Esta propriedade define o número de casas decimais para o valor nominal do E2Gauge.
FrameColor
Define a cor de fundo do objeto.
HiColorLegend
Define a cor da legenda para o limite Alto. O valor padrão desta propriedade é amarelo (RGB(255, 255, 0)).
HiDiv
Marca o início da escala para o limite Alto. O valor padrão desta propriedade é 13300.
HiHiColorLegend
Define a cor da legenda para o limite Muito Alto. O valor padrão desta propriedade é vermelho (RGB(255, 0, 0)).
HiHiDiv
Marca o início da escala para o limite Muito Alto. O valor padrão desta propriedade é 16600.
HiHiLimitVisible
Habilita ou desabilita a exibição do limite Muito Alto.
HiLimit
O valor máximo dessa propriedade é 1 (um) e o mínimo é limitado pela propriedade LowLimit. O valor padrão
desta propriedade é 0,7.
HiLimitVisible
Habilita ou desabilita a exibição do limite Alto.
LegendVisible
Exibe uma barra ao longo do objeto E2Gauge, onde podem ser configuradas diferentes cores, dependendo da
faixa de valores. O valor padrão desta propriedade é Verdadeiro.
LimitVisible
Define se os valores mínimos e máximos da escala aparecem ou não no gráfico.
LowColorLegend
Define a cor da legenda para o limite Baixo. O valor padrão desta propriedade é verde escuro (RGB(0, 128, 0)).
LowDiv
Marca o início da escala para o limite Baixo. O valor padrão desta propriedade é 6600.
LowLimit
O valor mínimo desta propriedade é 0,1 e o máximo é limitado pela propriedade HiLimit. O valor padrão desta
propriedade é 0,62.
LowLimitVisible
Habilita ou desabilita a exibição do limite Baixo.

Visualização 114
LowLowColorLegend
Define a cor da legenda para o limite Muito Baixo. O valor padrão desta propriedade é verde (RGB(0, 255, 0)).
LowLowDiv
Marca o início da escala para o limite Muito Baixo. O valor padrão desta propriedade é 3300.
LowLowLimitVisible
Habilita ou desabilita a exibição do limite Muito Baixo.
Maximum
Define o valor máximo da escala do E2Gauge.
Minimum
Define o valor mínimo da escala do E2Gauge.
NeedleColor
Define a cor do ponteiro do E2Gauge. O valor padrão desta propriedade é branco (RGB(255, 255, 255)).
NeedleThickness
Define a espessura do ponteiro do E2Gauge, em pixels. O valor padrão desta propriedade é 2 (dois), e só são
aceitos os valores 1 (um) ou 2 (dois).
NormalColor
Define a cor da legenda para o limite Normal. O valor padrão desta propriedade é oliva (RGB(128, 128, 0)).
NumberOfPoints
Define o número de subdivisões que estão visíveis na escala do objeto.
Orientation
Define a orientação do objeto E2Gauge. Os valores possíveis desta propriedade são os seguintes:
· 0 - Left: A parte inferior do objeto está alinhada com o lado esquerdo da moldura
· 1 - Up: A parte inferior do objeto está alinhada com a parte de cima da moldura
· 2 - Down: A parte inferior do objeto está alinhada com a parte de baixo da moldura (padrão)
· 3 - Right: A parte inferior do objeto está alinhada com o lado direito da moldura
Reverted
Habilita ou desabilita a reversão da escala do objeto.
ShowFrame
Habilita ou desabilita a exibição do fundo ao longo do percurso do ponteiro.
StartAngle
Define o ângulo inicial de exibição do ponteiro do objeto E2Gauge.
SubTickColor
Define a cor das subdivisões da escala. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
SubTicksVisible
Habilita ou desabilita a exibição das subdivisões da escala.
TextColor
Define a cor do texto da escala. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
TextFont
Esta propriedade é utilizada para determinar a fonte do texto da escala. Esta propriedade não pode ser utilizada
em Associações. Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.
ThickTicks
Habilita ou desabilita a exibição de divisores da escala mais espessos. O valor padrão desta propriedade é Falso.
TickColor
Define a cor dos divisores da escala. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
TicksVisible
Habilita ou desabilita a exibição das divisões da escala.

115 Visualização
TickValues
Habilita ou desabilita a exibição dos valores das divisões da escala.
TotalNumberOfSubTicks
Define o número total de subdivisões que são mostradas na escala.
Value
Esta propriedade define um valor entre as propriedades Maximum e Minimum da escala do objeto.
ValueVisible
Habilita ou desabilita a exibição do valor contido na propriedade Value. O valor padrão desta propriedade é Falso.

4.3.2.8.7 E2Setpoint
Esta seção contém informações sobre propriedades do objeto E2Setpoint. Este objeto não possui eventos nem
métodos associados.

4.3.2.8.7.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Setpoint.
AutoSend
Se esta propriedade estiver em Verdadeiro (valor padrão), o valor definido na propriedade Value é atualizado nas
Associações assim que o objeto perder o foco. Caso contrário, as Associações só recebem o valor quando for usada
a tecla ENTER.
BackgroundColor
Esta propriedade define a cor de fundo do objeto. O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).
BackgroundStyle
Define o estilo de fundo do objeto. Os valores desta propriedade são os seguintes:
· 0 - bsTransparent: O fundo é transparente
· 1 - bsOpaque: A cor definida em BackgroundColor é vísivel (padrão)
EnableMaxLimit
Habilita ou desabilita a definição de um limite máximo para o valor do E2Setpoint.
EnableMinLimit
Habilita ou desabilita a definição de um limite mínimo para o valor do E2Setpoint.
Format
Contém um texto que representa uma máscara, dentro da qual os valores do objeto são mostrados. Esta máscara
pode representar vários tipos de valores:
· Geral: Não possui formatação específica, adaptando-se automaticamente ao valor especificado
· Número: Apresenta números com parte inteira e fracionária. O usuário pode optar por até 15 casas decimais, por
usar ou não um separador de milhares, e por apresentar números negativos com sinal ou entre parênteses. Para
números muito grandes ou muito pequenos, recomenda-se utilizar o formato Científico
· Data: Apresenta valores numéricos de data e hora (quando válidos). Para representar apenas a hora, use o
formato equivalente
· Hora: Apresenta valores numéricos de hora e data (quando válidos). Para representar apenas a data, use o
formato equivalente
· Porcentagem: Multiplica o número por 100 e adiciona o símbolo de porcentagem. Admite até 15 casas decimais
· Científico: Apresenta o número em notação de mantissa e expoente. Ideal para números de magnitude variada.
Admite até 15 casas decimais
· Especial: Permite formatar números inteiros em bases não decimais (hexadecimal, octal ou binária, por exemplo)
· Outro: Permite editar diretamente o código de formatação desejado, ou selecionar um formato criado
anteriormente
HorizontalAlignment
Define o alinhamento horizontal do texto do E2Setpoint. Os valores desta propriedade são os seguintes:
· 0 - HorizontalAlignmentLeft: Alinha horizontalmente à esquerda
· 1 - HorizontalAlignmentCenter: Alinha horizontalmente ao centro (padrão)

Visualização 116
· 2 - HorizontalAlignmentRight: Alinha horizontalmente à direita
HScroll
Habilita ou desabilita a exibição de uma barra de rolagem horizontal no texto, caso a propriedade Multiline esteja
em Verdadeiro.
MaxLimit
Limite máximo que pode ser atingido pela propriedade Value do objeto. O valor padrão desta propriedade é 200.
O limite só é verificado se a propriedade EnableMaxLimit estiver habilitada.
MinLimit
Limite mínimo que pode ser atingido pela propriedade Value do objeto. O valor padrão desta propriedade é 0
(zero). O limite só é verificado se a propriedade EnableMinLimit estiver habilitada.
MultiLine
Define se o objeto possui múltiplas linhas ou não. Esta propriedade só está disponível se a propriedade Value for
do tipo String.
ReadOnly
Indica se o objeto pode ser editado ou não em tempo de execução. O valor padrão desta propriedade é Falso.
Refresh
Indica se o valor do E2Setpoint é atualizado ou não sempre que o valor do Tag mudar. O valor padrão desta
propriedade é Verdadeiro.
SelectAllOnFocus
Habilita ou desabilita a seleção de todos os caracteres do E2Setpoint quando o objeto recebe o foco. O valor
padrão desta propriedade é Verdadeiro.
TextColor
Define a cor do texto do objeto. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
TextFont
Esta propriedade é utilizada para determinar a fonte deste objeto. Esta propriedade não pode ser utilizada
Associações. Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.
Type
Define o tipo de Setpoint. Os valores possíveis desta propriedade são os seguintes:
· 0 - setpointString: Aceita quaisquer caracteres alfanuméricos
· 1 - setpointNumeric: Aceita somente caracteres numéricos e o separador decimal (ponto ou vírgula, dependendo
das configurações regionais, padrão)
· 2 - setpointDateTime: Aceita somente valores de data e hora, que são convertidos para o formato definido nas
configurações regionais
Value
Esta propriedade define um valor para o E2Setpoint. A forma como este valor é visualizado é definida na
propriedade Format.
VerticalAlignment
Define o alinhamento vertical do texto do E2Setpoint. Os valores desta propriedade são os seguintes:
· 0 - VerticalAlignmentTop: Alinha verticalmente com a parte superior do objeto
· 1 - VerticalAlignmentMiddle: Alinha verticalmente com o centro do objeto (padrão)
· 2 - VerticalAlignmentBottom: Alinha verticalmente com a parte inferior do objeto
VScroll
Habilita ou desabilita a exibição de uma barra de rolagem vertical no texto, caso a propriedade Multiline esteja em
Verdadeiro.

4.3.2.8.8 E2Text
Esta seção contém informações sobre propriedades do objeto E2Text. Este objeto não possui eventos nem métodos
associados.

117 Visualização
4.3.2.8.8.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto E2Text.
BlinkTime
Define o intervalo de tempo, em milissegundos, do efeito de piscar do objeto.
DefaultZone
Define a Zona padrão do objeto.
Value
Esta propriedade contém um Variant que pode assumir valores de todo e qualquer tipo de dados (Integer,
Boolean, String, etc.).
Zones
Coleção de Zonas do objeto E2Text. Esta propriedade é somente de leitura.

4.3.2.8.8.2 Coleção de Zonas


Esta seção contém informações sobre métodos do objeto Coleção de Zonas do objeto E2Text (TextZoneCollection).
Este objeto não possui eventos nem propriedades associadas.
Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Zonas do E2Text (TextZoneCollection).
Add
Add([AxisName])
Adiciona uma nova Zona na Coleção de Zonas. O parâmetro AxisName é opcional e não tem efeito, sendo mantido
por questões de compatibilidade com versões anteriores.
Remove
Remove(Index)
Remove uma Zona. O parâmetro Index indica o índice da Zona que deve ser removida.
Zonas
As Zonas definem um conjunto de Zonas de Texto (TextZone) para o objeto E2Text. Estas Zonas podem ser
configuradas acessando a janela de propriedades do objeto, na aba Zonas. As opções disponíveis nesta aba estão
descritas na tabela a seguir.
Opções disponíveis na aba Zonas
OPÇÃO DESCRIÇÃO
Zonas Listagem com todas as Zonas definidas no objeto

Adicionar Adiciona uma nova Zona

Remover Remove a Zona selecionada

Pisca a cada (ms) Define se o texto e o fundo da Zona piscam quando o


valor do objeto estiver dentro do intervalo da Zona

Mensagem Texto da mensagem exibida quando o valor do objeto


estiver dentro do intervalo da Zona

Alinhamento Define o alinhamento do texto

Fonte Define a fonte do texto

Cor de fundo Define a cor de fundo da Zona

Transparente Define se o fundo do objeto é transparente quando a


Zona estiver ativa

Zona padrão Define a Zona selecionada como a Zona padrão do


objeto

Pisca Define se a Zona pisca quando o valor do objeto estiver


dentro do intervalo da Zona

Mínimo Valor mínimo para a Zona

Visualização 118
OPÇÃO DESCRIÇÃO
Máximo Valor máximo para a Zona

Dica Mostra um texto de ajuda para a Zona

Exemplo Mostra um exemplo do comportamento da Zona em


tempo de execução

A seção a seguir contém informações sobre as propriedades do objeto Zona de uma Coleção de Zonas de um objeto
E2Text (TextZone). Este objeto não possui eventos nem métodos associados.
Propriedades
Esta seção contém informações sobre as propriedades dos objetos Zona (TextZone) de um objeto E2Text.
BackgroundColor
Define a cor de fundo do texto da Zona. O valor padrão desta propriedade é branco (RGB(255, 255, 255)).
Blink
Indica que esta Zona participa do efeito de piscar. O valor padrão desta propriedade é Falso. Se estiver habilitada,
esta Zona alterna com a Zona padrão, conforme o tempo definido na propriedade BlinkTime do objeto E2Text.
HorizontalAlignment
Define o alinhamento do texto. Os valores possíveis são:
· 0 - HorizontalAlignmentLeft: Alinha horizontalmente à esquerda
· 1 - HorizontalAlignmentCenter: Alinha horizontalmente ao centro (padrão)
· 2 - HorizontalAlignmentRight: Alinha horizontalmente à direita
Maximum
Define o valor máximo para a Zona. O valor padrão desta propriedade é 20000.
Message
Define o texto associado à Zona. Esta mensagem é mostrada quando o Tag associado estiver dentro dos limites da
Zona.
Minimum
Define o valor mínimo para a Zona. O valor padrão desta propriedade é 0 (zero).
TextColor
Define a cor do texto da Zona. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).
TextFont
Define o estilo, a cor e o tamanho da fonte usada para mostrar o texto da mensagem. Esta propriedade não pode
ser utilizada em Associações. Consulte o tópico Fonte para mais informações sobre as subpropriedades desta
propriedade.
TipEnable
Habilita ou desabilita a dica para a Zona. O valor padrão desta propriedade é Falso.
TipText
Define o texto da dica para a Zona. O valor padrão desta propriedade é uma String vazia.
Transparent
Define que o fundo do objeto é transparente quando esta Zona estiver ativa.

4.3.2.9 Elipse KeyPad


Esta seção contém informações sobre métodos e propriedades do objeto Elipse KeyPad. Este objeto não possui
eventos associados.

4.3.2.9.1 Métodos
Esta seção contém informações sobre os métodos do objeto Elipse KeyPad.

119 Visualização
4.3.2.9.1.1 Hide

Hide()
Oculta o Elipse KeyPad. Este método não tem efeito se o KeyPad já está invisível.

4.3.2.9.1.2 Show

Show()
Mostra o Elipse KeyPad. Este método não tem efeito se o KeyPad já está visível na tela.

4.3.2.9.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Elipse KeyPad.

4.3.2.9.2.1 AutoHideOnEnter
Automaticamente oculta o KeyPad quando a tecla ENTER do teclado virtual é pressionada.

4.3.2.9.2.2 AutoHideOnEsc
Automaticamente oculta o KeyPad quando a tecla ESC do teclado virtual é pressionada.

4.3.2.9.2.3 Layout
Permite alterar o layout de apresentação do KeyPad. Os valores possíveis desta propriedade são os seguintes:
· br-simple: Mostra um teclado alfanumérico

Exemplo de KeyPad alfanumérico


· num: Mostra um teclado numérico

Exemplo de KeyPad numérico

Visualização 120
Exemplo:
' Alterna entre os modos Alfanumérico e Numérico
Sub ToggleButton1_Click()
If ToggleButton1.Value Then
Application.GetKeyPad().Layout = "br-simple"
Else
Application.GetKeyPad().Layout = "num"
End If
End Sub

4.3.2.9.2.4 SizeFactor
Aumenta ou diminui o tamanho original do KeyPad, utilizando um fator de multiplicação. O tamanho original do
KeyPad é mostrado na tabela a seguir.
Valores padrão de tamanho do KeyPad
LAYOUT LARGURA ALTURA
Alfanumérico 550 px 250 px

Numérico 200 px 300 px

O exemplo a seguir redimensiona o KeyPad para 75% do tamanho original.


Sub Botao1_Click()
Application.GetKeyPad().SizeFactor = 0.75
Application.GetKeyPad().Show()
End Sub

4.3.2.9.2.5 Sound
Permite alterar o som emitido ao clicar-se em uma tecla do KeyPad. O valor padrão desta propriedade é uma
String vazia, significando que nenhum som é emitido ao clicar-se em uma tecla. Caso seja alterado o valor desta
propriedade, é necessário que o novo valor seja o caminho absoluto de um arquivo no formato WAV ou então que
este arquivo esteja incluído no Domínio como um Recurso.

4.3.2.9.2.6 X
A coordenada X do canto superior esquerdo do objeto KeyPad. Esta propriedade pode ser usada para mover o
KeyPad no sentido horizontal.

4.3.2.9.2.7 Y
A coordenada Y do canto superior esquerdo do objeto KeyPad. Esta propriedade pode ser usada para mover o
KeyPad no sentido vertical.

4.3.2.10 Escala
Esta seção contém informações sobre propriedades do objeto Escala (DrawScale). Este objeto não possui eventos
nem métodos associados.

4.3.2.10.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Escala (DrawScale).

4.3.2.10.1.1 BackgroundColor
Esta propriedade especifica a cor de preenchimento do fundo do objeto. Esta cor é utilizada quando a propriedade
BackgroundStyle está configurada para 1 (um, opaco) e umas das propriedades VerticalPercentFill ou
HorizontalPercentFill está com valores diferentes de 100. Outro uso desta cor é quando a propriedade FillStyle está
configurada entre os valores 2 (dois) e 8 (oito). Isto permite que a área restante utilize a cor de fundo para
preenchimento. Nos scripts, utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade.
O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).

4.3.2.10.1.2 BorderColor
Esta propriedade determina a cor da borda que é aplicada no objeto Escala. Com esta propriedade, é possível
aplicar a cor padrão ou personalizá-la através da edição. O valor padrão desta propriedade é branco (RGB(255, 255,
255)). Exemplo:

121 Visualização
Sub Escala1_Click()
BorderColor = RGB (255, 0, 0)
End Sub

4.3.2.10.1.3 BorderStyle
Esta propriedade determina o estilo de borda que é aplicada ao objeto Escala. Os valores possíveis para esta
propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade BorderStyle
OPÇÃO DESCRIÇÃO
0 - Normal Aplica uma borda sólida na grade vertical da escala

1 - Dash Aplica uma borda de linha tracejada na escala

2 - Dot Aplica uma borda pontilhada na escala

3 - DashDot Aplica uma borda de traço e ponto na escala

4 - DashDotDot Aplica uma borda de traço, ponto e ponto na escala

5 - Null O objeto não tem borda (padrão)

4.3.2.10.1.4 BorderWidth
Esta propriedade determina a largura, em pixels, da borda do objeto Escala. Através desta propriedade, é possível
configurar a largura da borda sem precisar modificar a estrutura. O valor padrão desta propriedade é 0 (zero).

4.3.2.10.1.5 ForegroundColor
Esta propriedade especifica a cor do preenchimento da frente do objeto. Esta cor é utilizada quando a propriedade
FillStyle está configurada para 0 (zero, sólido) ou entre 2 (dois) e 9 (nove). Nos scripts, utilize o método RGB do
VBScript para montar a cor a ser associada a esta propriedade. O valor padrão para esta propriedade é azul (RGB(0,
0, 255)). Exemplo:
Sub Botao1_Click()
' Troca a cor de fundo do botao para verde
'quando se clica no objeto
ForegroundColor = RGB(0, 255, 0)
End Sub

4.3.2.10.1.6 Format
Esta propriedade especifica que tipo de formato é atribuído ao objeto. Permite mudar a forma como os dados são
apresentados sem mudar o valor existente por trás destes dados. Esta propriedade pode ser editada manualmente
ou configurada através da janela de formatação. O uso é semelhante aos formatadores usados nas planilhas de
dados, seguindo a mesma sintaxe. A tabela a seguir contém os tipos de dados suportados.
Tipos de dados suportados pela propriedade Format
TIPO DE DADOS DESCRIÇÃO
Numérico Saída decimal, científica, hexadecimal, binária ou octal

Texto Textos em geral

Booleano Valores Booleanos

Data/Hora Calendário Gregoriano

4.3.2.10.1.7 LineColor
Determina a cor da linha com as marcas divisórias e subdivisórias da Escala. Para determinar a cor da legenda com
números do objeto, use a propriedade TextColor. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.3.2.10.1.8 MaximumValue
Esta propriedade determina o valor máximo atingido pela Escala. O valor padrão desta propriedade é 100.
Exemplo:
Sub CommandButton_Click()
' Ao clicar no botão, abre um MessageBox indicando
' o valor máximo da propriedade da escala

Visualização 122
MsgBox CSTr(Screen.Item("Escala1").MaximumValue)
End Sub

4.3.2.10.1.9 MinimumValue
Esta propriedade determina o valor mínimo requerido pela Escala. O valor padrão desta propriedade é 0 (zero).
Exemplo:
Sub CommandButton1_Click()
' Ao clicar no botão, abre um MessageBox indicando
' o valor da propriedade Minimum do Escala1
MsgBox _
CSTr(Application.GetObject("Dados.Escala1").MinimumValue)
End Sub

4.3.2.10.1.10 MinorTicks
Esta propriedade determina a quantidade de marcas da Escala. O valor padrão desta propriedade é 3 (três).
Exemplo:
Sub CommandButton1_Click()
' Mostra o total de marcas da escala
MsgBox CStr(Screen.Item("Escala1").MinorTicks)
End Sub

4.3.2.10.1.11 MinorTicksPercentSize
Esta propriedade determina o tamanho das marcas que subdividem cada medida do objeto Escala. O valor padrão
desta propriedade é 10.

4.3.2.10.1.12 ScaleAlignment
Esta propriedade determina o tipo de alinhamento que é atribuído à Escala. Os valores possíveis são 0 -
RightSide: À direita (padrão) ou 1 - LeftSide: À esquerda.

4.3.2.10.1.13 ShowText
Esta propriedade determina a visibilidade do texto na legenda do objeto Escala. Se esta propriedade está
habilitada, o texto é mostrado. Caso contrário, o objeto mostra somente as linhas e subdivisões da Escala. O valor
padrão desta propriedade é Verdadeiro.

4.3.2.10.1.14 StretchText
Esta propriedade determina a aplicação de extensão (stretch) ao texto do objeto Escala. Caso a largura ou altura da
Escala sejam alteradas, o texto acompanha esta variação. Se esta propriedade está habilitada, o objeto acompanha as
variações de altura e largura do objeto conforme seja transformado. Caso contrário, o texto permanece com as
configurações iniciais. O valor padrão desta propriedade é Falso.

4.3.2.10.1.15 TextAlignment
Esta propriedade determina o alinhamento do texto no objeto. Os valores possíveis para esta propriedade estão
descritos na tabela a seguir.
Opções disponíveis para a propriedade TextAlignment
OPÇÃO DESCRIÇÃO
0 - LeftAlignment O alinhamento do texto é à esquerda (padrão)

1 - CenterAlignment O alinhamento do texto é centralizado

2 - RightAlignment O alinhamento do texto é à direita

4.3.2.10.1.16 TextColor
Determina a cor da fonte aplicada na legenda com números do objeto Escala. Para determinar a cor da linha com
as marcas divisórias e subdivisórias da Escala, utilize a propriedade LineColor. O valor padrão desta propriedade é
preto (RGB(0, 0, 0)).

4.3.2.10.1.17 TextFont
Esta propriedade determina a fonte que é aplicada na Escala. A fonte selecionada é aplicada em todo o objeto
Escala. Esta propriedade não pode ser utilizada em Associações e as sub-propriedades podem ser consultadas no

123 Visualização
tópico Fonte.

4.3.2.10.1.18 Ticks
Determina a quantidade de divisórias que a Escala tem. O valor padrão desta propriedade é 5 (cinco).

4.3.2.10.1.19 TicksPercentSize
Determina o tamanho das linhas que dividem o objeto Escala. Conforme for o valor especificado nesta propriedade,
maior ou menor é o tamanho da linha da divisória padrão da Escala. O valor padrão desta propriedade é 20.

4.3.2.11 Figura
Esta seção contém informações sobre métodos e propriedades do objeto Figura (DrawPicture). Este objeto não
possui eventos associados.

4.3.2.11.1 Métodos
Esta seção contém informações sobre os métodos do objeto Figura (DrawPicture).

4.3.2.11.1.1 ScaleImage
ScaleImage(PercX, PercY, AnchorType)
Este método permite ajustar o tamanho de uma Figura proporcionalmente ao tamanho original. Os parâmetros PercX
e PercY definem, respectivamente, os tamanhos percentuais horizontal e vertical da Figura em relação ao tamanho
original. O parâmetro AnchorType define um ponto de ancoragem para este ajuste. Os valores possíveis para este
parâmetro são 0: Center (mantém fixo o centro da Figura), 3: TopLeft (mantém fixo o canto esquerdo superior da
Figura), 4: BottomLeft (mantém fixo o canto esquerdo inferior da Figura), 5: BottomRight (mantém fixo o canto direito
inferior da Figura) ou 6: TopRight (mantém fixo o canto direito superior da Figura).

4.3.2.11.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Figura (DrawPicture).

4.3.2.11.2.1 BackgroundColor
Esta propriedade especifica a cor de preenchimento do fundo do objeto. Esta cor é utilizada quando a propriedade
BackgroundStyle está configurada para 1 (um, opaco) e umas das propriedades VerticalPercentFill ou
HorizontalPercentFill está com valores diferentes de 100. Nos scripts, utilize o método RGB do VBScript para montar
a cor a ser associada a esta propriedade. O valor padrão desta propriedade é cinza (RGB(192, 192, 192)).

4.3.2.11.2.2 BackgroundStyle
Esta propriedade especifica o modo do preenchimento do fundo do objeto. Esta propriedade habilita a utilização
das propriedades VerticalPercentFill e HorizontalPercentFill com valores diferentes de 100, permitindo que a área
restante utilize a cor configurada na propriedade BackgroundColor para preenchimento. A tabela a seguir contém os
valores válidos para esta propriedade.
Opções disponíveis para a propriedade BackgroundStyle
OPÇÃO DESCRIÇÃO
0 - Transparent Nenhum fundo deste objeto é desenhado

1 - Opaque Caso visível, o fundo é desenhado (padrão)

4.3.2.11.2.3 Convert
Esta propriedade permite a conversão da figura. Se esta propriedade está configurada em 0 (zero), é possível
visualizar a conversão. Caso contrário, não é possível visualizar a conversão. Esta propriedade só aceita os valores 0
(zero) e 1 (um). O valor padrão desta propriedade é 0 (zero).

4.3.2.11.2.4 EnableOverrideLineColor
Esta propriedade habilita ou desabilita o objeto a sobrescrever a cor original da linha da imagem pela cor definida
na propriedade OverrideLineColor. Se esta propriedade está habilitada, permite que seja modificada a cor original
da linha do objeto pela cor de OverrideLineColor. Caso contrário, o objeto Figura exibe a cor original.

Visualização 124
4.3.2.11.2.5 Filename
Define o nome do arquivo de imagem associado a este objeto. O caminho do arquivo pode ser tanto o caminho
completo do arquivo no disco quanto o caminho relativo à aplicação, quando inserido o arquivo de imagem como um
Recurso da aplicação. O valor padrão desta propriedade é vazio. A tabela a seguir contém os tipos de arquivos de
imagem suportados.
Tipos de arquivos de imagem suportados
ARQUIVO FILTRO DESCRIÇÃO FILTRO
Bitmap BMP Não Sim

Graphics Interchange GIF Não Sim


Format
Joint Photographic JPG Não Sim
Experts Group
ICO File Format ICO Não Sim

Windows Metafile WMF Não Sim

Enhanced Metafile EMF Não Sim

Portable Network PNG Não Sim


Graphics
Tagged Image File Format TIF Não Sim

4.3.2.11.2.6 HorizontalFillStyle
Define como é o preenchimento horizontal do objeto. Esta propriedade trabalha em conjunto com a propriedade
HorizontalPercentFill, que informa qual porcentagem do objeto deve ser preenchida. Estas duas propriedades
permitem uma simulação de um preenchimento de nível em um objeto, como ocorre em um nível de um tanque, por
exemplo.
Opções disponíveis para a propriedade HorizontalFillStyle
OPÇÃO DESCRIÇÃO
0 - FillLeftToRight A porcentagem de preenchimento é da esquerda para a
direita (padrão)

1 - FillRightToLeft A porcentagem de preenchimento é da direita para a


esquerda

2 - FillCenterToEdgesH A porcentagem de preenchimento é do centro para as


bordas

4.3.2.11.2.7 HorizontalPercentFill
Utilize esta propriedade para especificar qual a porcentagem da área horizontal do objeto deve ser preenchida. Os
valores aceitos por esta propriedade variam de 0 (zero) a 100. Esta propriedade trabalha em conjunto com a
propriedade HorizontalFillStyle, que informa como este preenchimento ocorre. O valor padrão desta propriedade é
100. Exemplo:
Sub Circulo1_OnStartRunning()
HorizontalPercentFill = 200
End Sub

4.3.2.11.2.8 OverrideFillColor
Quando a propriedade OverrideFillMode é configurada com os valores 2 (dois) ou 3 (três), esta propriedade é
usada para definir a cor a ser usada no preenchimento da imagem, ao invés da cor original. Nos scripts, utilize o
método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é
vermelho (RGB(255, 0, 0)). Exemplo:
Sub DrawPicture1_Click()
' Ao clicar no objeto seta o modo
' Override para sólido e troca a cor de
' preenchimento da imagem para azul
OverrideFillMode = 2

125 Visualização
OverrideFillColor = RGB(0, 0, 255)
End Sub

NOTA
Esta propriedade só tem efeito quando o objeto Figura está trabalhando com arquivos Metafile (WMF ou EMF).

4.3.2.11.2.9 OverrideFillMode
Esta propriedade especifica o modo do preenchimento da imagem do objeto, quando este está mostrando um
arquivo Windows Metafile e altera o modo original de preenchimento da imagem sem alterar o arquivo definido pela
propriedade Filename. A tabela a seguir contém os valores válidos para esta propriedade.
Opções disponíveis para a propriedade OverrideFillMode
OPÇÃO DESCRIÇÃO
0 - NoOverride A imagem mantém o preenchimento original (padrão)

1 - Wireframe A imagem não é preenchida

2 - SolidFill A imagem é preenchida com a cor especificada pela


propriedade OverrideFillColor

3 - ByBrightness A imagem é preenchida com a cor especificada pela


propriedade OverrideFillColor, porém leva em conta
qual era a intensidade da cor original da imagem

Exemplo:
Sub DrawPicture1_Click()
' Ao clicar no objeto seta o modo
' Override para sólido e troca a cor de
' preenchimento da imagem para azul
OverrideFillMode = 2
OverrideFillColor = RGB(0, 0, 255)
End Sub

NOTA
Esta propriedade só tem efeito quando o objeto Figura está trabalhando com arquivos Metafile (WMF ou EMF).

4.3.2.11.2.10 OverrideLineColor
Quando a propriedade EnableOverrideLineColor está configurada para Verdadeiro, esta propriedade é usada
para definir a cor a ser usada na cor da linha da figura, ao invés da cor original. Nos scripts, utilize o método RGB do
VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é vermelho
(RGB(255, 0, 0)). Exemplo:
Sub DrawPicture1_Click()
OverrideLineColor = RGB(0, 0, 255)
End Sub

NOTA
Esta propriedade só tem efeito quando o objeto Figura está trabalhando com arquivos Metafile (WMF ou EMF).

4.3.2.11.2.11 Shadow
Indica a presença do efeito de sombra no objeto. Se configurada para Verdadeiro, o objeto possui uma sombra,
cujas coordenadas são estabelecidas pelas propriedades ShadowX e ShadowY. Do contrário, o objeto não possui o
efeito de sombra. O valor padrão desta propriedade é Falso.

4.3.2.11.2.12 ShadowColor
Especifica a cor do preenchimento da sombra do objeto. Esta cor é utilizada quando a propriedade Shadow está
configurada para Verdadeiro. Nos scripts, utilize o método RGB do VBScript para montar a cor a ser associada a esta
propriedade. O valor padrão desta propriedade é cinza escuro (RGB(128, 128, 128)). Exemplo:
Sub Botao1_Click()
' Troca a cor de fundo do botao para cinza claro
' quando se clica no objeto

Visualização 126
ShadowColor = RGB(192, 192, 192)
End Sub

NOTA
Esta propriedade só tem efeito quando o objeto Figura está trabalhando com arquivos Metafile (WMF ou EMF).

4.3.2.11.2.13 ShadowX
Define a coordenada vertical à esquerda da sombra deste objeto, em unidades Himetric. Esta sombra é sempre
relativa à propriedade X do objeto. Valores positivos indicam que a sombra está à direita do objeto, e negativos à
esquerda. O valor padrão desta propriedade é 200.

4.3.2.11.2.14 ShadowY
Define a coordenada horizontal superior da sombra deste objeto, em unidades Himetric. Esta sombra é sempre
relativa a propriedade Y do objeto. Valores positivos indicam que a sombra está abaixo do objeto, e negativos acima.
O valor padrão desta propriedade é 200. Exemplo:
Sub Botao1_Click()
ShadowY = 250
End Sub

NOTA
Esta propriedade só tem efeito quando o objeto Figura está trabalhando com arquivos Metafile (WMF ou EMF).

4.3.2.11.2.15 TransparentColor
Quando a propriedade TransparentMode está configurada para 1 (um), esta propriedade define qual cor da
imagem não é desenhada, e a imagem permanece transparente nestes pontos. Nos scripts, utilize o método RGB do
VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é branco
(RGB(255, 255, 255)). Exemplo:
Sub DrawPicture1_Click()
' Deixa a cor da imagem azul transparente
' quando se clica no objeto Figura
TransparentMode = 1 ' ByColor
TransparentColor = RGB(0, 0, 255)
End Sub

4.3.2.11.2.16 TransparentMode
Esta propriedade especifica o modo como é o efeito de transparência na imagem. A tabela a seguir contém os
valores possíveis para esta propriedade.
Opções disponíveis para a propriedade TransparentMode
OPÇÃO DESCRIÇÃO
0 - Disabled Nenhuma transparência é efetuada (padrão)

1 - ByColor A transparência é de acordo com a cor definida na


propriedade TransparentColor

2 - ByPercent A imagem permanece translúcida com porcentagem de


transparência especificada na propriedade
TransparentPercent

Exemplo:
Sub DrawPicture1_Click()
' Deixa a cor da imagem azul transparente
' quando se clica no objeto Figura
TransparentMode = 1 ' ByColor
TransparentColor = RGB(0, 0, 255)
End Sub

4.3.2.11.2.17 TransparentPercent
Quando a propriedade TransparentMode está configurada para 2 (dois), esta propriedade define quão translúcida
a imagem é exibida, variando de 0 (zero, totalmente translúcido) a 100 (opaco ou sólido). Exemplo:

127 Visualização
Sub DrawPicture1_Click()
' Deixa a imagem translúcida quando se clica no objeto
TransparentMode = 1 ' ByPercent
TransparentPercent = 50 ' 50% translúcido
End Sub

4.3.2.11.2.18 VerticalFillStyle
Define como é o preenchimento vertical do objeto. Esta propriedade trabalha em conjunto com a propriedade
VerticalPercentFill, que informa qual porcentagem do objeto deve ser preenchida. Estas duas propriedades
permitem uma simulação de um preenchimento de nível em um objeto.
Opções disponíveis para a propriedade VerticalFillStyle
OPÇÃO DESCRIÇÃO
0 - FillBottomToTop A porcentagem de preenchimento é de baixo para cima
(padrão)

1 - FillTopToBottom A porcentagem de preenchimento é de cima para baixo

2 - FillCenterToEdgesV A porcentagem de preenchimento é do centro para as


bordas

4.3.2.11.2.19 VerticalPercentFill
Utilize esta propriedade para especificar qual a porcentagem da área vertical do objeto deve ser preenchida. Os
valores aceitos por esta propriedade variam de 0 (zero) a 100. Esta propriedade trabalha em conjunto com a
propriedade VerticalFillStyle, que informa como este preenchimento ocorre. O valor padrão desta propriedade é
100.

4.3.2.12 Fonte
Esta seção contém informações sobre propriedades do objeto Fonte (Font) retornado pelas propriedades que
configuram uma fonte para os textos dos objetos de Tela, exceto os MS Forms. Este objeto não possui eventos nem
métodos associados.

4.3.2.12.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte (Font) retornado pelas propriedades que
configuram uma fonte para os textos dos objetos de Tela, exceto os MS Forms.

4.3.2.12.1.1 Bold
Esta propriedade indica se o texto do objeto de Tela está em negrito.

4.3.2.12.1.2 Charset
Esta propriedade indica o conjunto de caracteres disponível para a fonte do objeto de Tela. Os valores possíveis
para esta propriedade estão descritos na tabela a seguir.
Valores disponíveis para a propriedade Charset
VALOR PÁGINA DE CÓDIGO NOME DESCRIÇÃO
0 1252 ANSI_CHARSET ANSI (American National
Standards Institute)

1 -- DEFAULT_CHARSET Padrão (mostra o conjunto


de caracteres disponível na
Fonte)

2 -- SYMBOL_CHARSET Símbolos

128 932 SHIFTJIS_CHARSET Japonês (Shift-JIS)

129 949 HANGUL_CHARSET Coreano

134 936 GB2312_CHARSET Chinês Simplificado (GBK)

136 950 CHINESEBIG5_CHARSET Chinês Tradicional (Big5)

161 1253 GREEK_CHARSET Grego

Visualização 128
VALOR PÁGINA DE CÓDIGO NOME DESCRIÇÃO
162 1254 TURKISH_CHARSET Turco

177 1255 HEBREW_CHARSET Hebraico

178 1256 ARABIC_CHARSET Árabe

186 1257 BALTIC_CHARSET Báltico

204 1251 RUSSIAN_CHARSET Cirílico

222 874 THAI_CHARSET Tailandês

238 1250 EE_CHARSET Centro-Europeu

255 -- OEM_CHARSET OEM (Original Equipment


Manufacturer)

4.3.2.12.1.3 Italic
Esta propriedade indica se o texto do objeto de Tela está em itálico.

4.3.2.12.1.4 Name
Esta propriedade indica o nome da fonte do objeto de Tela.

4.3.2.12.1.5 Size
Esta propriedade indica o tamanho, em pontos, da fonte do texto do objeto de Tela.

4.3.2.12.1.6 Strikethrough
Esta propriedade indica se o texto do objeto de Tela usa o efeito de tachado.

4.3.2.12.1.7 Underline
Esta propriedade indica se o texto do objeto de Tela usa o efeito de sublinhado.

4.3.2.12.1.8 Weight
Esta propriedade indica a variação do efeito de negrito na fonte do objeto de Tela, ou seja, da propriedade Bold.
Os valores para esta propriedade podem variar entre 0 (zero, não interfere no efeito de negrito) e 1000.

4.3.2.13 Grupo
Esta seção contém informações sobre propriedades do Grupo de objetos (DrawGroup). Este objeto não possui
eventos nem métodos associados.

4.3.2.13.1 Propriedades
Esta seção contém informações sobre propriedades do Grupo de objetos (DrawGroup).

4.3.2.13.1.1 EnableOverrideLineColor
Esta propriedade habilita ou desabilita o objeto Grupo a sobrescrever as cores originais das linhas dos objetos
contidos no Grupo. Se esta propriedade está habilitada, as cores originais das linhas dos objetos do Grupo são
substituídas pela cor definida na propriedade OverrideLineColor. Caso contrário, cada objeto contido no Grupo
apresenta a cor de linha original. O valor padrão desta propriedade é Falso.

4.3.2.13.1.2 OverrideFillColor
Quando a propriedade OverrideFillMode está configurada para 2 (dois) ou 3 (três), esta propriedade é usada para
definir a cor a ser usada no preenchimento dos objetos contíguos no Grupo, ao invés da cor original. Nos scripts,
utilize o método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta
propriedade é vermelho (RGB(255, 0, 0)).

129 Visualização
4.3.2.13.1.3 OverrideFillMode
Esta propriedade especifica o modo do preenchimento dos objetos que estão dentro do Grupo e altera o modo
original de preenchimento da imagem, sem alterar a configuração original de preenchimento dos objetos.
Opções disponíveis para a propriedade OverrideFillMode
OPÇÃO DESCRIÇÃO
0 - NoOverride Preenchimento original do objeto (padrão)

1 - Wireframe Os objetos não são preenchidos, desenham somente as


bordas

2 - SolidFill O preenchimento dos objetos contidos no Grupo é


sólido com a cor especificada na propriedade
OverrideFillColor

3 - ByBrightness O preenchimento dos objetos contidos no Grupo é


sólido com a cor especificada pela propriedade
OverrideFillColor, porém leva em conta qual era a
intensidade da cor original de preenchimento de cada
objeto

4.3.2.13.1.4 OverrideLineColor
Quando a propriedade EnableOverrideLineColor está configurada para Verdadeiro, esta propriedade é usada
para definir a cor a ser usada na cor da linha dos objetos do Grupo, ao invés da cor original. Nos scripts, utilize o
método RGB do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é
vermelho (RGB(255, 0, 0)).

4.3.2.14 Microsoft Forms


Esta seção contém informações sobre eventos e propriedades comuns de objetos Microsoft Forms. Estes objetos
não possuem métodos comuns associados.

4.3.2.14.1 Eventos Comuns


Esta seção contém informações sobre os eventos comuns aos objetos Microsoft Forms.

4.3.2.14.1.1 BeforeDragOver
BeforeDragOver(Index, Cancel, Data, X, Y, DragState, Effect, Shift)
Ocorre quando há uma ação de arrastar e soltar (drag-and-drop) sobre um objeto. Utilize este evento para monitorar
se o ponteiro do mouse entrou, deixou ou permaneceu sobre um objeto alvo. O evento é disparado quando o
usuário move o ponteiro do mouse ou pressiona ou solta algum botão do mouse. A posição do ponteiro do mouse
indica qual objeto gerou o evento. Pode-se determinar o status do ponteiro do mouse examinando o parâmetro
DragState.
Muitos objetos não suportam operações de arrastar e soltar enquanto o parâmetro Cancel tem o valor Falso, que é o
padrão. Isto significa que o objeto rejeita qualquer tentativa de arrastar ou soltar algum outro objeto sobre si e,
consequentemente, não dispara o evento BeforeDropOrPaste. O objeto Text Box (Caixa de Texto) e o objeto Combo
(Lista de Seleção) são exceções. Estes objetos aceitam operações de arrastar e soltar mesmo quando o parâmetro
Cancel tem o valor Falso.
Parâmetros disponíveis no evento BeforeDragOver
NOME DESCRIÇÃO
Index Indica o índice da página, em um objeto multi-páginas,
que é afetada pela operação que gerou o evento. Para
outros objetos é ignorada

Cancel Status do evento. O padrão é Falso e indica que é o


objeto alvo que trata o evento e não a aplicação principal

Data Dados sendo arrastados para o objeto alvo, propriamente


ditos

Visualização 130
NOME DESCRIÇÃO
X, Y Posição do ponteiro do mouse dentro do objeto alvo, em
pontos. X é medido a partir do lado esquerdo do objeto
e Y é medido a partir do topo

DragState Indica a condição do ponteiro do mouse quando é


gerado o evento:
· 0 - fmDragStateEnter: O ponteiro do mouse está
dentro do alcance do objeto
· 1 - fmDragStateLeave: O ponteiro do mouse está fora
do alcance do objeto
· 2 - fmDragStateOver: O ponteiro do mouse está em
uma nova posição, mas ainda está dentro do alcance do
objeto

Effect Indica as ações que o objeto alvo suporta, ou seja, o


efeito de arrastar sobre o objeto alvo:
· 0 - fmDropEffectNone: Objeto alvo não aceita copiar
ou mover de alguma origem
· 1 - fmDropEffectCopy: Objeto alvo permite copiar de
alguma origem para si
· 2 - fmDropEffectMove: Objeto alvo permite mover de
alguma origem para si
· 3 - fmDropEffectCopyOrMove: Objeto alvo permite
copiar ou mover de alguma origem para si

Shift Inteiro cuja soma dos fatores indica o status das teclas
SHIFT, CTRL e ALT:
· 1: Tecla SHIFT pressionada
· 2: Tecla CTRL pressionada
· 4: Tecla ALT pressionada
Por exemplo, um valor igual a 5 (cinco) indica que as
teclas SHIFT e ALT estavam pressionadas (1 + 4 = 5)

4.3.2.14.1.2 BeforeDropOrPaste

BeforeDropOrPaste(Index, Cancel, Ctrl, Action, Data, X, Y, Effect, Shift)


Disparado no momento imediatamente anterior a uma operação de arrastar e soltar. Normalmente, isto ocorre logo
após o evento BeforeDragOver.
Parâmetros disponíveis no evento BeforeDropOrPaste
NOME DESCRIÇÃO
Index Indica o índice da página, em um objeto multi-páginas,
que é afetada pela operação que gerou o evento. Para
outros objetos é ignorada

Cancel Status do evento. O padrão é Falso e indica que é o


objeto alvo que trata o evento e não a aplicação principal

Ctrl Objeto alvo

Action Indica o resultado, baseado nas configurações do teclado,


de uma operação de arrastar e soltar pendente:
· 2 - fmActionPaste: Cola o objeto selecionado no objeto
alvo
· 3 - fmActionDragDrop: Indica que o usuário arrastou o
objeto selecionado de sua origem e soltou-o sobre o
objeto alvo

Data Dados sendo arrastados para o objeto alvo, propriamente


ditos

131 Visualização
NOME DESCRIÇÃO
X, Y Posição do ponteiro do mouse dentro do objeto alvo, em
pontos. X é medido a partir do lado esquerdo do objeto
e Y é medido a partir do topo

Effect Indica as ações que o objeto alvo suporta, ou seja, o


efeito de arrastar sobre o objeto alvo:
· 0 - fmDropEffectNone: Objeto alvo não aceita copiar
ou mover de alguma origem
· 1 - fmDropEffectCopy: Objeto alvo permite copiar de
alguma origem para si
· 2 - fmDropEffectMove: Objeto alvo permite mover de
alguma origem para si
· 3 - fmDropEffectCopyOrMove: Objeto alvo permite
copiar ou mover de alguma origem para si

Shift Inteiro cuja soma dos fatores indica o status das teclas
SHIFT, CTRL e ALT:
· 1: Tecla SHIFT pressionada
· 2: Tecla CTRL pressionada
· 4: Tecla ALT pressionada
Por exemplo, um valor igual a 5 (cinco) indica que as
teclas SHIFT e ALT estavam pressionadas (1 + 4 = 5)

4.3.2.14.1.3 Change
Change()
Ocorre quando o valor da propriedade Value de um objeto é modificada. A seguir estão alguns exemplos de ações
que disparam este evento:
· Clicar em uma Caixa de Seleção, em um Botão de Opção ou em um Botão Incremento-Decremento
· Clicar ou selecionar palavras em uma Lista de Seleção ou em um Editor de Texto
· Selecionar diferentes abas em uma caixa de diálogo
· Mover a barra de rolagem em uma Barra de Rolagem
· Clicar nas setas de um Botão Incremento-Decremento
· Selecionar diferentes páginas em um objeto multi-páginas

4.3.2.14.1.4 Error
Error(Number, Description, SCode, Source, HelpFile, HelpContext, CancelDisplay)
Gerado por um erro interno em um objeto. Se este evento não é tratado, o E3 mostra uma mensagem de erro
genérica.
Parâmetros disponíveis no evento Error
NOME DESCRIÇÃO
Number Número inteiro identificador do erro

Description String com a descrição do erro

SCode Inteiro com o código de erro do subsistema OLE (não


utilizado)

Source String com o objeto que originou o erro

HelpFile String com o nome e o caminho do arquivo de ajuda

HelpContext Número inteiro de contexto do tópico de ajuda referente


ao erro

CancelDisplay Booleano que indica se o erro deve ser mostrado em


uma caixa de mensagem

Visualização 132
4.3.2.14.1.5 KeyPress

KeyPress(KeyAscii)
Ocorre quando um objeto tem o foco de teclado e o usuário pressiona uma tecla que corresponde a um caractere
que pode ser mostrado em tela (uma tecla ANSI, de código indicado no parâmetro KeyAscii), ou seja, o evento ocorre
quando alguma das teclas a seguir são pressionadas:
· Qualquer caractere do teclado que possa ser impresso
· Tecla CTRL combinada com qualquer caractere do alfabeto padrão
· Tecla CTRL combinada com qualquer caractere especial
· Tecla BACKSPACE
· Tecla ESC

Este evento não ocorre nas seguintes condições:


· Pressionando a tecla TAB
· Pressionando a tecla ENTER
· Pressionando a tecla DEL (esta tecla não é padrão ANSI)
· Pressionando as setas do teclado
· Quando uma tecla move o foco de um objeto para outro

Enquanto o usuário pressiona uma tecla que produz um código ANSI, o objeto recebe o evento KeyDown e este
evento repetidamente. Quando o usuário libera a tecla, o evento KeyUp ocorre. Para monitorar o estado físico do
teclado ou manipular teclas não reconhecidas por este evento (como teclas de função, navegação, etc.), utilize os
eventos KeyDown e KeyUp.

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyAscii, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.3.2.14.2 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns aos objetos Microsoft Forms.

NOTA
O E3 utiliza para definição de coordenadas e espessura o sistema Himetric. Neste sistema, cada unidade lógica
equivale a um milésimo de centímetro, ou seja, cada 1000 unidades equivalem a um centímetro. Assim, este é o
padrão adotado na descrição das propriedades do E3, quando aplicável.

4.3.2.14.2.1 BackColor
Determina a cor de fundo de um objeto. Nos scripts, utilize o método RGB do VBScript para montar a cor a ser
associada a esta propriedade. O valor padrão desta propriedade para os objetos Lista de Seleção, Lista e Editor de
Texto é a cor branca (RGB(255, 255, 255)), e para os demais objetos é a cor bege (RGB(236, 233, 216)).

4.3.2.14.2.2 ForeColor
Especifica a cor do preenchimento do fundo de um objeto. Nos scripts, utilize o método RGB do VBScript para
montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade para todos os objetos Microsoft
Forms é a cor preta (RGB(0, 0, 0)).

4.3.2.14.2.3 MouseIcon
Esta propriedade atribui uma imagem ao ponteiro do mouse quando este é movido sobre um objeto. Esta
propriedade é válida somente quando a propriedade MousePointer está definida como 99 -
fmMousePointerCustom.
Um arquivo com imagem pode ser selecionado para o ponteiro do mouse de duas formas: através da Lista de
Propriedades (extensões .cur ou .ico) ou via scripts, utilizando-se a função LoadPicture para especificar o caminho e o
nome do arquivo que contém o ícone personalizado (somente arquivos com a extensão .cur). Exemplo:

133 Visualização
Sub CommandButton1_Click()
' Atribuindo o item 99 - fmMousePointerCustom à propriedade
' para que ela aceite a personalização do ícone do mouse
Screen.Item("CheckBox1").MousePointer = 99
Screen.Item("CheckBox1").MouseIcon = LoadPicture("c:\a.cur")
End Sub

4.3.2.14.2.4 MousePointer
Esta propriedade especifica o tipo de ponteiro do mouse que é mostrado quando o usuário o posiciona sobre um
objeto. As opções disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade MousePointer
OPÇÃO DESCRIÇÃO
0 - fmMousePointerDefault Ponteiro padrão (a imagem é determinada pelo objeto)

1 - fmMousePointerArrow Seta

2 - fmMousePointerCross Ponteiro em forma de cruz

3 - fmMousePointerIBeam Em forma de I

6 - fmMousePointerSizeNESW Seta dupla apontando para nordeste e sudoeste

7 - fmMousePointerSizeNS Seta dupla apontando para norte e sul

8 - fmMousePointerNWSE Seta dupla apontando para noroeste e sudeste

9 - fmMousePointerWE Seta dupla apontando para oeste e leste

10 - fmMousePointerUpArrow Seta para cima

11 - fmMousePointerHourglass Ampulheta

12 - fmMousePointerNoDrop Símbolo de Not (círculo com uma linha diagonal) na


parte superior do objeto sendo arrastado (indica um
destino inválido para uma operação de soltar)

13 - fmMousePointerAppStarting Seta com uma ampulheta

14 - fmMousePointerHelp Seta com um ponto de interrogação

15 - fmMousePointerSizeAll Dimensiona todo o cursor (setas apontando para norte,


sul, leste e oeste)

99 - fmMousePointerCustom Usa o ícone especificado pela propriedade MouseIcon

Use esta propriedade para indicar alterações de funcionalidade conforme o ponteiro do mouse passa sobre os
objetos em uma Tela. Por exemplo, a configuração de ampulheta (opção 11) é útil para indicar que o usuário precisa
esperar algum tempo para que um processo ou operação seja finalizado. Alguns ícones podem variar, dependendo
das configurações do sistema, como os ícones associados aos temas da área de trabalho. O valor padrão desta
propriedade é 0 - fmMousePointerDefault.

4.3.2.14.3 Barra de Rolagem


Esta seção contém informações sobre eventos e propriedades do objeto Barra de Rolagem (Scrollbar). Este objeto
não possui métodos associados.

4.3.2.14.3.1 Eventos
Esta seção contém informações sobre os eventos do objeto Barra de Rolagem (Scrollbar).
Scroll
Scroll()
Gerado quando o ponteiro da barra de rolagem é movido para alguma direção.

4.3.2.14.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Barra de Rolagem (Scrollbar).

Visualização 134
Delay
Especifica um tempo de espera para o objeto. Esta propriedade afeta a duração de tempo entre eventos Change
consecutivos, gerados quando o usuário clica e mantém pressionada a Barra de Rolagem. O primeiro evento ocorre
imediatamente. O tempo de espera até a segunda ocorrência do evento é de cinco vezes o valor especificado nesta
propriedade. Após o tempo inicial, o intervalo entre os eventos é o valor especificado para esta propriedade.
O valor padrão desta propriedade é 50ms. Isto significa que o objeto inicia o primeiro evento depois de 250 ms
(cinco vezes o valor especificado), e inicia cada evento subsequente depois de 50 ms.
LargeChange
Especifica a quantidade de passos do cursor da Barra de Rolagem. O valor desta propriedade é a quantidade pela
qual a propriedade Value é alterada, quando o usuário clica na área entre a caixa de rolagem e o cursor da Barra de
Rolagem. Qualquer valor inteiro é permitido para esta propriedade, mas o intervalo recomendado é de -32,767 a
+32,767, sendo que este valor deve estar entre os valores determinados nas propriedade Max e Min da Barra de
Rolagem.
Max
Esta propriedade é utilizada para determinar o limite máximo do objeto.
Min
Esta propriedade é utilizada para determinar o limite mínimo do objeto.
Orientation
Esta propriedade é utilizada para determinar a orientação do objeto na Tela. As opções disponíveis para esta
propriedade são as seguintes:
· -1 - fmOrientationAuto: Determina automaticamente a orientação com base nas dimensões do objeto, isto é,
conforme ele foi criado (padrão)
· 0 - fmOrientationVertical: O objeto é disposto verticalmente
· 1 - fmOrientationHorizontal: O objeto é disposto horizontalmente
ProportionalThumb
Esta propriedade especifica se o tamanho da caixa de rolagem é igual à dimensão do objeto. Se a propriedade
estiver configurada para Verdadeiro, a caixa da Barra de Rolagem tem a mesma dimensão do objeto. Caso contrário,
se for dimensionado o objeto, a caixa de rolagem permanece com o tamanho original. O valor padrão desta
propriedade é Verdadeiro.
SmallChange
Esta propriedade especifica a quantidade de movimento que ocorre quando o usuário clica em uma seta de
rolagem no objeto. O valor padrão desta propriedade é 1 (um).
Value
Número inteiro entre os valores definidos pelas propriedades Min e Max. Indica a posição inicial da barra de
rolagem. Não aceita valores menores que o valor de Min, nem maiores que o valor de Max.

4.3.2.14.4 Botão de Comando


Esta seção contém informações sobre eventos e propriedades do objeto Botão de Comando (CommandButton). Este
objeto não possui métodos associados.

4.3.2.14.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto Botão de Comando (CommandButton).
MouseMove
MouseMove()
Ocorre quando o ponteiro do mouse é movimentado sobre o botão de comando.

4.3.2.14.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Botão de Comando (CommandButton).
Accelerator
Define ou recupera a tecla aceleradora do objeto. Esta tecla aceleradora é uma tecla que, usada em conjunto com a
tecla ALT, move o foco para o objeto. O valor padrão desta propriedade é uma String vazia.

135 Visualização
AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Para o objeto
Botão de Comando (Command Button), quando a propriedade estiver configurada para Verdadeiro, a largura do
texto é reajustada para a mesma do objeto. O conteúdo do texto é cortado quando excede a área do objeto.
BackStyle
Esta propriedade define o estilo do plano de fundo para os objetos. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

Caption
Define o texto que é mostrado no objeto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Botão de Comando. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.
Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.
Picture
Esta propriedade especifica a figura (bitmap) atribuída ao objeto. Um arquivo com imagem pode ser selecionado
de duas maneiras: através da Lista de Propriedades ou via scripts, utilizando-se a função LoadPicture para especificar
o caminho e o nome do arquivo que contém a figura. Para remover a figura, clique no valor desta propriedade e
pressione a tecla DEL. A tecla BACKSPACE (tecla de espaço do teclado) não remove a figura.
PicturePosition
Esta propriedade especifica a posição da figura atribuída ao objeto em relação a sua legenda. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade PicturePosition
OPÇÃO DESCRIÇÃO
0 - fmPicturePositionLeftTop A figura aparece à esquerda da legenda. A legenda é
alinhada com a parte superior da figura

1 - fmPicturePositionLeftCenter A figura aparece à esquerda da legenda. A legenda é


centralizada relativamente à imagem

2 - fmPicturePositionLeftBottom A figura aparece à esquerda da legenda. A legenda é


alinhada com a parte inferior da figura

3 - fmPicturePositionRightTop A figura aparece à direita da legenda. A legenda é


alinhada com a parte superior da figura

4 - fmPicturePositionRightCenter A figura aparece à direita da legenda. A legenda é


centralizada relativamente à figura

5 - fmPicturePositionRightBottom A figura aparece à direita da legenda. A legenda é


alinhada com a parte inferior da figura

6 - fmPicturePositionAboveLeft A figura aparece acima da legenda. A legenda é alinhada


com a extremidade esquerda da figura

7 - fmPicturePositionAboveCenter A figura aparece acima da legenda. A legenda é


centralizada abaixo da figura (padrão)

8 - fmPicturePositionAboveRight A figura aparece acima da legenda. A legenda é alinhada


com a extremidade direita da figura

Visualização 136
OPÇÃO DESCRIÇÃO
9 - fmPicturePositionBelowLeft A figura aparece abaixo da legenda. A legenda é
alinhada com a extremidade esquerda da figura

10 - fmPicturePositionBelowCenter A figura aparece abaixo da legenda. A legenda é


centralizada acima da figura

11 - fmPicturePositionBelowRight A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade direita da figura

12 - fmPicturePositionCenter A figura aparece no centro do controle. A legenda é


centralizada horizontalmente e verticalmente sobre a
figura

TakeFocusOnClick
Especifica se o objeto recebe o foco quando clicado. Se a propriedade estiver configurada para Verdadeiro, o
objeto recebe o foco quando clicado. Caso contrário, o objeto não recebe o foco.
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto.

4.3.2.14.5 Botão de Opção


Esta seção contém informações sobre propriedades do objeto Botão de Opção (MdcOptionButton). Este objeto não
possui eventos nem métodos associados.

4.3.2.14.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Botão de Opção (MdcOptionButton).
Accelerator
Define ou recupera a tecla aceleradora do objeto. Esta tecla aceleradora é uma tecla que, usada em conjunto com a
tecla ALT, move o foco para o objeto. O valor padrão desta propriedade é uma String vazia.
Alignment
Esta propriedade especifica a posição do objeto relativa a sua legenda. As opções disponíveis para esta
propriedade são as seguintes:
· 0 - fmAlignmentLeft: Coloca a legenda à esquerda do objeto
· 1 - fmAligmentRight: Coloca a legenda à direita do objeto (padrão)
AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Quando a
propriedade estiver configurada para Verdadeiro, o texto é redimensionado para coincidir com o tamanho atual do
objeto.
BackStyle
Esta propriedade define o estilo do plano de fundo para os objetos. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

Caption
Define o texto que é mostrado no objeto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Botão de Opção. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.

137 Visualização
GroupName
Esta propriedade é utilizada para criar um grupo de objetos mutuamente exclusivos.

NOTA
Esta propriedade não é utilizada no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.
Picture
Esta propriedade especifica a figura (bitmap) atribuída ao objeto. Um arquivo com imagem pode ser selecionado
de duas maneiras: através da Lista de Propriedades ou via scripts, utilizando-se a função LoadPicture para especificar
o caminho e o nome do arquivo que contém a figura. Para remover a figura, clique no valor desta propriedade e
pressione a tecla DEL. A tecla BACKSPACE (tecla de espaço do teclado) não remove a figura. Exemplo:
Sub CommandButton1_Click()
Screen.Item("OptionButton1").Picture = LoadPicture("C:\aba.gif")
End Sub
PicturePosition
Esta propriedade especifica a posição da figura atribuída ao objeto em relação a sua legenda. As opções
disponíveis para esta propriedades estão descritas na tabela a seguir.
Opções disponíveis para a propriedade PicturePosition
OPÇÃO DESCRIÇÃO
0 - fmPicturePositionLeftTop A figura aparece à esquerda da legenda. A legenda é
alinhada com a parte superior da figura

1 - fmPicturePositionLeftCenter A figura aparece à esquerda da legenda. A legenda é


centralizada relativamente à imagem

2 - fmPicturePositionLeftBottom A figura aparece à esquerda da legenda. A legenda é


alinhada com a parte inferior da figura

3 - fmPicturePositionRightTop A figura aparece à direita da legenda. A legenda é


alinhada com a parte superior da figura

4 - fmPicturePositionRightCenter A figura aparece à direita da legenda. A legenda é


centralizada relativamente à figura

5 - fmPicturePositionRightBottom A figura aparece à direita da legenda. A legenda é


alinhada com a parte inferior da figura

6 - fmPicturePositionAboveLeft A figura aparece acima da legenda. A legenda é alinhada


com a extremidade esquerda da figura

7 - fmPicturePositionAboveCenter A figura aparece acima da legenda. A legenda é


centralizada abaixo da figura (padrão)

8 - fmPicturePositionAboveRight A figura aparece acima da legenda. A legenda é alinhada


com a extremidade direita da figura

9 - fmPicturePositionBelowLeft A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade esquerda da figura

10 - fmPicturePositionBelowCenter A figura aparece abaixo da legenda. A legenda é


centralizada acima da figura

11 - fmPicturePositionBelowRight A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade direita da figura

12 - fmPicturePositionCenter A figura aparece no centro do controle. A legenda é


centralizada horizontalmente e verticalmente sobre a
figura

Visualização 138
SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmButtonEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

2 - fmButtonEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita, como se
estivesse afundado na Tela (padrão)

TextAlign
Especifica como o texto é alinhado neste objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Alinha o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
TripleState
Esta propriedade determina até três estados de valores para o objeto. Se a propriedade estiver configurada para
Verdadeiro, o usuário pode selecionar entre três opções de estados: Falso, Verdadeiro ou Nulo. O valor Nulo é
exibido como um botão sombreado. Caso contrário, o usuário pode selecionar entre os valores Falso e Verdadeiro. O
valor padrão desta propriedade é Falso.
Value
Indica o valor inicial do objeto e tem comportamento Booleano: se Verdadeiro, o objeto inicia selecionado e, do
contrário, seu estado inicial é não selecionado. O valor padrão desta propriedade é Falso.
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto. Para que esta propriedade funcione, a propriedade Multiline deve ser obrigatoriamente
igual a Verdadeiro.

4.3.2.14.6 Botão Incremento-Decremento


Esta seção contém informações sobre eventos e propriedades do objeto Botão Incremento-Decremento (Spinbutton).
Este objeto não possui métodos associados.

4.3.2.14.6.1 Eventos
Esta seção contém informações sobre os eventos do objeto Botão Incremento-Decremento (Spinbutton).
SpinDown
SpinDown()
Ocorre quando o usuário pressiona a tecla de seta para baixo. Este evento decrementa a propriedade Value do
objeto.
SpinUp
SpinUp()
Ocorre quando o usuário pressiona a tecla de seta para cima. Este evento incrementa a propriedade Value do objeto.

4.3.2.14.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Botão Incremento-Decremento (Spinbutton).
Delay
Especifica um tempo de espera para o objeto. Esta propriedade afeta a duração de tempo entre os eventos SpinUp,
SpinDown e Change consecutivos, gerados quando o usuário clica e mantém pressionado o botão Incremento-
Decremento. O primeiro evento ocorre imediatamente. O tempo de espera até a segunda ocorrência do evento é de
cinco vezes o valor especificado nesta propriedade. Após o tempo inicial, o intervalo entre os eventos é o valor
especificado para esta propriedade.

139 Visualização
O valor padrão desta propriedade é 50 ms. Isto significa que o objeto inicia o primeiro evento depois de 250 ms
(cinco vezes o valor especificado), e inicia cada evento subsequente depois de 50 ms.
Max
Esta propriedade é utilizada para determinar o limite máximo do objeto.
Min
Esta propriedade é utilizada para determinar o limite mínimo do objeto.
Orientation
Esta propriedade é utilizada para determinar a orientação do objeto na Tela. As opções disponíveis para esta
propriedade são as seguintes:
· -1 - fmOrientationAuto: Determina automaticamente a orientação com base nas dimensões do objeto, isto é,
conforme ele foi criado (padrão)
· 0 - fmOrientationVertical: O objeto é disposto verticalmente
· 1 - fmOrientationHorizontal: O objeto é disposto horizontalmente
SmallChange
Esta propriedade especifica a quantidade de movimento que ocorre quando o usuário clica em uma seta de
rolagem no objeto. O valor padrão desta propriedade é 1 (um).
Value
Número inteiro entre os valores definidos pelas propriedades Min e Max. Indica a posição inicial do incremento ou
decremento. Não aceita valores menores que o valor de Min, nem maiores que o valor de Max.

4.3.2.14.7 Botão Liga-Desliga


Esta seção contém informações sobre eventos e propriedades do objeto Botão Liga-Desliga (MdcToggleButton). Este
objeto não possui métodos associados.

4.3.2.14.7.1 Eventos
Esta seção contém informações sobre os eventos do objeto Botão Liga-Desliga (MdcToggleButton).
MouseMove
MouseMove()
Ocorre quando o ponteiro do mouse é movimentado sobre o botão Liga-Desliga.

4.3.2.14.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Botão Liga-Desliga (MdcToggleButton).
Accelerator
Define ou recupera a tecla aceleradora do objeto. Esta tecla aceleradora é uma tecla que, usada em conjunto com a
tecla ALT, move o foco para o objeto. O valor padrão desta propriedade é uma String vazia.
Alignment
Esta propriedade especifica a posição do objeto, relativa a sua legenda. As opções disponíveis para esta
propriedade são as seguintes:
· 0 - fmAlignmentLeft: Coloca a legenda à esquerda do objeto
· 1 - fmAligmentRight: Coloca a legenda à direita do objeto (padrão)

Esta propriedade não pode ser alterada com o objeto ativo.


AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Para o objeto
Botão Liga-Desliga (Toggle Button), quando a propriedade estiver configurada para Verdadeiro, o texto é
redimensionado para coincidir com o tamanho atual o objeto, permitindo assim a sua exibição completa.
BackStyle
Esta propriedade define o estilo do plano de fundo para o objeto. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

Visualização 140
NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

Caption
Define o texto que é mostrado no objeto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Botão Liga-Desliga. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.
GroupName
Esta propriedade é utilizada para criar um grupo de objetos mutuamente exclusivos. Esta propriedade não pode
ser alterada com o objeto ativo.

NOTA
Esta propriedade não é utilizada no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.
Picture
Esta propriedade especifica a figura (bitmap) atribuída ao objeto. Um arquivo com imagem pode ser selecionado
de duas maneiras: através da Lista de Propriedades ou via scripts, utilizando-se a função LoadPicture para especificar
o caminho e o nome do arquivo que contém a figura. Para remover a figura, clique no valor desta propriedade e
pressione a tecla DEL. A tecla BACKSPACE (tecla de espaço do teclado) não remove a figura.
PicturePosition
Esta propriedade especifica a posição da figura atribuída ao objeto em relação a sua legenda. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade PicturePosition
OPÇÃO DESCRIÇÃO
0 - fmPicturePositionLeftTop A figura aparece à esquerda da legenda. A legenda é
alinhada com a parte superior da figura

1 - fmPicturePositionLeftCenter A figura aparece à esquerda da legenda. A legenda é


centralizada relativamente à imagem

2 - fmPicturePositionLeftBottom A figura aparece à esquerda da legenda. A legenda é


alinhada com a parte inferior da figura

3 - fmPicturePositionRightTop A figura aparece à direita da legenda. A legenda é


alinhada com a parte superior da figura

4 - fmPicturePositionRightCenter A figura aparece à direita da legenda. A legenda é


centralizada relativamente à figura

5 - fmPicturePositionRightBottom A figura aparece à direita da legenda. A legenda é


alinhada com a parte inferior da figura

6 - fmPicturePositionAboveLeft A figura aparece acima da legenda. A legenda é alinhada


com a extremidade esquerda da figura

7 - fmPicturePositionAboveCenter A figura aparece acima da legenda. A legenda é


centralizada abaixo da figura (padrão)

8 - fmPicturePositionAboveRight A figura aparece acima da legenda. A legenda é alinhada


com a extremidade direita da figura

141 Visualização
OPÇÃO DESCRIÇÃO
9 - fmPicturePositionBelowLeft A figura aparece abaixo da legenda. A legenda é
alinhada com a extremidade esquerda da figura

10 - fmPicturePositionBelowCenter A figura aparece abaixo da legenda. A legenda é


centralizada acima da figura

11 - fmPicturePositionBelowRight A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade direita da figura

12 - fmPicturePositionCenter A figura aparece no centro do controle. A legenda é


centralizada horizontalmente e verticalmente sobre a
figura

SpecialEffect
Esta propriedade especifica a aparência de um objeto. Esta propriedade não pode ser alterada com o objeto
ativo. As opções disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmSpecialEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

1 - fmSpecialEffectRaised O objeto possui um destaque na parte superior


esquerda e uma sombra na parte inferior direita. O
objeto parece estar em relevo (padrão)

2 - fmSpecialEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita. O objeto e a sua
borda parecem estar afundados na Tela

3 - fmSpecialEffectEtched A borda parece estar esculpida ao redor da extremidade


do objeto

6 - fmSpecialEffectBump O objeto possui um ressalto na parte inferior direita e


parece plano na parte superior esquerda

TextAlign
Especifica como o texto é alinhado no objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto
· 2 - fmTextAlignCenter: Alinha o texto ao centro do objeto (padrão)
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
TripleState
Esta propriedade determina até três estados de valores para o objeto. Se a propriedade estiver configurada para
Verdadeiro, o usuário pode selecionar entre três opções de estados: Falso, Verdadeiro ou Nulo. O valor Nulo é
exibido como um botão sombreado. Caso contrário, o usuário pode selecionar entre os valores Falso e Verdadeiro. O
valor padrão desta propriedade é Falso.
Value
Indica o valor inicial do objeto. Tem comportamento Booleano: Se Verdadeiro, o objeto inicia selecionado e, do
contrário, seu estado inicial é não selecionado. O valor padrão desta propriedade é Falso.
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto.

4.3.2.14.8 Caixa de Seleção


Esta seção contém informações sobre propriedades do objeto Caixa de Seleção (MdcCheckBox). Este objeto não
possui eventos nem métodos associados.

4.3.2.14.8.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Caixa de Seleção (MdcCheckBox).

Visualização 142
Accelerator
Define ou recupera a tecla aceleradora do objeto. Esta tecla aceleradora é uma tecla que, usada em conjunto com a
tecla ALT, move o foco para o objeto. O valor padrão desta propriedade é uma String vazia.
Alignment
Esta propriedade especifica a posição do objeto relativa a sua legenda. As opções disponíveis para esta
propriedade são as seguintes:
· 0 - fmAlignmentLeft: Coloca a legenda à esquerda do objeto
· 1 - fmAligmentRight: Coloca a legenda à direita do objeto (padrão)
AutoSize
Esta propriedade ajusta a largura do texto caso a área disponível ultrapasse o tamanho do objeto. Quando a
propriedade estiver configurada para Verdadeiro, o texto é redimensionado para coincidir com o tamanho atual do
objeto.
BackStyle
Esta propriedade define o estilo do plano de fundo para os objetos. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

Caption
Define o texto que é mostrado no objeto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Caixa de Seleção. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.
GroupName
Esta propriedade é utilizada para criar um grupo de objetos mutuamente exclusivos.

NOTA
Esta propriedade não é utilizada no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento de Locked. Para maiores detalhes, consulte a propriedade
Enabled. O valor padrão desta propriedade é Falso.
Picture
Esta propriedade especifica a figura (bitmap) atribuída ao objeto. Um arquivo com imagem pode ser selecionado
de duas maneiras: através da Lista de Propriedades ou via scripts, utilizando-se a função LoadPicture para especificar
o caminho e o nome do arquivo que contém a figura. Para remover a figura, clique no valor desta propriedade e
pressione a tecla DEL. A tecla BACKSPACE (tecla de espaço do teclado) não remove a figura. Exemplo:
Sub CommandButton1_Click()
Screen.Item("CheckBox1").Picture = LoadPicture("C:\aba.gif")
End Sub
PicturePosition
Esta propriedade especifica a posição da figura atribuída ao objeto em relação a sua legenda. As opções
disponíveis para esta propriedades estão descritas na tabela a seguir.

143 Visualização
Opções disponíveis para a propriedade PicturePosition
OPÇÃO DESCRIÇÃO
0 - fmPicturePositionLeftTop A figura aparece à esquerda da legenda. A legenda é
alinhada com a parte superior da figura

1 - fmPicturePositionLeftCenter A figura aparece à esquerda da legenda. A legenda é


centralizada relativamente à imagem

2 - fmPicturePositionLeftBottom A figura aparece à esquerda da legenda. A legenda é


alinhada com a parte inferior da figura

3 - fmPicturePositionRightTop A figura aparece à direita da legenda. A legenda é


alinhada com a parte superior da figura

4 - fmPicturePositionRightCenter A figura aparece à direita da legenda. A legenda é


centralizada relativamente à figura

5 - fmPicturePositionRightBottom A figura aparece à direita da legenda. A legenda é


alinhada com a parte inferior da figura

6 - fmPicturePositionAboveLeft A figura aparece acima da legenda. A legenda é alinhada


com a extremidade esquerda da figura

7 - fmPicturePositionAboveCenter A figura aparece acima da legenda. A legenda é


centralizada abaixo da figura (padrão)

8 - fmPicturePositionAboveRight A figura aparece acima da legenda. A legenda é alinhada


com a extremidade direita da figura

9 - fmPicturePositionBelowLeft A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade esquerda da figura

10 - fmPicturePositionBelowCenter A figura aparece abaixo da legenda. A legenda é


centralizada acima da figura

11 - fmPicturePositionBelowRight A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade direita da figura

12 - fmPicturePositionCenter A figura aparece no centro do controle. A legenda é


centralizada horizontalmente e verticalmente sobre a
figura.

SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmButtonEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

2 - fmButtonEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita, como se
estivesse afundado na Tela (padrão)

TextAlign
Especifica como o texto é alinhado neste objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Alinha o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
TripleState
Esta propriedade determina até três estados de valores para o objeto. Se a propriedade estiver configurada para
Verdadeiro, o usuário pode selecionar entre três opções de estados: Falso, Verdadeiro ou Nulo. O valor Nulo é
exibido como um botão sombreado. Caso contrário, o usuário pode selecionar entre os valores Falso e Verdadeiro. O
valor padrão desta propriedade é Falso.

Visualização 144
Value
Indica o valor inicial do objeto e tem comportamento Booleano: Se Verdadeiro, o objeto inicia selecionado e, do
contrário, seu estado inicial é não selecionado. O valor padrão desta propriedade é Falso.
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto.

4.3.2.14.9 Editor de Texto


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Editor de Texto (MdcText).

4.3.2.14.9.1 Eventos
Esta seção contém informações sobre os eventos do objeto Editor de Texto (MdcText).
DropButtonClick
DropButtonClick()
Ocorre quando a lista de opções aparece ou desaparece ao se clicar no objeto.

4.3.2.14.9.2 Métodos
Esta seção contém informações sobre os métodos do objeto Editor de Texto (MdcText).
Copy
Copy()
Copia para a Área de Transferência um texto previamente selecionado. Utilize o método Paste para colar o texto em
outro local.
Cut
Cut()
Recorta para a Área de Transferência um texto previamente selecionado. Utilize o método Paste para colar o texto em
outro local.
Paste
Paste()
Insere em um objeto de texto o conteúdo da Área de Transferência.

4.3.2.14.9.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Editor de Texto (MdcText).
AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Para o objeto
Editor de Texto (Text Box), quando a propriedade estiver configurada para Verdadeiro, a largura do texto é
reajustada para a mesma do objeto. O valor padrão desta propriedade é Falso.

NOTA
Recomenda-se evitar o uso desta propriedade com um Editor de Texto vazio, que também utilize as propriedades
Multiline e WordWrap. Quando o usuário digita em um Editor de Texto com estas propriedades ajustadas para
Verdadeiro, ele automaticamente se redimensiona como uma caixa longa e estreita, com um caractere de largura e
uma linha de texto de comprimento.

AutoTab
Esta propriedade habilita ou desabilita a tabulação automática no objeto. Se a propriedade estiver configurada
para Verdadeiro, a tabulação automática ocorre. Caso contrário, não é utilizada.
Após o usuário digitar o número máximo de caracteres em um objeto (configurado na propriedade MaxLength), o
foco se move automaticamente para o próximo objeto da ordem de tabulação, quando estes caracteres forem
atingidos. Por exemplo, quando se quer que um Editor de Texto exiba dados de estoque que possuam sempre cinco
caracteres, pode-se usar a propriedade MaxLength para especificar o número máximo de caracteres a serem
introduzidos no objeto e esta propriedade para tabular automaticamente para o próximo objeto depois que o
usuário digitar cinco caracteres.

145 Visualização
AutoWordSelect
Habilita ou desabilita a seleção automática de palavras no objeto. Se esta propriedade estiver configurada para
Verdadeiro, a palavra indicada é selecionada no texto mais o espaço seguinte, caso se tenha selecionado parte dela.
Caso contrário, somente o caractere indicado na palavra é selecionado.
BackStyle
Esta propriedade define o estilo do plano de fundo para os objetos. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

BorderColor
Esta propriedade determina a cor da borda que é aplicada no objeto. Com esta propriedade, é possível aplicar a
cor padrão ou personalizá-la através da sua edição. Para que esta propriedade seja aplicável, é necessário que a
propriedade BorderStyle esteja configurada para 1 - fmBorderStyleSingle. O valor padrão desta propriedade é
preto (RGB(0, 0, 0)).
BorderStyle
Esta propriedade determina o estilo de borda que é aplicada ao objeto. As opções disponíveis são as seguintes:
· 0 - fmBorderStyleNone: Sem borda (padrão)
· 1 - fmBorderStyleSingle: Com borda simples
CanPaste
Esta propriedade especifica se a Área de Transferência contém os dados aos quais o objeto dá suporte. Se a opção
estiver configurada para Verdadeiro, o objeto pode receber informações coladas da Área de Transferência. Se os
dados da Área de Transferência estiverem em um formato ao qual o objeto não dá suporte, o valor desta
propriedade é Falso. Por exemplo, ao se tentar colar um bitmap em um objeto que só dê suporte a texto, o valor
desta propriedade é Falso. Esta propriedade é somente de leitura.
CurLine
Especifica a linha corrente do objeto, ou seja, a linha que contém o ponto de inserção de texto. O número da
primeira linha é 0 (zero). O valor padrão desta propriedade é 0 (zero).
CurTargetX
Retorna a posição horizontal de inserção de um texto no objeto. Esta posição é medida em unidades himétricas (um
himetro corresponde a 0,0001 de um metro). Pode-se usar esta propriedade e a propriedade CurX para mover o
ponto de inserção de um texto conforme o usuário percorre o conteúdo do objeto. Quando o usuário move o ponto
de inserção para outra linha do texto, esta propriedade especifica a posição mais indicada para o ponto de inserção
do texto desejado. A propriedade CurX é definida neste valor, se a linha do texto for maior que o valor desta
propriedade. Caso contrário, a propriedade CurX é definida como o final da linha do texto. Esta propriedade é
somente de leitura.
CurX
Esta propriedade especifica a posição atual horizontal do ponto de inserção no objeto. Esta propriedade é aplicada
em um objeto que possua várias linhas, isto é, a propriedade Multiline está habilitada. O valor de retorno é válido
quando o objeto possui o foco. Pode-se usar a propriedade Multiline e esta propriedade para posicionar o ponto
de inserção do texto, conforme o usuário usa a barra de rolagem pelo conteúdo no objeto. Quando o usuário move o
ponto de inserção para uma outra linha de texto rolando o conteúdo do objeto, a propriedade CurTargetX especifica
a posição desejada para o ponto de inserção. Esta propriedade é definida com este valor se a linha de texto for
maior do que o valor de CurTargetX. Caso contrário, esta propriedade é definida no fim da linha de texto. Esta
propriedade não pode ser alterada com o objeto ativo.
DragBehavior
Habilita ou desabilita o recurso de arrastar e soltar um texto no conteúdo do objeto. As opções disponíveis para
esta propriedade são as seguintes:
· 0 - fmDragBehaviorDisabled: Não permite a ação de arrastar e soltar o texto no conteúdo do objeto
· 1 - fmDragBehaviorEnabled: Permite a ação de arrastar e soltar o texto no conteúdo do objeto

Visualização 146
O valor padrão desta propriedade é 0 - fmDragBehaviorDisabled.

NOTA
Esta propriedade não tem efeito se a propriedade Style estiver configurada para 2 - fmStyleDropDownList.

EnterFieldBehavior
Esta propriedade controla a forma como o conteúdo do texto é selecionado na área de edição quando se
pressiona a tecla TAB no objeto e não quando o objeto recebe o foco como um resultado do método SetFocus. As
opções disponíveis para esta propriedade são as seguintes:
· 0 - fmEnterFieldBehaviorSelectAll: Seleciona todo o conteúdo do texto quando a tecla TAB é pressionada no
objeto (padrão)
· 1 - fmEnterFieldBehaviorRecallSelection: A seleção permanece inalterada
EnterKeyBehavior
Define o efeito da tecla ENTER no objeto. Se esta propriedade estiver configurada para Verdadeiro, ao pressionar a
tecla ENTER uma nova linha é criada na área de edição do texto no objeto. Caso contrário, ao pressionar a tecla
ENTER o foco é passado para o próximo objeto da ordem de tabulação. Isto também ocorre se a propriedade
Multiline estiver configurada para Falso, independente do valor desta propriedade.
O atalho de teclado CTRL + ENTER também depende do valor da propriedade Multiline. Se esta propriedade estiver
configurada para Verdadeiro, ao pressionar estas teclas uma nova linha é criada na área de edição do texto do
objeto, independente do valor desta propriedade. Se o valor da propriedade é Falso, as teclas não têm efeito sobre o
texto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Editor de Texto. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.
HideSelection
Esta propriedade especifica se o texto selecionado continua em destaque quando um objeto não tem mais o foco.
Se a propriedade estiver configurada para Verdadeiro, o texto selecionado não está em destaque, a menos que o
objeto tenha o foco. Caso contrário, o texto selecionado sempre aparece em destaque. O valor padrão desta
propriedade é Verdadeiro.
IMEMode
Esta propriedade especifica o modo IME (Input Method Editor) do objeto Editor de Texto.

NOTA
Esta propriedade se aplica apenas a programas escritos em idiomas asiáticos (chinês simplificado, chinês tradicional,
coreano e japonês) e é ignorada em outros programas. Foi mantida por motivos de compatibilidade com a
especificação padrão dos objetos Microsoft Forms.

As opções disponíveis para esta propriedade estão descritas na tabela a seguir.


Opções disponíveis para a propriedade IMEMode
OPÇÃO DESCRIÇÃO
0 - fmIMEModeNoControl Não controla o modo IME (padrão)

1 - fmIMEModeOn Modo IME ativado

2 - fmIMEModeOff Modo IME desativado. Modo inglês

3 - fmIMEModeDisable Modo IME desativado. O usuário não pode ativar o


modo IME pelo teclado

4 - fmIMEModeHiragana Modo IME ativado com modo Hiragana de largura total

5 - fmIMEModeKatakana Modo IME ativado com modo Katakana de largura total

6 - fmIMEModeKatakanaHalf Modo IME ativado com modo Katakana de meia largura

7 - fmIMEModeAlphaFull Modo IME ativado com modo Alfanumérico de largura


total

147 Visualização
OPÇÃO DESCRIÇÃO
8 - fmIMEModeAlpha Modo IME ativado com modo Alfanumérico de meia
largura

9 - fmIMEModeHangulFull Modo IME ativado com modo Hangul de largura total

10 - fmIMEModeHangul Modo IME ativado com modo Hangul de meia largura

11 - fmIMEModeHanziFull Modo IME ativado com modo Hanzi de largura total

12 - fmIMEModeHanzi Modo IME ativado com modo Hanzi de meia largura

IntegralHeight
Esta propriedade ajusta a altura da área de edição do texto, caso a área disponível ultrapasse o tamanho do
objeto. Se esta propriedade estiver configurada para Verdadeiro, a altura da área de edição do texto é reajustada
para coincidir com o tamanho atual do objeto, permitindo assim a exibição completa do conteúdo do texto. Caso
contrário, a área de edição do texto continua com seu tamanho original. Se os textos são maiores que o espaço
disponível, estes não são exibidos no objeto.
LineCount
Esta propriedade retorna o número de linhas do objeto. Esta propriedade é somente de leitura.
Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.
MaxLength
Esta propriedade determina o número máximo de caracteres no objeto. Configurando esta propriedade como 0
(zero), não há limite de caracteres no objeto.
Multiline
Esta propriedade indica se o texto tem múltiplas linhas (Verdadeiro) ou é uma caixa de texto simples (Falso). Isto
pode ser visualizado quando o E3 Viewer está em execução. O valor padrão desta propriedade é Falso.
PasswordChar
Converte o texto do objeto para um caractere especial, configurado na propriedade. Utilize esta propriedade para
proteger informações sensíveis, como senhas ou códigos de segurança. O valor desta propriedade é o caractere
(normalmente um asterisco) que aparece em um objeto, ao invés dos caracteres reais que o usuário digita. Se não for
especificado um caractere, o controle exibe os caracteres digitados pelo usuário.
ScrollBars
Especifica se o objeto possui barras de rolagem verticais, horizontais ou ambas. As opções disponíveis são as
seguintes:
· 0 - fmScrollBarsNone: Não exibe barras de rolagem (padrão)
· 1 - fmScrollBarsHorizontal: Exibe uma barra de rolagem horizontal
· 2 - fmScrollBarsVertical: Exibe uma barra de rolagem vertical
· 3 - fmScrollBarsBoth: Exibe tanto a barra de rolagem vertical quanto a barra de rolagem horizontal
SelectionMargin
Habilita ou desabilita a margem de seleção do objeto. Se esta propriedade estiver configurada para Verdadeiro, ao
clicar na margem do objeto o texto é selecionado. Caso contrário, ao clicar na margem o texto não é selecionado.

NOTA
Se esta propriedade estiver configurada para Verdadeiro quando o objeto for impresso, a margem de seleção
também é impressa.

SelLength
Retorna o número de caracteres selecionados no objeto. Esta propriedade não pode ser alterada com o objeto
ativo.

Visualização 148
SelStart
Indica o ponto inicial do texto selecionado ou o ponto de inserção, se nenhum texto for selecionado. Esta
propriedade não pode ser alterada com o objeto ativo.
SelText
Retorna o texto selecionado no objeto. Esta propriedade não pode ser alterada com o objeto ativo.
SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmSpecialEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

1 - fmSpecialEffectRaised O objeto possui um destaque na parte superior


esquerda e uma sombra na parte inferior direita. O
objeto parece estar em relevo

2 - fmSpecialEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita. O objeto e a sua
borda parecem estar afundados na Tela (padrão)

3 - fmSpecialEffectEtched A borda parece estar esculpida ao redor da extremidade


do objeto

6 - fmSpecialEffectBump O objeto possui um ressalto na parte inferior direita e


parece plano na parte superior esquerda

TabKeyBehavior
Determina se as tabulações são permitidas na região de edição. Se a propriedade estiver configurada para
Verdadeiro, ao pressionar a tecla TAB é inserido um caractere de espaçamento na região de edição. Caso contrário,
ao pressionar TAB, o foco é passado para o próximo objeto na ordem de tabulação.
Text
Retorna o texto sendo digitado na opção selecionada. Esta propriedade não pode ser alterada com o objeto ativo.
TextAlign
Especifica como o texto é alinhado no objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Alinha o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
TextLength
Retorna o número de caracteres digitados no objeto. Esta propriedade é somente de leitura.
Value
Este é o texto na área de edição. Esta propriedade é do tipo Variant, e pode assumir valores de todo e qualquer
tipo (Date, Boolean, String, etc.).
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto. Para que esta propriedade funcione, a propriedade Multiline deve ser obrigatoriamente
igual a Verdadeiro.

4.3.2.14.10 Fonte
Esta seção contém informações sobre propriedades do objeto Fonte (Font) retornado pelas propriedades Font
dos objetos MS Forms, com exceção dos objetos Barra de Rolagem e Botão Incremento-Decremento. Este objeto não
possui eventos nem métodos associados.

4.3.2.14.10.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte (Font) retornado pelas propriedades Font
dos objetos MS Forms, com exceção dos objetos Barra de Rolagem e Botão Incremento-Decremento.

149 Visualização
Bold
Esta propriedade indica se o texto do objeto MS Forms está em negrito.
Charset
Esta propriedade indica o conjunto de caracteres disponível para a fonte do objeto MS Forms. Os valores possíveis
para esta propriedade estão descritos na tabela a seguir.
Valores disponíveis para a propriedade Charset
VALOR PÁGINA DE CÓDIGO NOME DESCRIÇÃO
0 1252 ANSI_CHARSET ANSI (American National
Standards Institute)

1 -- DEFAULT_CHARSET Padrão (mostra o conjunto


de caracteres disponível na
Fonte)

2 -- SYMBOL_CHARSET Símbolos

128 932 SHIFTJIS_CHARSET Japonês (Shift-JIS)

129 949 HANGUL_CHARSET Coreano

134 936 GB2312_CHARSET Chinês Simplificado (GBK)

136 950 CHINESEBIG5_CHARSET Chinês Tradicional (Big5)

161 1253 GREEK_CHARSET Grego

162 1254 TURKISH_CHARSET Turco

177 1255 HEBREW_CHARSET Hebraico

178 1256 ARABIC_CHARSET Árabe

186 1257 BALTIC_CHARSET Báltico

204 1251 RUSSIAN_CHARSET Cirílico

222 874 THAI_CHARSET Tailandês

238 1250 EE_CHARSET Centro-Europeu

255 -- OEM_CHARSET OEM (Original Equipment


Manufacturer)

Italic
Esta propriedade indica se o texto do objeto MS Forms está em itálico.
Name
Esta propriedade indica o nome da fonte do objeto MS Forms.
Size
Esta propriedade indica o tamanho, em pontos, da fonte do texto do objeto MS Forms.
Strikethrough
Esta propriedade indica se o texto do objeto MS Forms usa o efeito de tachado.
Underline
Esta propriedade indica se o texto do objeto MS Forms usa o efeito de sublinhado.
Weight
Esta propriedade indica a variação do efeito de negrito na fonte do objeto MS Forms, ou seja, da propriedade Bold.
Os valores para esta propriedade podem variar entre 0 (zero, não interfere no efeito de negrito) e 1000.

4.3.2.14.11 Lista
Esta seção contém informações sobre métodos e propriedades do objeto Lista (MdcList). Este objeto não possui
eventos associados.

Visualização 150
4.3.2.14.11.1 Métodos
Esta seção contém informações sobre os métodos do objeto Lista (MdcList).
AddItem
AddItem([pvargItem], [pvargIndex])
Este método é utilizado para adicionar itens a uma Lista. O parâmetro pvargItem é uma String que contém o texto que
é adicionado à lista e, se omitido, é acrescentada uma String em branco. O parâmetro pvargIndex é o índice do texto
na lista e, se omitido, o valor do parâmetro pvargItem é adicionado como último item da lista. Exemplo:
Sub CommandButton1_Click()
EntryCount = EntryCount + 1
ListBox1.AddItem(EntryCount & " - Selection")
End Sub
Clear
Clear()
Limpa o texto do objeto.
RemoveItem
RemoveItem(pvargIndex)
Remove itens da Lista. Este método possui o parâmetro pvargIndex, que especifica a linha que é excluída, iniciando em
0 (zero), ou seja, o primeiro elemento é 0 (zero), o segundo é 1 (um) e assim por diante. Exemplo:
Sub CommandButton2_Click()
List1.SetFocus
' Verifica se a lista contém dados selecionados
If List1.ListCount >= 1 Then
' Se não há nenhuma seleção,
' seleciona o último dado da lista.
If List1.ListIndex = -1 Then
List1.ListIndex = List1.ListCount – 1
End If
List1.RemoveItem(List1.ListIndex)
End If
End Sub

4.3.2.14.11.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Lista (MdcList).
BorderColor
Esta propriedade determina a cor da borda que é aplicada no objeto. Com esta propriedade, é possível aplicar a
cor padrão ou personalizá-la através da sua edição. Para que esta propriedade seja aplicável, é necessário que a
propriedade BorderStyle esteja configurada para 1 - fmBorderStyleSingle. O valor padrão desta propriedade é
preto (RGB(0, 0, 0)).
BorderStyle
Esta propriedade determina o estilo de borda que é aplicada ao objeto. As opções disponíveis são as seguintes:
· 0 - fmBorderStyleNone: Sem borda (padrão)
· 1 - fmBorderStyleSingle: Com borda simples
BoundColumn
Determina a coluna da lista onde os dados são armazenados. Por exemplo, se cada linha contém oito itens e esta
propriedade é igual a 3 (três), o sistema armazena as informações na terceira coluna da linha atualmente selecionada.
Se o valor for igual a 0 (zero), este valor é passado para a propriedade ListIndex do objeto. Se o valor for 1 (um) ou
superior, o dado indicado é atribuído à coluna referente ao valor especificado na propriedade. As colunas são
numeradas a partir de 1 (um).

NOTA
Esta propriedade não tem efeito no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

Column

151 Visualização
Especifica a linha e coluna no objeto. Se for especificado somente o valor de coluna, esta propriedade lê ou escreve
a coluna especificada na linha atual do objeto. Por exemplo, "MinhaListadeSelecao.Column(3)" lê ou escreve a terceira
coluna do objeto. Esta propriedade não pode ser alterada com o objeto ativo.
ColumnCount
Esta propriedade especifica o número de colunas do objeto. A configuração desta propriedade em 0 (zero) não
exibe nenhuma coluna, e a configuração desta propriedade como -1 (menos um) exibe todas as colunas disponíveis.
O valor padrão desta propriedade é 1 (um).
ColumnHeads
Esta propriedade habilita ou desabilita a exibição do título das colunas no objeto. Se a propriedade estiver
configurada para Verdadeiro, o título é mostrado. Caso contrário, o título das colunas não é mostrado. O valor
padrão é Falso.
ColumnWidths
Esta propriedade é utilizada para especificar a largura da coluna do objeto, em pontos. Um valor igual a -1 (menos
um) ou em branco faz com que a largura seja calculada na coluna (a largura mínima de uma coluna calculada é 72
pontos, ou uma polegada). Um valor igual a 0 (zero) oculta a coluna. Para produzir colunas mais estreitas, deve-se
especificar a largura na propriedade ou utilizar algum dos valores descritos na tabela a seguir.
Opções disponíveis para a propriedade ColumnWidths
OPÇÃO DESCRIÇÃO
90;72;90 A primeira coluna possui 90 pontos (1,25 polegada), a
segunda coluna possui 72 pontos (uma polegada) e a
terceira coluna possui 90 pontos

6 cm;0;6 cm A primeira coluna possui 6 centímetros, a segunda coluna


está oculta e a terceira coluna possui 6 centímetros.
Como parte da terceira coluna é visível, uma barra de
rolagem horizontal aparece

1,5 pol;0;2,5 pol A primeira coluna possui 1,5 polegadas, a segunda


coluna está oculta e a terceira coluna possui 2,5
polegadas

2 pol;;2 pol A primeira coluna possui 2 polegadas, a segunda coluna


possui 1 polegada (padrão) e a terceira coluna possui 2
polegadas. Como somente metade da terceira coluna é
visível, uma barra de rolagem horizontal aparece

(Vazio) Todas as três colunas possuem a mesma largura (1,33


polegadas). O valor padrão desta propriedade é vazio (o
E3 utiliza o valor padrão do sistema)

Font
Esta propriedade é utilizada para determinar a fonte do objeto Lista. Esta propriedade não pode ser utilizada em
Associações e contém as subpropriedades descritas no tópico Fonte.
IMEMode
Esta propriedade especifica o modo IME (Input Method Editor) do objeto Lista.

NOTA
Esta propriedade se aplica apenas a programas escritos em idiomas asiáticos (chinês simplificado, chinês tradicional,
coreano e japonês) e é ignorada em outros programas. Foi mantida por motivos de compatibilidade com a
especificação padrão dos objetos Microsoft Forms.

As opções disponíveis para esta propriedade estão descritas na tabela a seguir.


Opções disponíveis para a propriedade IMEMode
OPÇÃO DESCRIÇÃO
0 - fmIMEModeNoControl Não controla o modo IME (padrão)

1 - fmIMEModeOn Modo IME ativado

Visualização 152
OPÇÃO DESCRIÇÃO
2 - fmIMEModeOff Modo IME desativado. Modo inglês

3 - fmIMEModeDisable Modo IME desativado. O usuário não pode ativar o


modo IME pelo teclado

4 - fmIMEModeHiragana Modo IME ativado com modo Hiragana de largura total

5 - fmIMEModeKatakana Modo IME ativado com modo Katakana de largura total

6 - fmIMEModeKatakanaHalf Modo IME ativado com modo Katakana de meia largura

7 - fmIMEModeAlphaFull Modo IME ativado com modo Alfanumérico de largura


total

8 - fmIMEModeAlpha Modo IME ativado com modo Alfanumérico de meia


largura

9 - fmIMEModeHangulFull Modo IME ativado com modo Hangul de largura total

10 - fmIMEModeHangul Modo IME ativado com modo Hangul de meia largura

11 - fmIMEModeHanziFull Modo IME ativado com modo Hanzi de largura total

12 - fmIMEModeHanzi Modo IME ativado com modo Hanzi de meia largura

IntegralHeight
Esta propriedade ajusta a altura da área de edição do texto, caso a área disponível ultrapasse o tamanho do
objeto. Se esta propriedade estiver configurada para Verdadeiro, a altura da área de edição do texto é reajustada
para coincidir com o tamanho atual do objeto, permitindo assim a exibição completa do conteúdo do texto. Caso
contrário, a área de edição do texto continua com seu tamanho original. Se os textos são maiores que o espaço
disponível, este não é exibido no objeto.
List
Retorna ou define as entradas da linha e da coluna na lista do objeto. A numeração de linha e de coluna começa
com 0 (zero). Isto é, o número de linha da primeira linha na lista é 0 (zero) e o número de coluna da primeira coluna é
0 (zero). O número da segunda linha ou coluna é 1 (um), e assim por diante. Esta propriedade não pode ser alterada
com o objeto ativo.
ListCount
Retorna o número de itens contidos na lista do objeto. Esta propriedade é somente de leitura.
ListIndex
Identifica o item atualmente selecionado na lista, chamado de índice. Os valores desta propriedade vão de -1
(menos um) ao número total de linhas em uma lista menos um (isto é, ListCount - 1). Quando nenhuma linha é
selecionada, esta propriedade retorna -1 (menos um). Quando o usuário seleciona uma linha em uma Lista de Seleção,
o sistema define o valor desta propriedade. O valor desta propriedade da primeira linha de uma lista é 0 (zero), o
valor da segunda linha é 1 (um), e assim por diante. Esta propriedade não pode ser alterada com o objeto ativo.
ListStyle
Esta propriedade determina o estilo da lista do objeto. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - fmListStylePlain: Listagem com os itens do plano de fundo em destaque (padrão)
· 1 - fmListStyleOption: Exibe botões de opção ou caixas de seleção para uma lista de várias opções. Quando o
usuário seleciona um item do grupo, o botão de opção associado ao item é selecionado e os botões de opção
para outros itens no grupo são desmarcados

NOTA
A opção 1 - fmListStyleOption só pode ser habilitada se a propriedade MultiSelect estiver configurada como 1 -
fmMultiSelectMulti.

Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.

153 Visualização
MatchEntry
Procura, através do texto digitado pelo usuário, por uma entrada de texto que coincida com os dados existentes
no objeto. Ao encontrar uma coincidência no texto, a linha é selecionada e o conteúdo da coluna é exibido. As opções
disponíveis são as seguintes:
· 0 - fmMatchEntryFirstLetter: Procura pela entrada de texto que coincida com o primeiro caractere digitado no
objeto. Se for digitada repetidamente a mesma letra, é passada para a próxima entrada de texto que comece
com esta letra, e assim por diante (padrão)
· 1 - fmMatchEntryComplete: Conforme cada caractere é digitado, o objeto procura por uma entrada de texto
que coincida com os caracteres digitados
· 2 - fmMatchEntryNone: Não realiza a procura no objeto
MultiSelect
Esta propriedade indica se o objeto permite múltiplas seleções. As opções disponíveis para esta propriedade são
as seguintes:
· 0 - fmMultiSelectSingle: Somente um item pode ser selecionado (padrão)
· 1 - fmMultiSelectMulti: Permite selecionar um item através da barra de espaço ou clique com o mouse, fazendo
com que se marque ou desmarque um item na lista
· 2 - fmMultiSelectExtended: Permite selecionar um item através da tecla SHIFT, clicando com o mouse ou
pressionando a tecla SHIFT e uma das teclas de direção, estendendo a seleção para o item atual. Pressionando a
tecla CTRL e clicando com o mouse, marca ou desmarca um item
Selected
Seleciona ou desfaz a seleção de um item, e verifica se um item está selecionado, quando a propriedade Multiline
está configurada como Verdadeiro. Para saber se um determinado item está selecionado, o índice do item a ser
consultado deve ser passado e a propriedade retorna se o item está selecionado ou não. Desta forma, é possível
identificar quais itens estão selecionados quando o usuário selecionar mais de um. Esta propriedade não pode ser
alterada com o objeto ativo. Quando o usuário não estiver utilizando múltiplas seleções, recomenda-se que sejam
usadas as propriedades Value ou ListIndex.
SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmSpecialEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

1 - fmSpecialEffectRaised O objeto possui um destaque na parte superior


esquerda e uma sombra na parte inferior direita. O
objeto parece estar em relevo

2 - fmSpecialEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita. O objeto e a sua
borda parecem estar afundados na Tela (padrão)

3 - fmSpecialEffectEtched A borda parece estar esculpida ao redor da extremidade


do objeto

6 - fmSpecialEffectBump O objeto possui um ressalto na parte inferior direita e


parece plano na parte superior esquerda

Text
Retorna o texto da opção selecionada. Esta propriedade não pode ser alterada com o objeto ativo.
TextAlign
Especifica como o texto é alinhado no objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Alinha o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto

Visualização 154
TextColumn
Esta propriedade identifica a coluna no objeto. Os valores para esta propriedade vão de -1 (menos um) ao número
de colunas na lista. O valor desta propriedade para a primeira coluna é 1 (um), o valor da segunda coluna é 2 (dois), e
assim por diante. A configuração desta propriedade em 0 (zero) exibe os valores para a propriedade ListIndex. A
configuração desta propriedade como -1 (menos um) exibe a primeira coluna que possui o valor da propriedade
ColumnWidths maior do que 0 (zero).
TopIndex
Esta propriedade define ou retorna o item da lista que aparece na posição mais próxima do topo na lista. Esta
propriedade retorna o valor -1 (menos um) se a lista está vazia ou não é exibida.
Value
Este é o valor da propriedade BoundColumn das linhas atualmente selecionadas. Esta propriedade não tem efeito
no E3 e foi mantida por motivos de compatibilidade com a especificação padrão dos objetos Microsoft Forms.

4.3.2.14.12 Lista de Seleção


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Lista de Seleção (MdcCombo).

4.3.2.14.12.1 Eventos
Esta seção contém informações sobre os eventos do objeto Lista de Seleção (MdcCombo).
DropButtonClick
DropButtonClick()
Ocorre quando a Lista de Opções aparece ou desaparece ao se clicar no objeto.

4.3.2.14.12.2 Métodos
Esta seção contém informações sobre os métodos do objeto Lista de Seleção (MdcCombo).
AddItem
AddItem([pvargItem], [pvargIndex])
Este método é utilizado para se adicionar itens a uma Lista de Seleção. O parâmetro pvargItem é uma String que
contém o texto que é adicionado na lista. Se omitido, é acrescentada uma String em branco. O parâmetro pvargIndex
é o índice do texto na lista. Se omitido, o valor do parâmetro pvargItem é adicionado como último item da lista.
Exemplo:
Sub CommandButton1_Click()
EntryCount = EntryCount + 1
ComboBox1.AddItem(EntryCount & " - Selection")
End Sub
Clear
Clear()
Limpa o texto do objeto.
Copy
Copy()
Copia o texto previamente selecionado para a Área de Transferência. Utilize o método Paste para colar o texto no
local indicado. Exemplo:
Sub CommandButton1_Click()
Screen.Item("ComboBox1").Copy()
End Sub
Cut
Cut()
Recorta o texto previamente selecionado para a Área de Transferência. Utilize o método Paste para colar o texto no
local indicado. Exemplo:
Sub CommandButton1_Click()
Screen.Item("ComboBox1").Cut()
End Sub
DropDown
DropDown()

155 Visualização
Este método abre a lista de itens de uma Lista de Seleção. A chamada deste método tem o mesmo efeito que clicar,
em tempo de execução, no botão com a seta ao lado direito do objeto. Exemplo:
Sub CommandButton1_Click()
Dim ComboBox1
ComboBox1.AddItem "Abacaxi"
ComboBox1.AddItem "Morango"
ComboBox1.AddItem "Uva"
ComboBox1.AddItem "Laranja"
ComboBox1.DropDown()
End Sub
Paste
Paste()
Insere no objeto o conteúdo da Área de Transferência. Exemplo:
Sub CommandButton1_Click()
Screen.Item("ComboBox1").Paste()
End Sub
RemoveItem
RemoveItem(pvargIndex)
Remove itens de uma Lista. Este método possui o parâmetro pvargIndex, que especifica a linha que é excluída,
iniciando em 0 (zero), ou seja, o primeiro elemento é 0 (zero), o segundo é 1 (um) e assim por diante. Exemplo:
Sub CommandButton2_Click()
ComboBox1.SetFocus
' Verifica se a lista contém dados selecionados
If ComboBox1.ListCount >= 1 Then
' Se não há nenhuma seleção,
' selecione o último dado da lista.
If ComboBox1.ListIndex = -1 Then
ComboBox1.ListIndex = ComboBox1.ListCount – 1
End If
ComboBox1.RemoveItem(ComboBox1.ListIndex)
End If
End Sub

4.3.2.14.12.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Lista de Seleção (MdcCombo).
AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Para o objeto
Lista de Seleção (Combo), quando a propriedade estiver configurada para Verdadeiro, a largura do texto é reajustada
para a mesma do objeto.
AutoTab
Esta propriedade habilita ou desabilita a tabulação automática no objeto. Se a propriedade estiver configurada
para Verdadeiro, a tabulação automática ocorre. Caso contrário, não é utilizada.
Após o usuário digitar o número máximo de caracteres em um objeto (utilizando a propriedade MaxLength), o foco
se move automaticamente para o próximo objeto da ordem de tabulação, quando estes caracteres forem atingidos.
Por exemplo, para que uma Lista de Seleção exiba dados de estoque que possuam sempre cinco caracteres, pode-se
usar a propriedade MaxLength para especificar o número máximo de caracteres a serem introduzidos no objeto e
esta propriedade para tabular automaticamente para o próximo objeto depois que o usuário digitar cinco caracteres.
AutoWordSelect
Habilita ou desabilita a seleção automática de palavras no objeto. Se esta propriedade estiver configurada para
Verdadeiro, a palavra indicada é selecionada no texto mais o espaço seguinte, caso se tenha selecionada parte dela.
Caso contrário, somente o caractere indicado na palavra é selecionado.
BackStyle
Esta propriedade define o estilo do plano de fundo para este objeto. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

Visualização 156
NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

BorderColor
Esta propriedade determina a cor da borda que é aplicada no objeto. Com esta propriedade, é possível aplicar a
cor padrão ou personalizá-la através da sua edição. Para que esta propriedade seja aplicável, é necessário que a
propriedade BorderStyle esteja configurada para 1 - fmBorderStyleSingle. O valor padrão desta propriedade é
preto (RGB(0, 0, 0)).
BorderStyle
Esta propriedade determina o estilo de borda que é aplicada ao objeto. As opções disponíveis são as seguintes:
· 0 - fmBorderStyleNone: Sem borda (padrão)
· 1 - fmBorderStyleSingle: Com borda simples
BoundColumn
Determina a coluna da lista onde os dados são armazenados. Por exemplo, se cada linha contém oito itens e esta
propriedade é igual a 3 (três), o objeto armazena as informações na terceira coluna da linha atualmente selecionada.
Se o valor for igual a 0 (zero), este valor é passado para a propriedade ListIndex do objeto. Se o valor for igual a 1
(um) ou superior, o dado indicado é atribuído à coluna referente ao valor especificado na propriedade. As colunas
são numeradas a partir de 1 (um).

NOTA
Esta propriedade não tem efeito no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

CanPaste
Esta propriedade especifica se a Área de Transferência contém os dados aos quais o objeto dá suporte. Se esta
propriedade estiver configurada para Verdadeiro, o objeto pode receber informações coladas da Área de
Transferência. Se os dados da Área de Transferência estiverem em um formato ao qual o objeto não dá suporte, o
valor desta propriedade é Falso. Por exemplo, ao tentar colar um bitmap em um objeto que só dê suporte a texto, o
valor desta propriedade é Falso. Esta propriedade é somente de leitura.
Column
Especifica a linha e a coluna no objeto. Se for especificado somente o valor de coluna, esta propriedade lê ou
escreve a coluna especificada na linha atual do objeto. Por exemplo, "MinhaListadeSelecao.Column(3)" lê ou escreve a
terceira coluna do objeto. Esta propriedade não pode ser alterada com o objeto ativo.
ColumnCount
Esta propriedade especifica o número de colunas do objeto. A configuração desta propriedade em 0 (zero) não
exibe nenhuma coluna, e a configuração desta propriedade como -1 (menos um) exibe todas as colunas disponíveis.
O valor padrão desta propriedade é 1 (um).
ColumnHeads
Esta propriedade habilita ou desabilita a exibição do título das colunas no objeto. Se a propriedade estiver
configurada para Verdadeiro, o título é mostrado. Caso contrário, o título das colunas não é mostrado. O valor
padrão é Falso.
ColumnWidths
Esta propriedade é utilizada para especificar a largura da coluna do objeto, em pontos. Um valor igual a –1
(menos um) ou em branco faz com que a largura seja calculada na coluna (a largura mínima de uma coluna calculada
é 72 pontos, ou uma polegada). Um valor igual a 0 (zero) oculta a coluna. Para produzir colunas mais estreitas, deve-
se especificar a largura na propriedade ou utilizar algum dos valores descritos na tabela a seguir.
Opções disponíveis para a propriedade ColumnWidths
OPÇÃO DESCRIÇÃO
90;72;90 A primeira coluna possui 90 pontos (1,25 polegada), a
segunda coluna possui 72 pontos (uma polegada) e a
terceira coluna possui 90 pontos

157 Visualização
OPÇÃO DESCRIÇÃO
6 cm;0;6 cm A primeira coluna possui 6 centímetros, a segunda coluna
está oculta e a terceira coluna possui 6 centímetros.
Como parte da terceira coluna é visível, uma barra de
rolagem horizontal aparece

1,5 pol;0;2,5 pol A primeira coluna possui 1,5 polegadas, a segunda


coluna está oculta e a terceira coluna possui 2,5
polegadas

2 pol;;2 pol A primeira coluna possui 2 polegadas, a segunda coluna


possui 1 polegada (padrão) e a terceira coluna possui 2
polegadas. Como somente metade da terceira coluna é
visível, uma barra de rolagem horizontal aparece

(Vazio) Todas as três colunas possuem a mesma largura (1,33


polegadas). O valor padrão desta propriedade é vazio (o
E3 utiliza o valor padrão do sistema)

CurTargetX
Retorna a posição horizontal de inserção de um texto no objeto. Esta posição é medida em unidades himétricas (um
himetro é igual a 0,0001 de um metro). Pode-se usar esta propriedade e a propriedade CurX para mover o ponto de
inserção de um texto conforme o usuário percorre o conteúdo do objeto. Quando o usuário move o ponto de
inserção para outra linha do texto, esta propriedade especifica a posição mais indicada para o ponto de inserção do
texto desejado. A propriedade CurX é definida neste valor se a linha do texto for maior que o valor desta
propriedade. Caso contrário, a propriedade CurX é definida como o final da linha do texto. Esta propriedade é
somente de leitura.

NOTA
Esta propriedade não tem efeito no E3 e foi mantida por motivos de compatibilidade com a especificação padrão
dos objetos Microsoft Forms.

CurX
Esta propriedade especifica a posição atual horizontal do ponto de inserção no objeto. Esta propriedades é
aplicada em um objeto que possua várias linhas, isto é, cuja propriedade Multiline está habilitada. O valor de retorno
é válido quando o objeto possui o foco. Pode-se usar a propriedade Multiline e esta propriedade para posicionar o
ponto de inserção do texto conforme o usuário usa a barra de rolagem pelo conteúdo do objeto. Quando o usuário
move o ponto de inserção para uma outra linha de texto rolando o conteúdo do objeto, a propriedade CurTargetX
especifica a posição desejada para o ponto de inserção. Esta propriedade é definida com este valor se a linha de
texto for maior do que o valor de CurTargetX. Caso contrário, o valor desta propriedade é definido no fim da linha
de texto. Esta propriedade é somente de leitura.
DragBehavior
Habilita ou desabilita o recurso de arrastar e soltar um texto no conteúdo do objeto. As opções disponíveis para
esta propriedade são as seguintes:
· 0 - fmDragBehaviorDisabled: Não permite a ação de arrastar e soltar o texto no conteúdo do objeto (padrão)
· 1 - fmDragBehaviorEnabled: Permite a ação de arrastar e soltar o texto no conteúdo do objeto

NOTA
Esta propriedade não tem efeito se a propriedade Style estiver configurada para 2 - fmStyleDropDownList.

DropButtonStyle
Esta propriedade especifica o símbolo exibido no botão da Lista de Seleção. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade DropButtonStyle
OPÇÃO DESCRIÇÃO
0 - fmDropButtonStylePlain Exibe um botão plano, sem símbolo

1 - fmDropButtonStyleArrow Exibe um seta para baixo (padrão)

Visualização 158
OPÇÃO DESCRIÇÃO
2 - fmDropButtonStyleEllipsis Exibe reticências

3 - fmDropButtonStyleReduce Exibe uma reta horizontal como um caractere sublinhado

EnterFieldBehavior
Esta propriedade controla a forma como o conteúdo do texto é selecionado na área de edição quando se
pressiona a tecla TAB no objeto e não quando o objeto recebe o foco como um resultado do método SetFocus. As
opções disponíveis para esta propriedade são as seguintes:
· 0 - fmEnterFieldBehaviorSelectAll: Seleciona todo o conteúdo do texto quando a tecla TAB é pressionada no
objeto (padrão)
· 1 - fmEnterFieldBehaviorRecallSelection: A seleção permanece inalterada
Font
Esta propriedade é utilizada para determinar a fonte do objeto Lista de Seleção. Esta propriedade não pode ser
utilizada em Associações e contém as subpropriedades descritas no tópico Fonte.
HideSelection
Esta propriedade especifica se o texto selecionado continua em destaque quando um objeto não tem mais o foco.
Se a propriedade estiver configurada para Verdadeiro, o texto selecionado somente se mantém em destaque caso o
objeto tenha o foco. Caso contrário, o texto selecionado sempre aparece em destaque, independente do foco no
objeto. O valor padrão desta propriedade é Verdadeiro.
IMEMode
Esta propriedade especifica o modo IME (Input Method Editor) do objeto Lista de Seleção.

NOTA
Esta propriedade se aplica apenas a programas escritos em idiomas asiáticos (chinês simplificado, chinês tradicional,
coreano e japonês) e é ignorada em outros programas. Foi mantida por motivos de compatibilidade com a
especificação padrão dos objetos Microsoft Forms.

As opções disponíveis para esta propriedade estão descritas na tabela a seguir.


Opções disponíveis para a propriedade IMEMode
OPÇÃO DESCRIÇÃO
0 - fmIMEModeNoControl Não controla o modo IME (padrão)

1 - fmIMEModeOn Modo IME ativado

2 - fmIMEModeOff Modo IME desativado. Modo inglês

3 - fmIMEModeDisable Modo IME desativado. O usuário não pode ativar o


modo IME pelo teclado

4 - fmIMEModeHiragana Modo IME ativado com modo Hiragana de largura total

5 - fmIMEModeKatakana Modo IME ativado com modo Katakana de largura total

6 - fmIMEModeKatakanaHalf Modo IME ativado com modo Katakana de meia largura

7 - fmIMEModeAlphaFull Modo IME ativado com modo Alfanumérico de largura


total

8 - fmIMEModeAlpha Modo IME ativado com modo Alfanumérico de meia


largura

9 - fmIMEModeHangulFull Modo IME ativado com modo Hangul de largura total

10 - fmIMEModeHangul Modo IME ativado com modo Hangul de meia largura

11 - fmIMEModeHanziFull Modo IME ativado com modo Hanzi de largura total

12 - fmIMEModeHanzi Modo IME ativado com modo Hanzi de meia largura

LineCount
Esta propriedade retorna o número de linhas do objeto. Esta propriedade é somente de leitura.

159 Visualização
List
Retorna ou define as entradas da linha e da coluna na lista do objeto. A numeração de linha e de coluna começa em
0 (zero), isto é, o número de linha da primeira linha na lista é 0 (zero) e o número de coluna da primeira coluna é 0
(zero). O número da segunda linha ou coluna é um (um) e assim por diante. Esta propriedade não pode ser alterada
com o objeto ativo.
ListCount
Retorna o número de itens contidos na lista do objeto. Esta propriedade é somente de leitura.
ListIndex
Identifica o item atualmente selecionado na lista, chamado de índice. Os valores desta propriedade vão de -1
(menos um) ao número total de linhas em uma lista menos um (isto é, ListCount - 1). Quando nenhuma linha é
selecionada, esta propriedade retorna -1 (menos um). Quando o usuário seleciona uma linha em uma Lista de Seleção,
o sistema define o valor desta propriedade. O valor desta propriedade da primeira linha de uma lista é 0 (zero), o
valor da segunda linha é 1 (um) e assim por diante. Esta propriedade não pode ser alterada com o objeto ativo.
ListRows
Esta propriedade determina o número máximo de linhas na lista do objeto. O valor padrão desta propriedade é 8
(oito).
ListStyle
Esta propriedade determina o estilo da lista do objeto. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - fmListStylePlain: Listagem com os itens do plano de fundo em destaque (padrão)
· 1 - fmListStyleOption: Exibe botões de opção ou caixas de seleção para uma lista com várias opções. Quando o
usuário seleciona um item do grupo, o botão de opção associado ao item é selecionado e os botões de opção
para outros itens no grupo são desmarcados
ListWidth
Esta propriedade determina a largura da lista do objeto. O valor padrão desta propriedade é 0 (zero).
Locked
Esta propriedade habilita ou desabilita a edição do objeto. Se esta propriedade estiver configurada para
Verdadeiro, a edição não é permitida. Caso contrário, é possível editar o objeto. Os valores configurados na
propriedade Enabled influenciam o comportamento desta propriedade. Para maiores detalhes, consulte a
propriedade Enabled. O valor padrão desta propriedade é Falso.
MatchEntry
Procura, através do texto digitado pelo usuário, por uma entrada de texto que coincida com os dados existentes
no objeto. Ao encontrar uma coincidência do texto, a linha é selecionada e o conteúdo da coluna é exibido. As opções
disponíveis são as seguintes:
· 0 - fmMatchEntryFirstLetter: Procura pela entrada de texto que coincida com o primeiro caractere digitado no
objeto. Se for digitada repetidamente a mesma letra, é passada para a próxima entrada de texto que comece
com esta letra e assim por diante
· 1 - fmMatchEntryComplete: Conforme cada caractere é digitado, o objeto procura por uma entrada de texto
que coincida com os caracteres digitados (padrão)
· 2 - fmMatchEntryNone: Não realiza a procura no objeto
MatchFound
Indica se o texto que o usuário digitou no objeto coincide com qualquer entrada na lista. Se a propriedade estiver
configurada para Verdadeiro, o conteúdo da propriedade Value coincide com um dos registros na lista. Caso
contrário, o conteúdo da propriedade Value não coincide com nenhum dos registros na lista (padrão). Esta
propriedade é somente de leitura, não sendo aplicável quando a propriedade MatchEntry é definida como 2 (dois). O
valor padrão desta propriedade é Falso.
MatchRequired
Especifica se o texto digitado deve ou não coincidir com os itens existentes na Lista de Seleção. Se a propriedade
estiver configurada para Verdadeiro, o usuário não pode sair da Lista de Seleção até que o texto inserido coincida
com um item existente do objeto. Caso contrário, o texto inserido na Lista de Seleção pode ser diferente de todos os
dados existente na Lista.

Visualização 160
MaxLength
Esta propriedade determina o número máximo de caracteres no objeto. Configurando esta propriedade como 0
(zero), não há limite de caracteres no objeto.
SelectionMargin
Habilita ou desabilita a margem de seleção do objeto. Se esta propriedade estiver configurada para Verdadeiro, o
texto é selecionado ao se clicar na margem do objeto. Caso contrário, o texto não é selecionado ao se clicar na
margem.

NOTA
Se esta propriedade estiver configurada para Verdadeiro quando o objeto for impresso, a margem de seleção
também é impressa.

SelLength
Retorna o número de caracteres selecionados no objeto. Esta propriedade não pode ser alterada com o objeto
ativo.
SelStart
Indica o ponto inicial do texto selecionado ou o ponto de inserção se nenhum texto for selecionado. Esta
propriedade não pode ser alterada com o objeto ativo.
SelText
Retorna o texto selecionado no objeto. Esta propriedade não pode ser alterada com o objeto ativo.
ShowDropButtonWhen
Esta propriedade especifica quando mostrar o botão suspenso (tecla de navegação do objeto). As opções
disponíveis para esta propriedade são as seguintes:
· 0 - fmShowDropButtonWhenNever: Não mostra o botão suspenso em nenhuma circunstância
· 1 - fmShowDropButtonWhenFocus: Mostra o botão suspenso quando o objeto possui o foco
· 2 - fmShowDropButtonWhenAlways: Sempre mostra o botão suspenso (padrão)
SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmSpecialEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos

1 - fmSpecialEffectRaised O objeto possui um destaque na parte superior


esquerda e uma sombra na parte inferior direita, como
se estivesse em relevo

2 - fmSpecialEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita. O objeto e a sua
borda aparecem afundados na Tela (padrão)

3 - fmSpecialEffectEtched A borda parece estar esculpida ao redor da extremidade


do objeto

6 - fmSpecialEffectBump O objeto possui um ressalto na parte inferior direita e


parece plano na parte superior esquerda

Style
Determina o estilo do objeto. As opções disponíveis são as seguintes:
· 0 - fmStyleDropDownCombo: A Lista de Seleção se comporta como uma caixa de combinação suspensa. O
usuário pode digitar um valor na região de edição ou selecionar um valor da lista suspensa (padrão)
· 2 - fmStyleDropDownList: A Lista de Seleção se comporta como uma caixa de listagem e o usuário deve
escolher um valor da lista
Text
Retorna o texto da opção selecionada. Esta propriedade é acessível apenas em tempo de execução.

161 Visualização
TextAlign
Especifica como o texto é alinhado no objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Centraliza o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
TextColumn
Esta propriedade identifica a coluna no objeto. Os valores para esta propriedade vão de -1 (menos um) ao número
de colunas na lista. O valor desta propriedade para a primeira coluna é 1 (um), o valor da segunda coluna é 2 (dois), e
assim por diante. A configuração desta propriedade em 0 (zero) exibe os valores para a propriedade ListIndex. A
configuração desta propriedade em -1 (menos um) exibe a primeira coluna que possui o valor da propriedade
ColumnWidths maior do que 0 (zero).
TextLength
Retorna o número de caracteres digitados no objeto. Esta propriedade é somente de leitura.
TopIndex
Esta propriedade define ou retorna o item da lista que aparece na posição mais próxima do topo na lista. Esta
propriedade retorna o valor -1 (menos um) se a lista está vazia ou não é exibida.
Value
Este é o valor da propriedade BoundColumn das linhas atualmente selecionadas. Uma mudança de valor nesta
propriedade não implica em mudança de valor na propriedade BoundColumn. Para adicionar ou apagar entradas em
uma lista de seleção, use os métodos AddItem ou RemoveItem.

4.3.2.14.13 Texto
Esta seção contém informações sobre propriedades do objeto Texto (LabelControl). Este objeto não possui eventos
nem métodos associados.

4.3.2.14.13.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Texto (LabelControl).
Accelerator
Define ou recupera a tecla aceleradora do objeto. Esta tecla aceleradora é uma tecla que, usada em conjunto com a
tecla ALT, move o foco para o objeto. O valor padrão desta propriedade é uma String vazia.
AutoSize
Esta propriedade ajusta a largura do texto, caso a área disponível ultrapasse o tamanho do objeto. Para o objeto
Texto (Label), quando a propriedade estiver configurada para Verdadeiro, o texto é redimensionado para coincidir
com o tamanho atual do objeto, permitindo assim a sua exibição completa.
BackStyle
Esta propriedade define o estilo do plano de fundo para os objetos. As opções disponíveis para esta propriedade
são as seguintes:
· 0 - fmBackStyleTransparent: Define o objeto como transparente, isto é, nenhum fundo deste objeto é desenhado
· 1 - fmBackStyleOpaque: Define o objeto como opaco, isto é, o fundo é desenhado (padrão)

NOTA
Esta propriedade não afeta a transparência de bitmaps. Deve-se usar um editor de imagens como o Paintbrush, por
exemplo, para tornar um bitmap transparente. Nem todos os objetos ActiveX suportam bitmaps transparentes.

BorderColor
Esta propriedade determina a cor da borda que é aplicada no objeto. Com esta propriedade, é possível aplicar a
cor padrão ou personalizá-la através da sua edição. Para que esta propriedade seja aplicável, é necessário que a
propriedade BorderStyle esteja configurada para 1 - fmBorderStyleSingle. O valor padrão desta propriedade é
preto (RGB(0, 0, 0)).
BorderStyle
Esta propriedade determina o estilo de borda que é aplicada ao objeto. As opções disponíveis são:
· 0 - fmBorderStyleNone: Sem borda (padrão)

Visualização 162
· 1 - fmBorderStyleSingle: Com borda simples
Caption
Define o texto que é mostrado no objeto.
Font
Esta propriedade é utilizada para determinar a fonte do objeto Texto. Esta propriedade não pode ser utilizada em
Associações e contém as subpropriedades descritas no tópico Fonte.
Picture
Esta propriedade especifica a figura (bitmap) atribuída ao objeto. Um arquivo com imagem pode ser selecionado
de duas maneiras: através da Lista de Propriedades ou via scripts, utilizando-se a função LoadPicture para especificar
o caminho e o nome do arquivo que contém a figura. Para remover a figura, clique no valor desta propriedade e
pressione a tecla DEL. A tecla BACKSPACE (tecla de espaço do teclado) não remove a figura.
PicturePosition
Esta propriedade especifica a posição da figura atribuída ao objeto em relação a sua legenda. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade PicturePosition
OPÇÃO DESCRIÇÃO
0 - fmPicturePositionLeftTop A figura aparece à esquerda da legenda. A legenda é
alinhada com a parte superior da figura

1 - fmPicturePositionLeftCenter A figura aparece à esquerda da legenda. A legenda é


centralizada relativamente à imagem

2 - fmPicturePositionLeftBottom A figura aparece à esquerda da legenda. A legenda é


alinhada com a parte inferior da figura

3 - fmPicturePositionRightTop A figura aparece à direita da legenda. A legenda é


alinhada com a parte superior da figura

4 - fmPicturePositionRightCenter A figura aparece à direita da legenda. A legenda é


centralizada relativamente à figura

5 - fmPicturePositionRightBottom A figura aparece à direita da legenda. A legenda é


alinhada com a parte inferior da figura

6 - fmPicturePositionAboveLeft A figura aparece acima da legenda. A legenda é alinhada


com a extremidade esquerda da figura

7 - fmPicturePositionAboveCenter A figura aparece acima da legenda. A legenda é


centralizada abaixo da figura (padrão)

8 - fmPicturePositionAboveRight A figura aparece acima da legenda. A legenda é alinhada


com a extremidade direita da figura

9 - fmPicturePositionBelowLeft A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade esquerda da figura

10 - fmPicturePositionBelowCenter A figura aparece abaixo da legenda. A legenda é


centralizada acima da figura

11 - fmPicturePositionBelowRight A figura aparece abaixo da legenda. A legenda é


alinhada com a extremidade direita da figura

12 - fmPicturePositionCenter A figura aparece no centro do controle. A legenda é


centralizada horizontalmente e verticalmente sobre a
figura.

SpecialEffect
Esta propriedade especifica a aparência de um objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SpecialEffect
OPÇÃO DESCRIÇÃO
0 - fmSpecialEffectFlat O objeto aparece plano e possui um destaque na borda,
uma alteração de cor ou ambos (padrão)

163 Visualização
OPÇÃO DESCRIÇÃO
1 - fmSpecialEffectRaised O objeto possui um destaque na parte superior
esquerda e uma sombra na parte inferior direita. O
objeto parece estar em relevo

2 - fmSpecialEffectSunken O objeto possui uma sombra na parte superior esquerda


e um destaque na parte inferior direita. O objeto e a sua
borda parecem estar afundados na Tela

3 - fmSpecialEffectEtched A borda parece estar esculpida ao redor da extremidade


do objeto

6 - fmSpecialEffectBump O objeto possui um ressalto na parte inferior direita e


parece plano na parte superior esquerda

TextAlign
Especifica como o texto é alinhado neste objeto. As opções disponíveis são as seguintes:
· 1 - fmTextAlignLeft: Alinha o texto com a extremidade esquerda do objeto (padrão)
· 2 - fmTextAlignCenter: Alinha o texto com o centro do objeto
· 3 - fmTextAlignRight: Alinha o texto com a extremidade direita do objeto
WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto. Para que esta propriedade funcione, a propriedade Multiline deve ser obrigatoriamente
igual a Verdadeiro.

4.3.2.15 Polígono
Esta seção contém informações sobre propriedades do objeto Polígono (DrawLine). Este objeto não possui eventos
nem métodos associados.

4.3.2.15.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Polígono (DrawLine).

4.3.2.15.1.1 Points
Retorna o objeto Coleção de Pontos dentro do Polígono. O objeto Coleção de Pontos é utilizado para inserir,
remover ou acessar os Pontos disponíveis no Polígono. Esta propriedade é somente de leitura.

4.3.2.15.1.2 PolygonFill
Esta propriedade configura o modo de preenchimento da área do Polígono. Para determinar se a área deve ser
preenchida ou não, traça-se uma linha a partir de um ponto p em direção ao infinito sem passar por vértices. Os
valores possíveis para esta propriedade são os seguintes:
· 0 - Alternate: Se a linha traçada atravessa um número ímpar de linhas, a área do Polígono é preenchida. Caso
contrário, a área do Polígono não é preenchida
· 1 - Winding: Neste modo estabelece-se um contador para determinar se a área está dentro ou fora do Polígono.
Se a linha do Polígono corta a linha traçada no sentido horário, subtrai-se 1 (um) deste contador. Se a linha do
Polígono corta a linha traçada no sentido anti-horário, soma-se 1 (um) a este contador. Se ao final o contador é
igual a 0 (zero), a área não está dentro do Polígono e não é preenchida. Se o contador é diferente de 0 (zero), a
área está dentro do Polígono e é preenchida

4.3.2.15.2 Coleção de Pontos do Polígono


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Pontos do Polígono
(DrawLinePoints). Este objeto não possui eventos associados.

4.3.2.15.2.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Pontos do Polígono (DrawLinePoints).

Visualização 164
AddPoint
AddPoint(X, Y, [lIndexAt])
Adiciona um Ponto do Polígono na Coleção de Pontos do Polígono e retorna este objeto. O objeto é criado nas
coordenadas especificadas pelos parâmetros X e Y e no índice especificado pelo parâmetro lIndexAt. Se este
parâmetro é omitido ou é igual a -1 (menos um), o Ponto do Polígono é adicionado ao final da sequência de Pontos
do Polígono. Caso contrário, o valor deste parâmetro deve ser um número entre 1 (um) e o valor da propriedade
Count.
DeletePoint
DeletePoint(lIndex)
Remove o Ponto do Polígono indicado pelo parâmetro lIndex, que é o índice do Ponto do Polígono na Coleção de
Pontos do Polígono. Só é possível remover Pontos do Polígono de uma Coleção de Pontos do Polígono com mais de
dois Pontos do Polígono.
Item
Item(Index)
Retorna um objeto Ponto do Polígono indicado pelo parâmetro Index, que é o índice do Ponto do Polígono na
Coleção de Pontos do Polígono.

4.3.2.15.2.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Pontos do Polígono (DrawLinePoints).
Count
Contém o número de Pontos do Polígono na Coleção. Esta propriedade é somente de leitura.

4.3.2.15.2.3 Ponto do Polígono


Esta seção contém informações sobre métodos e propriedades do objeto Ponto do Polígono (DrawLinePoint). Este
objeto não possui eventos associados.
Métodos
Esta seção contém informações sobre os métodos do objeto Ponto do Polígono (DrawLinePoint).
Delete
Delete()
Remove este Ponto do Polígono. Após utilizar este método, qualquer tentativa de acessar este objeto retorna um erro.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Ponto do Polígono (DrawLinePoint).
X
Indica a coordenada horizontal deste Ponto do Polígono em relação à borda esquerda da Tela, em unidades
Himetric.
Y
Indica a coordenada vertical deste Ponto do Polígono em relação à borda superior da Tela, em unidades Himetric.

4.3.2.16 Polígono de Curvas


Esta seção contém informações sobre propriedades do objeto Polígono de Curvas (DrawBezier). Este objeto não
possui eventos nem métodos associados.

4.3.2.16.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Polígono de Curvas (DrawBezier).

4.3.2.16.1.1 PolygonFill
Esta propriedade configura o modo de preenchimento da área do Polígono de Curvas. Para determinar se a área
deve ser preenchida ou não, traça-se uma linha a partir de um ponto p em direção ao infinito sem passar por vértices.
Os valores possíveis para esta propriedade são os seguintes:
· 0 - Alternate: Se a linha traçada atravessa um número ímpar de linhas, a área do Polígono de Curvas é
preenchida. Caso contrário, a área do Polígono de Curvas não é preenchida

165 Visualização
· 1 - Winding: Neste modo estabelece-se um contador para determinar se a área está dentro ou fora do Polígono
de Curvas. Se a linha do Polígono de Curvas corta a linha traçada no sentido horário, subtrai-se 1 (um) deste
contador. Se a linha do Polígono de Curvas corta a linha traçada no sentido anti-horário, soma-se 1 (um) a este
contador. Se ao final o contador é igual a 0 (zero), a área não está dentro do Polígono de Curvas e não é
preenchida. Se o contador é diferente de 0 (zero), a área está dentro do Polígono de Curvas e é preenchida

4.3.2.17 Retângulo Arredondado


Esta seção contém informações sobre propriedades do objeto Retângulo Arredondado (DrawTank). Este objeto não
possui eventos nem métodos associados.

4.3.2.17.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Retângulo Arredondado (DrawTank).

4.3.2.17.1.1 RoundAspectX
Esta propriedade define o tamanho da dimensão das laterais do Retângulo no eixo X. Sendo assim, de acordo com
o valor definido na propriedade, os cantos do Retângulo mudam a forma, desde um retângulo até uma elipse. Esta
propriedade pode variar o valor de 0,1 até 1,0. Exemplo:
Sub RetanguloArred_Click()
RoundAspectX = 0.5
End Sub

4.3.2.17.1.2 RoundAspectY
Esta propriedade define o tamanho da dimensão da altura do Retângulo no eixo Y. Sendo assim, de acordo com o
valor definido na propriedade, os cantos do Retângulo mudam a forma, desde um retângulo até uma elipse. Esta
propriedade pode variar o valor de 0,1 até 1,0. Exemplo:
Sub RetanguloArred_Click()
RoundAspectY = 0.5
End Sub

4.3.2.18 Texto, Display e SetPoint


Esta seção contém informações sobre eventos e propriedades dos objetos Texto, Display e SetPoint (DrawString).
Este objeto não possui métodos associados.

4.3.2.18.1 Eventos
Esta seção contém informações sobre os eventos dos objetos Texto, Display e SetPoint (DrawString).

4.3.2.18.1.1 Validate
Validate(Cancel, NewValue)
Ocorre após os testes de limites do SetPoint (consulte as propriedades MinLimit, MaxLimit, EnableLimits) e antes
do valor do SetPoint ser enviado para o Tag. A finalidade deste evento é permitir que o usuário cancele o envio do
valor do SetPoint para o Tag.
O parâmetro Cancel é um Booleano que indica se a operação de atribuição do valor do SetPoint ao Tag deve ser
cancelada (Cancel igual a Verdadeiro). O padrão é Falso, ou seja, o valor do SetPoint é enviado ao Tag. NewValue é o
valor que está sendo avaliado. O valor antigo pode ser acessado pela propriedade Value do SetPoint. Exemplo:
Sub Texto1_Validate(Cancel, NewValue)
' Mostra um MessageBox que pergunta ao usuário
' se ele deseja usar o novo valor digitado no SetPoint
message = "Valor atual: " & value & vbnewline & _
"Valor novo: " & NewValue & vbnewline & vbnewline & _
"Aceita o novo valor?"
If MsgBox (message, vbQuestion + vbYesNo, _
Cancel = True
End If
End Sub

4.3.2.18.2 Propriedades
Esta seção contém informações sobre as propriedades dos objetos Texto, Display e SetPoint (DrawString).

Visualização 166
4.3.2.18.2.1 EnableLimits
Indica se é executada a verificação de limites no texto. Quando esta propriedade é igual a Verdadeiro, e o usuário
inserir um valor não numérico ou inserir um valor fora dos limites definidos em MinLimit e MaxLimit, uma mensagem
de erro é mostrada (a propriedade IsSetPoint deve ser igual a Verdadeiro). Exemplo:
Sub CommandButton1_Click()
Screen.Item("Texto1").EnableLimits = _
Not(Screen.Item("Texto1").EnableLimits)
End Sub

4.3.2.18.2.2 Format
Esta propriedade especifica que tipo de formato é atribuído ao objeto. Permite mudar a forma como os dados são
apresentados sem mudar o valor que existe por trás destes dados. Esta propriedade pode ser editada manualmente
ou configurada através da janela de formatação. O uso é semelhante aos formatadores usados nas planilhas de
dados, seguindo a mesma sintaxe. A tabela a seguir contém os tipos de dados suportados.
Tipos de dados suportados pela propriedade Format
TIPO DE DADOS DESCRIÇÃO
Numérico Saída decimal, científica, hexadecimal, binária ou octal

Texto Textos em geral

Booleano Valores Booleanos

Data e Hora Calendário Gregoriano

4.3.2.18.2.3 IsSetPoint
Esta propriedade é utilizada para determinar se um objeto tem comportamento de SetPoint, ou seja, se permite a
edição da propriedade Value. A propriedade Value consiste em um Variant, que pode assumir valores de todo e
qualquer tipo. Esta propriedade é Booleana e assume o seguinte comportamento: se esta propriedade é igual a
Verdadeiro, permite a edição e, se esta propriedade é igual a Falso, não permite a edição. Este comportamento pode
ser visualizado quando o E3 Viewer está em execução. O valor padrão desta propriedade é Verdadeiro.

NOTA
Configurar esta propriedade para Falso em tempo de execução cancela a edição corrente e descarta o conteúdo
deste objeto.

4.3.2.18.2.4 KeepFormatWhenEditing
Permite que o valor do objeto seja editado com ou sem formatação. As opções disponíveis são as seguintes:
· 0 - kfNever: O valor é sempre editado sem formatação (padrão)
· 1 - kfAutomatic: Permite que o valor seja editado no valor formatado, caso o E3 detecte que o texto formatado é
passível de ser interpretado como um valor

Caso o formato seja considerado incompatível, o valor é editado sem formatação.

4.3.2.18.2.5 MaxCharacters
Esta propriedade estabelece um limite de caracteres que o usuário pode digitar, quando em modo de edição, em
um objeto Texto, Display ou SetPoint. As seguintes restrições se aplicam a esta propriedade:
· Configurar esta propriedade em 0 (zero) não limita o número de caracteres na edição destes controles, e também
configura a propriedade RemainingCharacters em 0 (zero)
· Ao colar um texto que tenha mais caracteres que o valor configurado nesta propriedade, este texto é cortado
· Ao modificar o valor desta propriedade para um valor menor que o tamanho do texto já contido no controle,
este texto é cortado
· O valor desta propriedade vale para o número de caracteres que o usuário pode digitar, sem levar em conta a
formatação do controle

167 Visualização
4.3.2.18.2.6 MaxLimit
Contém o valor máximo permitido no objeto (a propriedade EnableLimits deve ser igual a Verdadeiro). Exemplo:
Sub CommandButton3_Click()
Screen.Item("Texto1").MaxLimit = Screen.Item("Texto6").Value
End Sub

4.3.2.18.2.7 MinLimit
Contém o valor mínimo permitido no objeto (a propriedade EnableLimits deve ser igual a Verdadeiro). Exemplo:
Sub CommandButton2_Click()
Screen.Item("Texto1").MinLimit = Screen.Item("Texto5").Value
End Sub

4.3.2.18.2.8 Multiline
Esta propriedade indica se o texto tem múltiplas linhas (Verdadeiro) ou se é uma caixa de texto simples (Falso). Este
comportamento pode ser visualizado quando o E3 Viewer está em execução. O valor padrão desta propriedade é
Falso.

4.3.2.18.2.9 RemainingCharacters
Esta propriedade indica o número de caracteres que o usuário ainda pode digitar em um objeto Texto, Display ou
SetPoint, caso a propriedade MaxCharacters seja configurada para um valor maior que 0 (zero). Esta propriedade é
somente de leitura e só está disponível em tempo de execução.

4.3.2.18.2.10 SetPointDataType
Determina o tipo de valor que é enviado do SetPoint para o Tag. Os valores possíveis para esta propriedade estão
descritos na tabela a seguir.
Opções disponíveis para a propriedade SetPointDataType
OPÇÃO DESCRIÇÃO
0 - stCurrentType Mantém o tipo do valor atual no SetPoint (padrão, ver a
seguir)

1 - stChar Valor inteiro de 8 bits com sinal

2 - stByte Valor inteiro de 8 bits sem sinal

3 - stWord Valor inteiro de 16 bits sem sinal

4 - stInteger Valor inteiro de 16 bits com sinal

5 - stLong Valor inteiro de 32 bits com sinal

6 - stDWord Valor inteiro de 16 bits sem sinal

7 - stSingle Valor de ponto flutuante de 32 bits

8 - stDouble Valor de ponto flutuante de 64 bits

9 - stDateTime Valor de data e hora

10 - stString Texto

Quando o texto digitado é enviado pelo SetPoint, este primeiro tenta converter o valor para o tipo de dados
configurado (Word, String, Double, etc.). Se a conversão não é possível, ou seja, o valor digitado é inválido para o
tipo de dados selecionado, nenhum valor é enviado (por exemplo, se o usuário digitar -1 e o tipo de dados é Byte).
Já quando o valor da propriedade é igual a 0 - stCurrentType, o tipo de dados enviado pelo SetPoint é extraído do
valor anterior presente no objeto. Caso o valor anterior seja Empty ou Null, nenhuma conversão é realizada e o valor
digitado é enviado como texto. Exemplo:
Sub Combobox1_Change()
Screen.Item("Texto1").SetPointDataType = CInt(Left(Value, 2))
End Sub

Visualização 168
4.3.2.18.2.11 StretchText
Redimensiona o tamanho do objeto. A partir do momento em que esta propriedade é habilitada, o objeto
automaticamente redimensiona o tamanho da fonte do texto para que a área ocupada continue sempre a mesma. De
outra forma, se esta propriedade está configurada para Falso, nenhum redimensionamento é efetuado.

4.3.2.18.2.12 TextAlignment
Esta propriedade especifica o alinhamento horizontal do texto mostrado no objeto. Os valores possíveis para esta
propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade TextAlignment
OPÇÃO DESCRIÇÃO
0 - LeftAlignment O alinhamento horizontal do texto é à esquerda

1 - CenterAlignment O alinhamento horizontal do texto é centralizado


(padrão)

2 - RightAlignment O alinhamento horizontal do texto é à direita

4.3.2.18.2.13 TextColor
Esta propriedade especifica a cor da fonte do texto a ser exibido. Nos scripts, utilize o método RGB do VBScript
para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.3.2.18.2.14 TextFont
Define as informações da fonte a ser utilizado pelo objeto de Tela. Esta propriedade não pode ser utilizada em
Associações e as sub-propriedades podem ser consultadas no tópico Fonte.

4.3.2.18.2.15 Value
Esta propriedade consiste em um Variant que pode assumir valores de todo e qualquer tipo de dados, e que é
exibido pelo objeto. Geralmente esta propriedade contém um texto, pois é automaticamente preenchida quando
ocorre a criação de um novo objeto Texto. A propriedade IsSetPoint é utilizada para determinar se o objeto Texto
tem o mesmo comportamento de um SetPoint, ou seja, permite a edição desta propriedade. Exemplo:
Sub DrawString1_OnStartRunning()
' Lê o valor de um tag e mostra o Texto
Dim obj
Set obj = Application.GetObject("DataServer1.DemoTag1")
Value = "Valor de DemoTag1 = " & obj.Value
End Sub

4.3.2.18.2.16 VertTextAlignment
Determina o alinhamento vertical do texto do objeto. Os valores possíveis para esta propriedade estão descritos
na tabela a seguir.
Opções disponíveis para a propriedade VertTextAlignment
OPÇÃO DESCRIÇÃO
0 - TopAlignment Alinhamento vertical do texto no topo do objeto

1 - MidAlignment Alinhamento vertical do texto no centro do objeto


(padrão)

2 - BottomAlignment Alinhamento vertical do texto na base do objeto

4.3.2.18.2.17 WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto. Para que esta propriedade funcione, a propriedade Multiline deve ser obrigatoriamente
igual a Verdadeiro.

4.4 E3Alarm
Esta seção contém informações sobre eventos, métodos e propriedades do objeto E3Alarm.

169 Visualização
4.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto E3Alarm.

4.4.1.1 KeyPress
KeyPress(KeyAscii)
Ocorre quando o E3Alarm tem o foco de teclado e o usuário pressiona uma tecla correspondente a um caractere que
pode ser mostrado em tela, ou seja, uma tecla ANSI de código indicado no parâmetro KeyAscii. Este evento ocorre
quando alguma das teclas a seguir são pressionadas:
· Qualquer caractere do teclado que possa ser impresso
· Tecla CTRL combinada com qualquer caractere do alfabeto padrão
· Tecla CTRL combinada com qualquer caractere especial
· Tecla BACKSPACE
· Tecla ESC

Este evento não ocorre nas seguintes condições:


· Pressionando-se a tecla TAB
· Pressionando-se a tecla ENTER
· Pressionando-se a tecla DEL, que não é padrão ANSI)
· Pressionando-se as setas do teclado
· Quando uma tecla move o foco de um objeto a outro

Enquanto o usuário pressiona uma tecla que produz um código ANSI, o E3Alarm recebe os eventos KeyDown e
KeyPress repetidamente. Quando o usuário libera esta tecla, o evento KeyUp ocorre. Para monitorar o estado físico
do teclado ou manipular teclas não reconhecidas pelo evento KeyPress, como por exemplo teclas de função ou de
navegação, utilize os eventos KeyDown e KeyUp.

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyAscii, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.4.1.2 MouseMove
MouseMove()
Ocorre quando o ponteiro do mouse se move sobre o objeto E3Alarm.

4.4.2 Métodos
Esta seção contém informações sobre os métodos do objeto E3Alarm.

4.4.2.1 AboutBox
AboutBox()
Este método exibe uma caixa de diálogo com informações sobre versão e copyright do objeto E3Alarm.

4.4.2.2 AckAll
AckAll([Operator])
Permite reconhecer globalmente todos os alarmes. O parâmetro Operator é uma String opcional que indica o nome
do operador que reconheceu o alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é utilizado
o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário logado. Para o reconhecimento em si
é necessário que o usuário logado tenha a permissão Reconhecer alarme.

Visualização 170
4.4.2.3 AckCurrentFilter
AckCurrentFilter([Operator])
Permite reconhecer todos os alarmes do filtro corrente. O parâmetro Operator é uma String opcional que indica o
nome do operador que reconheceu o alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é
utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário logado. Para o
reconhecimento em si é necessário que o usuário logado tenha a permissão Reconhecer alarme.

4.4.2.4 AckSelected
AckSelected([Operator])
Permite reconhecer os alarmes selecionados. Se não houver alarme selecionado no E3Alarm, este método falha. O
usuário pode reconhecer o alarme, e neste caso, é inserido um novo registro no Banco de Dados indicando o
reconhecimento, e no E3Alarm a linha correspondente indica que foi reconhecido. O parâmetro Operator é uma String
opcional que indica o nome do operador que reconheceu o alarme. Este valor é mostrado na coluna Operator do
E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário
logado. Para o reconhecimento em si é necessário que o usuário logado tenha a permissão Reconhecer alarme.

4.4.2.5 DeleteUnboundAll
DeleteUnboundAll([Operator])
Permite remover globalmente todos os alarmes não vinculados. O parâmetro Operator é uma String opcional que
indica o nome do operador que removeu o alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se
omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário logado. Para a
remoção em si é necessário que o usuário logado tenha a permissão Remover alarmes desvinculados.

4.4.2.6 DeleteUnboundCurrentFilter
DeleteUnboundCurrentFilter([Operator])
Permite remover todos os alarmes não vinculados do filtro corrente. O parâmetro Operator é uma String opcional que
indica o nome do operador que removeu o alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se
omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário logado. Para a
remoção em si é necessário que o usuário logado tenha a permissão Remover alarmes desvinculados.

4.4.2.7 DeleteUnboundSelected
DeleteUnboundSelected([Operator])
Permite remover os alarmes não vinculados selecionados. Se não houver alarme não vinculado selecionado no
E3Alarm, este método falha. O usuário pode remover o alarme, e neste caso é inserido um novo registro no Banco de
Dados indicando a remoção, e no E3Alarm a linha correspondente indica que foi removido. O parâmetro Operator é
uma String opcional que indica o nome do operador que reconheceu o alarme. Este valor é mostrado na coluna
Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja nenhum
usuário logado. Para a remoção em si é necessário que o usuário logado tenha a permissão Remover alarmes
desvinculados.

4.4.2.8 GetEventByIndex
GetEventByIndex(Index)
Retorna um objeto Evento de uma Coleção de Eventos, especificado pelo parâmetro Index, que corresponde ao
índice do objeto na Coleção. Para mais informações sobre as propriedades do objeto retornado por este método,
consulte o tópico Evento - Propriedades.

4.4.2.9 GetFocusedEvent
GetFocusedEvent()
Este método retorna um objeto com as propriedades do evento selecionado (aquele que tem o foco atual) no
E3Alarm, caso haja algum evento selecionado. Se nenhum evento estiver selecionado, o método retorna um objeto
Nothing.
As propriedades do objeto retornado contém os valores dos campos do evento selecionado. O objeto contém uma
cópia dos valores no momento da chamada do método. Portanto, se houver uma mudança no evento selecionado, as
propriedades não são atualizadas automaticamente, e é necessário utilizar este método sempre que houver

171 Visualização
necessidade de obter informações atualizadas do evento selecionado. As propriedades do objeto retornado por este
método estão descritas no tópico Evento - Propriedades.

4.4.2.10 ShelveAll
ShelveAll(Duration, Reason, [Operator])
Permite arquivar globalmente todos os alarmes. O parâmetro Duration indica o período de tempo, em minutos, que
os alarmes permanecem arquivados. O parâmetro Reason indica o motivo para o arquivamento. O parâmetro
Operator é uma String opcional que indica o nome do operador que arquivou o alarme. Este valor é mostrado na
coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja
nenhum usuário logado. Para o arquivamento em si é necessário que o usuário logado tenha a permissão Arquivar
alarmes.

4.4.2.11 ShelveCurrentFilter
ShelveCurrentFilter(Duration, Reason, [Operator])
Permite arquivar todos os alarmes do filtro corrente. O parâmetro Duration indica o período de tempo, em minutos,
que os alarmes permanecem arquivados. O parâmetro Reason indica o motivo para o arquivamento. O parâmetro
Operator é uma String opcional que indica o nome do operador que arquivou o alarme. Este valor é mostrado na
coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem usuário)", caso não haja
nenhum usuário logado. Para o arquivamento em si é necessário que o usuário logado tenha a permissão Arquivar
alarmes.

4.4.2.12 ShelveSelected
ShelveSelected(Duration, Reason, [Operator])
Permite arquivar os alarmes selecionados. Se não houver alarme selecionado no E3Alarm, este método falha. O
usuário pode arquivar o alarme, e neste caso é inserido um novo registro no Banco de Dados indicando o
arquivamento, e no E3Alarm a linha correspondente indica que foi arquivado. O parâmetro Duration indica o período
de tempo, em minutos, que os alarmes permanecem arquivados. O parâmetro Reason indica o motivo para o
arquivamento. O parâmetro Operator é uma String opcional que indica o nome do operador que arquivou o alarme.
Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer ou "(Sem
usuário)", caso não haja nenhum usuário logado. Para o arquivamento em si é necessário que o usuário logado tenha
a permissão Arquivar alarmes.

4.4.2.13 UnshelveAll
UnshelveAll(Reason, [Operator])
Permite desarquivar globalmente todos os alarmes arquivados. O parâmetro Reason indica o motivo para o
desarquivamento. O parâmetro Operator é uma String opcional que indica o nome do operador que desarquivou o
alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer
ou "(Sem usuário)", caso não haja nenhum usuário logado. Para o desarquivamento em si é necessário que o usuário
logado tenha a permissão Desarquivar alarmes.

4.4.2.14 UnshelveCurrentFilter
UnshelveCurrentFilter(Reason, [Operator])
Permite desarquivar todos os alarmes do filtro corrente. O parâmetro Reason indica o motivo para o
desarquivamento. O parâmetro Operator é uma String opcional que indica o nome do operador que desarquivou o
alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual do E3 Viewer
ou "(Sem usuário)", caso não haja nenhum usuário logado. Para o desarquivamento em si é necessário que o usuário
logado tenha a permissão Desarquivar alarmes.

4.4.2.15 UnshelveSelected
UnshelveSelected(Reason, [Operator])
Permite desarquivar os alarmes selecionados. Se não houver alarmes selecionados no E3Alarm, este método falha. O
usuário pode desarquivar o alarme, e neste caso é inserido um novo registro no Banco de Dados indicando o
desarquivamento, e no E3Alarm a linha correspondente indica que foi desarquivado. O parâmetro Reason indica o
motivo para o desarquivamento. O parâmetro Operator é uma String opcional que indica o nome do operador que
desarquivou o alarme. Este valor é mostrado na coluna Operator do E3Alarm. Se omitido, é utilizado o usuário atual

Visualização 172
do E3 Viewer ou "(Sem usuário)", caso não haja nenhum usuário logado. Para o desarquivamento em si é necessário
que o usuário logado tenha a permissão Desarquivar alarmes.

4.4.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto E3Alarm.

NOTA
O E3 utiliza, para definição de coordenadas e espessura, o sistema Himetric. Neste sistema, cada unidade lógica
equivale a um milésimo de centímetro, ou seja, cada 1000 unidades equivalem a um centímetro. Assim, este é o
padrão adotado na descrição das propriedades do E3, quando aplicável.

4.4.3.1 ActiveAlarms
Determina o número total de alarmes ativos em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.2 ActiveCritAlarms
Indica o número de alarmes ativos com severidade Crítica em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.3 ActiveCritNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Crítica em um E3Alarm. Esta propriedade é somente
de leitura.

4.4.3.4 ActiveHighAlarms
Indica o número de alarmes ativos com severidade Alta em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.5 ActiveHighNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Alta em um E3Alarm. Esta propriedade é somente de
leitura.

4.4.3.6 ActiveLowAlarms
Indica o número de alarmes ativos com severidade Baixa em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.7 ActiveLowNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Baixa em um E3Alarm. Esta propriedade é somente
de leitura.

4.4.3.8 ActiveMedAlarms
Indica o número de alarmes ativos com severidade Média em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.9 ActiveMedNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Média em um E3Alarm. Esta propriedade é somente
de leitura.

4.4.3.10 ActiveNACKAlarms
Indica o número total de alarmes que estão sem reconhecimento em um E3Alarm, ativos ou não. Esta propriedade é
somente de leitura.

4.4.3.11 AlarmCount
Determina o número de alarmes em um E3Alarm. Esta propriedade é somente de leitura.

4.4.3.12 AlarmServer
Nome do Servidor de Alarmes único existente em uma aplicação.

173 Visualização
4.4.3.13 AllowAckAll
Habilita ou desabilita a opção Reconhecimento no menu contextual de um E3Alarm, que permite o reconhecimento
de todos os alarmes. O valor padrão desta propriedade é Verdadeiro.

4.4.3.14 AllowAckCurrentFilter
Habilita ou desabilita o item Todos os alarmes do filtro corrente da opção Reconhecimento no menu contextual
de um E3Alarm, que permite o reconhecimento de todos os alarmes do filtro atual. Se não houver alarmes visíveis,
esta propriedade não tem efeito. O valor padrão desta propriedade é Verdadeiro.

4.4.3.15 AllowAckSelected
Habilita ou desabilita o item Apenas os alarmes selecionados da opção Reconhecimento no menu contextual de
um E3Alarm, que permite o reconhecimento de alarmes selecionados. Se não houver alarmes selecionados, esta
propriedade não tem efeito. O valor padrão desta propriedade é Verdadeiro.

4.4.3.16 AllowColumnClick
Habilita ou desabilita a seleção dos campos e a direção de ordenação destes, através do clique no cabeçalho das
colunas de um E3Alarm em tempo de execução. Se esta opção estiver configurada para Verdadeiro e o cabeçalho
estiver visível (consulte a propriedade ColumnHeader), ao clicar no título da coluna os dados são ordenados, tendo
esta coluna como chave. Clicando novamente nesta mesma coluna, a ordenação é realizada na direção contrária, ou
seja, muda-se a ordem ascendente para descendente e vice-versa. Ao clicar na coluna com a tecla SHIFT pressionada,
o campo é usado como segunda chave. Como na chave primária, um segundo clique com SHIFT inverte a ordenação
do campo secundário.

4.4.3.17 AllowDeleteUnboundAlarms
Habilita ou desabilita a opção Deletar alarmes desvinculados no menu contextual de um E3Alarm, que permite
remover alarmes não vinculados. Se não houver alarmes não vinculados, esta propriedade não tem efeito. O valor
padrão desta propriedade é Verdadeiro.

4.4.3.18 AllowShelveAlarms
Habilita ou desabilita as opções Arquivar Alarmes e Desarquivar Alarmes no menu contextual de um E3Alarm, que
permitem o arquivamento ou desarquivamento de todos os alarmes. O valor padrão desta propriedade é Verdadeiro.

4.4.3.19 AreaFilter
Controla as Áreas de alarmes visíveis em um E3Alarm. Se o valor não é uma String vazia, são apresentados eventos
cujo nome das Áreas comecem com o texto indicado. Por exemplo, se AreaFilter é igual a "Ana", são mostrados os
alarmes de Áreas como "Analogicos.Producao" ou "Analise", mas não "Digitais.Analise" ou "Digitais.Producao". Quando
a propriedade SimpleAreaFilter está configurada como Falso, a Área de Alarme também permite o uso de caracteres
curingas para a filtragem e múltiplos filtros de Área, separados por dois pontos. Consulte a propriedade AreaFilter
do objeto Filtro de Alarme para informações sobre os caracteres curinga permitidos.
O valor padrão desta propriedade é uma String vazia, ou seja, sem filtragem por Área. Consulte também as
propriedades CustomFilter, SimpleAreaFilter, ShowCriticalPriority, ShowHighPriority, ShowMediumPriority e
ShowLowPriority.

NOTA
A propriedade AreaFilter corresponde à propriedade Filter, disponível até a versão 4.0 do E3.

4.4.3.20 BannerMode
Habilita a visualização de apenas uma mensagem em um E3Alarm. A mensagem mostrada depende da configuração
de ordenação e sempre está selecionada. O valor padrão desta propriedade é Falso. Para mais informações sobre a
configuração de ordenação, consulte o tópico Aba Ordenação no Manual do Usuário do E3.

4.4.3.21 BorderColor
Define a cor da borda de um E3Alarm. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

Visualização 174
4.4.3.22 BorderThickness
Define a espessura da borda de um E3Alarm. O valor desta propriedade pode variar entre 0 (zero, que desabilita a
borda) e 10, e seu padrão é 1 (um).

4.4.3.23 ColorAckedAlarm
Define um objeto que configura as cores de um alarme reconhecido. Esta propriedade é indexada pela severidade
do alarme e só está disponível via script. Para mais informações sobre o comportamento desta propriedade, consulte
a propriedade ColorActiveAlarm.

4.4.3.24 ColorActiveAlarm
Define um objeto que configura as cores de um alarme ativo. Esta propriedade é indexada pela severidade do
alarme e só está disponível via script. A tabela a seguir contém os valores possíveis para o índice desta propriedade.
Opções disponíveis para o índice da propriedade ColorActiveAlarm
ÍNDICE SEVERIDADE OBJETO RETORNADO
-2 Crítica Define as cores para alarmes ativos
com severidade crítica

-1 - Define as cores para alarmes ativos,


independente da severidade

0 Alta Define as cores para alarmes ativos


com severidade alta

1 Média Define as cores para alarmes ativos


com severidade média

2 Baixa Define as cores para alarmes ativos


com severidade baixa

Exemplo de uso desta propriedade:


' Retorna um objeto para configurar as cores dos alarmes ativos com severidade alta
Set Objeto = Screen.Item("E3Alarm1").ColorActiveAlarm(0)
' Copia as configurações de alarme ativo com severidade alta (0)
' para o alarme ativo com severidade média (1)
Screen.Item("E3Alarm1").ColorActiveAlarm(1) = Screen.Item("E3Alarm1").ColorActiveAlarm(0)

O objeto retornado por esta propriedade representa um alarme ativo em uma severidade específica, ou seja, crítica,
alta, média, baixa ou a configuração padrão deste tipo de alarme. A partir deste objeto é possível configurar a cor de
fundo, a cor de texto e o modo de pisca do alarme, que também estão disponíveis para configuração através da
Janela de Propriedades do objeto E3Alarm, na aba Cores. Para mais informações sobre o objeto retornado por esta
propriedade, consulte o tópico Cor do Alarme.

4.4.3.25 ColorActiveEvent
Define um objeto que configura as cores de um evento ativo. Esta propriedade é indexada pela severidade do
alarme e só está disponível via script. Para mais informações sobre o comportamento desta propriedade, consulte a
propriedade ColorActiveAlarm.

4.4.3.26 ColorNAckAlarm
Define um objeto que configura as cores de um alarme não reconhecido. Esta propriedade é indexada pela
severidade do alarme e só está disponível via script. Para mais informações sobre o comportamento desta
propriedade, consulte a propriedade ColorActiveAlarm.

4.4.3.27 ColumnHeader
Esta propriedade habilita ou não a visualização do cabeçalho de um E3Alarm. O cabeçalho também permite que
seja realizada a reordenação dos dados da tabela visualmente (consulte a propriedade AllowColumnClick). O valor
padrão desta propriedade é Verdadeiro.

175 Visualização
4.4.3.28 Connections
Retorna uma coleção de Conexões em um E3Alarm. Esta propriedade é somente de leitura. Para mais informações
sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Conexões.

4.4.3.29 ConnectionStatusBarColor
Especifica a cor da barra de status de conexões de um E3Alarm. O valor padrão desta propriedade é preto (RGB(0,
0, 0)).

4.4.3.30 CustomFilter
Permite informar um filtro personalizado para os alarmes, na forma de uma expressão. Consulte a propriedade
CustomFilter do objeto Filtro de Alarmes para informações sobre os campos disponíveis para utilização na expressão
deste filtro. Os campos definidos pelo usuário também podem ser utilizados na expressão do filtro, utilizando-se o
nome definido no Servidor de Alarmes.
Ao todo, as mensagens que aparecem na listagem do E3Alarm sempre passam pelos seguintes filtros:
· Filtro por tipo, definido na propriedade FilterType
· Filtro por severidade, definida nas propriedades ShowCriticalProperty, ShowLowPriority, ShowMediumPriority
e ShowHighPriority
· Filtro por área, definida nas propriedades AreaFilter e SimpleAreaFilter
· Filtro pela propriedade CustomFilter
· Filtro do sumário de alarmes, equivalente à expressão "Enabled AND (ConditionActive OR (AckRequired AND NOT
Acked))"

Exemplos de Utilização da Propriedade CustomFilter


Para um campo de usuário chamado IsSupressed, e que se queira mostrar apenas alarmes em que este campo tem
valor diferente de zero, a expressão a ser utilizada é a seguinte:
IsSupressed <> 0

Para mostrar apenas mensagens com a subcondição "HIHI" ou "LOLO" de objetos de alarme cujo nome inicie por
"Pressure", a expressão a ser utilizada é a seguinte:
(SubConditionName = "HIHI" OR SubConditionName = "LOLO")
AND (Mid(AlarmSourceName, 1, 8) = "Pressure")

4.4.3.31 Domain
Especifica o Domínio ao qual um E3Alarm se conecta, como por exemplo "\\NomedeOutroServidor". O padrão
desta propriedade é uma String vazia, ou seja, o E3Alarm se conecta ao mesmo Domínio do E3 Viewer onde se
encontra.

4.4.3.32 EnableSortMarker
Habilita ou desabilita uma indicação de ordenação de uma coluna de um E3Alarm. Somente a primeira coluna
utilizada na ordenação mostra esta indicação. Para aplicações criadas na versão 4.8 ou mais recentes, o valor padrão
desta propriedade é Verdadeiro. Para aplicações criadas em versões anteriores e atualizadas para a versão 4.8 ou
superiores, o valor padrão desta propriedade é Falso.

Indicação de ordenação pela coluna Mensagem em ordem descendente

Visualização 176
4.4.3.33 Events
Retorna uma coleção de Eventos em um E3Alarm. Esta propriedade é somente de leitura. Para mais informações
sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Eventos.

4.4.3.34 Fields
Retorna uma coleção de Campos em um E3Alarm. Esta propriedade é somente de leitura. Para mais informações
sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Campos.

4.4.3.35 Filters
Retorna uma coleção de Filtros em um E3Alarm. Esta propriedade é somente de leitura. Para mais informações
sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Filtros.

4.4.3.36 FilterType
Efetua os filtros de alarme. As opções disponíveis são 1 - OnlyAlarms: Mostra apenas alarmes (padrão), 2 -
OnlyEvents: Mostra apenas eventos ou 3 - AlarmsAndEvents: Mostra tanto alarmes quanto eventos.

4.4.3.37 Font
Determina a fonte (tipo de letra) do cabeçalho e das linhas de um E3Alarm. Esta propriedade é somente de leitura e
só pode ser modificada via E3 Studio, não em tempo de execução. Consulte o tópico Fonte para mais informações
sobre as subpropriedades desta propriedade.

4.4.3.38 FourthSortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo quaternário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

4.4.3.39 FourthSortField
Determina o campo quaternário para a ordenação dos eventos em um E3Alarm. O nome do campo deve ser
sempre especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é uma String vazia. Esta propriedade não tem efeito quando as propriedades PrimarySortField,
SecondarySortField ou ThirdSortField são configuradas como uma String vazia.

4.4.3.40 GridBkColor
Esta propriedade determina a cor de fundo de um E3Alarm. O valor padrão desta propriedade é a cor configurada
no Windows para o item Janela, em Painel de Controle - Vídeo - Aparência - Avançada.

4.4.3.41 InactiveCritNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Crítica em um E3Alarm. Esta propriedade é
somente de leitura.

4.4.3.42 InactiveHighNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Alta em um E3Alarm. Esta propriedade é
somente de leitura.

4.4.3.43 InactiveLowNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Baixa em um E3Alarm. Esta propriedade é
somente de leitura.

4.4.3.44 InactiveMedNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Média em um E3Alarm. Esta propriedade é
somente de leitura.

4.4.3.45 InactiveNACKAlarms
Determina o número total de alarmes inativos e não reconhecidos em um E3Alarm. Esta propriedade é somente de
leitura.

177 Visualização
4.4.3.46 PictureConnected
Caminho de um arquivo de imagem com o ícone para representar uma Conexão da Coleção de Conexões de um
E3Alarm conectada com sucesso a um Servidor de Alarmes. O valor padrão desta propriedade é uma String vazia, ou
seja, o E3Alarm apresenta o ícone na barra de status para esta Conexão.

4.4.3.47 PictureNotConnected
Caminho de um arquivo de imagem com o ícone para representar uma Conexão da Coleção de Conexões de um
E3Alarm não conectada a um Servidor de Alarmes. O valor padrão desta propriedade é uma String vazia, ou seja, o
E3Alarm apresenta o ícone na barra de status para esta Conexão.

4.4.3.48 PictureUnknown
Caminho de um arquivo de imagem com o ícone para representar uma Conexão da Coleção de Conexões de um
E3Alarm com o status indefinido. O valor padrão desta propriedade é uma String vazia, ou seja, o E3Alarm apresenta
o ícone na barra de status para esta Conexão.

NOTA
O status indefinido indica que um E3Alarm não recebeu uma confirmação do Servidor de Alarmes de que a conexão
teve sucesso. Este é o status padrão para versões anteriores à 4.7.

4.4.3.49 PopupMenu
Habilita um menu contextual ao clicar com o botão direito do mouse em um E3Alarm. O valor padrão desta
propriedade é Verdadeiro.

4.4.3.50 PrimarySortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo primário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

4.4.3.51 PrimarySortField
Determina o campo primário para a ordenação dos eventos em um E3Alarm. O nome do campo deve ser sempre
especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é "EventTime". Quando esta propriedade é uma String vazia, as propriedades SecondarySortField,
ThirdSortField e FourthSortField não têm efeito.

4.4.3.52 SecondarySortAscending
Quando esta propriedade estiver configurada para Verdadeiro, a ordenação de eventos pelo campo secundário é
no sentido ascendente. Caso contrário, o sentido é descendente. O valor padrão desta propriedade é Falso.

4.4.3.53 SecondarySortField
Determina o campo secundário para a ordenação dos eventos em um E3Alarm. O nome do campo deve ser sempre
especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é uma String vazia. Esta propriedade não tem efeito quando a propriedade PrimarySortField for
configurada como uma String vazia.

4.4.3.54 ShowConnectionStatusBar
Mostra ou esconde a barra de status de conexões de um E3Alarm. O valor padrão desta propriedade é Falso.

4.4.3.55 ShowCriticalPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Crítica. O valor padrão
desta propriedade é Verdadeiro.

4.4.3.56 ShowHighPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Alta. O valor padrão
desta propriedade é Verdadeiro.

Visualização 178
4.4.3.57 ShowIcon
Permite mostrar ou esconder o ícone na primeira coluna dos eventos. O valor padrão desta propriedade é
Verdadeiro.

4.4.3.58 ShowLowPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Baixa. O valor padrão
desta propriedade é Verdadeiro.

4.4.3.59 ShowMediumPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Média. O valor padrão
desta propriedade é Verdadeiro.

4.4.3.60 SimpleAreaFilter
Quando esta propriedade é igual a Verdadeiro, o comportamento de filtragem pelo nome de Área de Alarmes é
baseado apenas na coincidência da parte inicial do nome. Quando é igual a Falso, o comportamento leva em conta
todo o nome da Área, mas permite o uso de caracteres curinga e múltiplos filtros de área, que devem ser separados
por dois pontos. Consulte também a propriedade AreaFilter, que especifica o filtro por nome de área.

4.4.3.61 ThirdSortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo terciário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

4.4.3.62 ThirdSortField
Determina o campo terciário para a ordenação dos eventos em um E3Alarm. O nome do campo deve ser sempre
especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é uma String vazia. Esta propriedade não tem efeito quando as propriedades PrimarySortField ou
SecondarySortField são configuradas como uma String vazia.

4.4.4 Coleção de Campos


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Campos (AlarmFieldCollection).
Este objeto não possui eventos associados.

NOTA
A Coleção de Campos pode ser acessada através da propriedade Fields do objeto E3Alarm.

4.4.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Campos (AlarmFieldCollection).

4.4.4.1.1 Item
Item(Index)
Retorna um objeto Campo da Coleção de Campos, especificado pelo parâmetro Index. Este parâmetro pode ser
numérico, se corresponder ao índice do objeto na Coleção, ou textual, se corresponder ao nome do Campo indicado
na propriedade Name.

4.4.4.1.2 MoveAlarmField
MoveAlarmField(Index, NewPosition)
Muda a ordem de um Campo de Alarme na Coleção de Campos em tempo de execução. O parâmetro Index indica o
nome, que corresponde à propriedade Name, ou o índice, que corresponde à propriedade Index, do Campo cuja
ordem deve ser modificada. O parâmetro NewPosition indica a nova posição do Campo na Coleção de Campos.

4.4.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Campos (AlarmFieldCollection).

179 Visualização
4.4.4.2.1 Count
Contém o número de Campos na Coleção de Campos. Esta propriedade é somente de leitura.

4.4.4.3 Campo
Esta seção contém informações sobre as propriedades do objeto Campo da Coleção de Campos (AlarmField). Este
objeto não possui eventos nem métodos associados.

4.4.4.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo da Coleção de Campos (AlarmField).

4.4.4.3.1.1 AckOnClick
Habilita ou desabilita o reconhecimento do alarme correspondente à coluna deste Campo em um E3Alarm. Os
valores possíveis para esta propriedade são 0: Não reconhece o alarme (padrão), 1: Reconhece o alarme com um
clique simples ou 2: Reconhece o alarme com um duplo clique.

4.4.4.3.1.2 AllowBlink
Habilita ou desabilita um efeito de pisca na coluna deste Campo em um E3Alarm. O valor padrão desta propriedade
é desabilitada.

4.4.4.3.1.3 FieldId
Identificador único da coluna deste Campo em um E3Alarm. Os valores possíveis desta propriedade estão
descritos na tabela a seguir.
Valores possíveis para a propriedade FieldId
VALOR DESCRIÇÃO
1 Precisa Ack (Need Ack)

2 Reconhecido (Acked)

3 Operador (Operator)

4 Máscara (Mask)

5 Nome da Condição (Condition Name)

6 Condição Ativa (Active Condition)

7 Cookie

8 Habilitado (Enabled)

9 Categoria (Category)

10 Tipo (Type)

11 Mensagem (Message)

12 Qualidade (Quality)

13 Severidade (Severity)

14 Fonte (Source)

15 Nome da SubCondição (SubCondition Name)

16 DataHora (DateTime)

17 DataHoraUTC (DateTimeUTC)

18 Valor (Value)

19 Área (Area)

20 Nome da Fonte (Source name)

21 DataHora (Entrada) (DateTime (in))

Visualização 180
VALOR DESCRIÇÃO
22 DataHora (Saída) (DateTime (out))

23 DataHora (Reconhecido) (DateTime (ack))

24 Nome da Fonte (Completo) (Source name (full))

25 Valor formatado (Formatted value)

26 Fonte da Medida (Measurement Source)

27 Domínio de Origem (Source Domain)

28 Desvinculado (Unbound)

29 Removido (Deleted)

30 Permite Arquivar (Allow Shelving)

31 Arquivado (Shelved)

32 Arquivado (Entrada) (Shelved (In))

33 Arquivado (Saída) (Shelved (Out))

34 Arquivado (Duração [h]:mm) (Shelved (Duration [h]:mm))

35 Arquivado (Limite Duração [h]:mm) (Shelved (Max Duration


[h]:mm))

36 Número Arquivamentos (Shelve Count)

37 Limite Arquivamentos (Maximum Shelve Count)

38 Arquivado (Motivo) (Shelved (Reason))

39 Arquivado (Operador) (Shelved (Operator))

40 E3TimeStamp

4.4.4.3.1.4 Format
Formato aplicado na coluna deste Campo para visualização em um E3Alarm. O valor padrão desta propriedade é
uma String vazia, ou seja, sem formatação.

4.4.4.3.1.5 Index
Índice deste Campo na Coleção de Campos. Esta propriedade é somente de leitura.

4.4.4.3.1.6 Name
Nome que identifica este Campo. Consulte a propriedade geral Name para mais informações sobre os caracteres
permitidos no nome deste objeto.

4.4.4.3.1.7 UseFormat
Habilita ou desabilita o uso do formato especificado na propriedade Format à coluna deste Campo em um
E3Alarm. O valor padrão desta propriedade é desabilitada.

4.4.4.3.1.8 Visible
Habilita ou desabilita a visibilidade deste Campo no E3Alarm. O valor padrão desta propriedade é Verdadeiro.

4.4.4.3.1.9 Width
Indica a largura da coluna deste Campo, em pixels, em um E3Alarm. O valor padrão desta propriedade é 80 pixels.

4.4.5 Coleção de Conexões


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Conexões
(AlarmConnectionCollection). Este objeto não possui eventos associados.

181 Visualização
NOTA
A Coleção de Conexões pode ser acessada através da propriedade Connections dos objetos Filtro de Alarmes e
E3Alarm.

4.4.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Conexões (AlarmConnectionCollection).

4.4.5.1.1 Add
Add(ConnectionName)
Adiciona uma nova Conexão com o nome informado no parâmetro ConnectionName e retorna a Conexão criada. Caso
o usuário tente criar uma Conexão com um nome já existente, uma mensagem de erro é mostrada. Para gerar um
nome automaticamente, deixe o parâmetro ConnectionName em branco. Consulte a propriedade geral Name para
mais informações sobre os caracteres permitidos nos nomes de objetos.

4.4.5.1.2 Item
Item(Index)
Retorna um objeto Conexão da Coleção de Conexões, especificado pelo parâmetro Index. Este parâmetro pode ser
numérico, se corresponder ao índice do objeto na Coleção, ou textual, se corresponder ao nome da Conexão
(propriedade ConnectionName do objeto Conexão).

4.4.5.1.3 Remove
Remove(Index)
Remove um objeto Conexão da Coleção de Conexões através de seu nome ou índice, especificado pelo parâmetro
Index. A Conexão de índice 0 (zero) não pode ser removida. Caso o usuário tente removê-la, uma mensagem de erro é
mostrada.

4.4.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Conexões (AlarmConnectionCollection).

4.4.5.2.1 Count
Contém o número de Conexões na Coleção de Conexões. Esta propriedade é somente de leitura.

4.4.5.3 Conexão
Esta seção contém informações sobre as propriedades do objeto Conexão da Coleção de Conexões
(AlarmConnection). Este objeto não possui eventos nem métodos associados.

4.4.5.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Conexão da Coleção de Conexões
(AlarmConnection).

4.4.5.3.1.1 AlarmServer
Nome do Servidor de Alarmes, que pode estar tanto em um Domínio local quanto em um Domínio remoto.

4.4.5.3.1.2 ConnectionName
Nome que identifica esta Conexão. Consulte a propriedade geral Name para mais informações sobre os caracteres
permitidos no nome deste objeto.

4.4.5.3.1.3 ConnectionStatus
Status atual da Conexão. Esta propriedade é somente de leitura. Os valores possíveis para esta propriedade são
os seguintes:
· 0 - Não conectado: Não está conectada ao Servidor de Alarmes selecionado (padrão)
· 1 - Conectado: Está conectada ao Servidor de Alarmes selecionado

Visualização 182
· 2 - Filtro não configurado: O filtro da Conexão (propriedade FilterConnection) não está configurado
corretamente
· 3 - Servidor de Alarmes não configurado: O Servidor de Alarmes (propriedade AlarmServer) não está
configurado
· 4 - Erro inesperado: Houve um erro inesperado na Conexão
· 5 - Status não identificado: Não foi possível receber uma confirmação da conexão com o Servidor de Alarmes.
Possivelmente o Servidor de Alarmes está em um Domínio remoto com uma versão do E3 anterior à 4.7

4.4.5.3.1.4 DomainName
Nome amigável para identificar o Domínio onde está o Servidor de Alarmes selecionado. Este nome é mostrado na
coluna Domínio de Origem do E3Alarm.

4.4.5.3.1.5 FilterConnection
Nome do objeto Filtro que contém a configuração do filtro de alarmes, presente na Coleção de Filtros.

4.4.6 Coleção de Eventos


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Eventos (EventStatusCollection).
Este objeto não possui eventos associados.

NOTA
A Coleção de Eventos pode ser acessada através da propriedade Events dos objetos Filtro de Alarmes e E3Alarm.

4.4.6.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Eventos (EventStatusCollection).

4.4.6.1.1 Item
Item(Index)
Retorna um objeto Evento da Coleção de Eventos, especificado pelo parâmetro Index. Este parâmetro pode ser
numérico, se corresponder ao índice do objeto na Coleção, ou textual, se corresponder ao nome da Fonte de Alarme
(propriedade AlarmSourceName do objeto Evento).

4.4.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Eventos (EventStatusCollection).

4.4.6.2.1 Count
Contém o número de Eventos na Coleção de Eventos. Esta propriedade é somente de leitura.

4.4.6.3 Evento
Esta seção contém informações sobre as propriedades do objeto Evento da Coleção de Eventos (EventStatus). Este
objeto não possui eventos nem métodos associados.

4.4.6.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Evento da Coleção de Eventos (EventStatus).

4.4.6.3.1.1 Acked
Informa se este Evento foi reconhecido (Verdadeiro) ou não (Falso). Esta propriedade é somente de leitura.

4.4.6.3.1.2 AckRequired
Determina o reconhecimento automático (Falso) ou manual (Verdadeiro) deste Evento. Esta propriedade é somente
de leitura.

183 Visualização
4.4.6.3.1.3 AckTime
Registra a data e hora do E3 no momento em que este Alarme é reconhecido, ou zero (30/12/1899) enquanto este
evento não é reconhecido. No caso de Eventos que não pedem reconhecimento, esta propriedade assume a data e
hora do E3 no momento em que este Evento é ativado. Esta propriedade é somente de leitura.

4.4.6.3.1.4 ActiveSource
Fonte de Medida ativa da Fonte de Alarme no momento deste Evento. Esta propriedade é somente de leitura.

4.4.6.3.1.5 ActorID
Nome do operador que reconheceu este Evento. Esta propriedade é somente de leitura e seu valor pode ser:
· O usuário logado no E3 Viewer, quando o reconhecimento é realizado no E3Alarm, ou "Sem usuário" se não há
usuário logado
· "System", quando o reconhecimento é automático, ou seja, para Eventos que pedem reconhecimento
· Um nome passado por script, como por exemplo ao usar os métodos AckAllAlarms, AckArea ou o método Ack
da Fonte de Alarmes

4.4.6.3.1.6 AlarmSourceName
Contém o nome da Fonte de Alarme. Esta propriedade é somente de leitura.

4.4.6.3.1.7 AllowShelving
Indica se este Evento pode ou não ser arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.8 Area
Para Eventos de Alarmes, é o nome da Área a qual a Fonte de Alarmes pertence. Esta propriedade é somente de
leitura.

4.4.6.3.1.9 ConditionActive
Indica se a Fonte de Alarmes está em Alarme (Verdadeiro) ou não (Falso). Esta propriedade é somente de leitura.

4.4.6.3.1.10 ConditionName
Nome da condição, se este é um Evento de Alarme. Os valores possíveis para esta propriedade são:
· Banda Morta: Fonte de Alarme do tipo Banda Morta
· Digital: Fonte de Alarme do tipo Digital
· Discreto: Fonte de Alarme do tipo Discreto
· Nível: Fonte de Alarme do tipo Analógico
· TaxaDeVariação: Fonte de Alarme do tipo Taxa de Variação

Se este Evento não é um Alarme, esta propriedade é sempre uma String vazia. Esta propriedade é somente de leitura.

4.4.6.3.1.11 CurrentValue
Determina o valor da Fonte de Alarme, convertido para Double, no momento deste Evento. Para outros Eventos, o
valor desta propriedade é sempre 0 (zero). Esta propriedade é somente de leitura.

4.4.6.3.1.12 Deleted
Indica se este Evento foi removido. Esta propriedade é somente de leitura.

4.4.6.3.1.13 DomainName
Retorna o nome de Domínio da Conexão deste Evento. Este nome corresponde à coluna Domínio da lista de
Conexões disponível na aba Conexões do E3Alarm. Esta propriedade é somente de leitura.

4.4.6.3.1.14 E3TimeStamp
Data e hora em que este Evento ocorreu. Esta propriedade é somente de leitura.

Visualização 184
4.4.6.3.1.15 Enabled
Determina se a verificação deste Alarme está habilitada (Verdadeiro) ou não (Falso). Esta propriedade é somente de
leitura.

4.4.6.3.1.16 EventCategory
Categoria deste Evento. Para Alarmes, os valores possíveis para esta propriedade são:
· Banda Morta: Fonte de Alarme do tipo Banda Morta
· Digital: Fonte de Alarme do tipo Digital
· Discreto: Fonte de Alarme do tipo Discreto
· Nível: Fonte de Alarme do tipo Analógico
· TaxaDeVariação: Fonte de Alarme do tipo Taxa de Variação

Esta propriedade é somente de leitura.

4.4.6.3.1.17 EventCLSID
Identificador único para toda a vida deste Evento. Quando um Evento novo ocorre em uma Fonte, é gerado um
novo número de EventCLSID. Assim, este Evento mantém este mesmo CLSID no banco de dados, enquanto não sair da
lista de Eventos ativos e não reconhecidos. Esta propriedade é somente de leitura.

4.4.6.3.1.18 EventTime
Data e hora do valor da Fonte de Alarme no momento deste Evento. Esta propriedade é somente de leitura.

4.4.6.3.1.19 EventTimeUTC
Data e hora do valor da Fonte de Alarme no momento deste Evento, com relação ao horário de Greenwich. O valor
é o mesmo da propriedade EventTime, sendo mantido no E3 por questões de compatibilidade. Esta propriedade é
somente de leitura.

4.4.6.3.1.20 EventType
Tipo deste Evento. Para Eventos de Alarme, é sempre "Condition". Esta propriedade é somente de leitura.

4.4.6.3.1.21 FormattedValue
Mostra o valor formatado da Fonte de Alarme que vai para este Evento. Esta propriedade é somente de leitura.

4.4.6.3.1.22 FullAlarmSourceName
Registra o caminho completo da Fonte de Alarme, incluindo Áreas, nome da Configuração de Alarmes e de
possíveis Pastas onde esta possa estar inserida, como por exemplo "Pasta1.ConfigAlarmes1.Area1.FonteAlarme1". Esta
propriedade é somente de leitura.

4.4.6.3.1.23 InTime
Registra a data e hora do valor no momento em que entra na condição de Alarme. Esta propriedade é somente de
leitura.

4.4.6.3.1.24 Message
É o texto configurado na Fonte de Alarme. Esta propriedade é somente de leitura.

4.4.6.3.1.25 OutTime
Registra a data e hora do valor no momento em que sai da condição de Alarme, ou zero (30/12/1899) enquanto o
Alarme ainda não tenha saído da condição ativa. Esta propriedade é somente de leitura.

4.4.6.3.1.26 Quality
Qualidade do valor da Fonte de Alarme no momento deste Evento. Esta propriedade é somente de leitura e os
valores possíveis são:
· 0 - 63: Qualidade ruim

185 Visualização
· 64 - 127: Qualidade incerta
· 128 - 191: Valor indefinido
· 192 - 255: Qualidade boa

Se este Evento não é um Alarme, esta propriedade é igual a uma String vazia. Exemplos de conteúdo desta
propriedade são "Ruim (0)", "Incerta (64)", "?? (128)" e "Boa (192)".

4.4.6.3.1.27 Severity
Valor de severidade configurado na Fonte de Alarme. Os valores possíveis para esta propriedade são -2: Crítica, 0:
Alta, 1: Média ou 2: Baixa e é somente de leitura.

4.4.6.3.1.28 ShelveActorID
Nome do operador que arquivou este Evento. Esta propriedade é somente de leitura e seu valor pode ser o
usuário logado no E3 Viewer, quando o arquivamento é realizado no E3Alarm, "Sem usuário" se não há usuário
logado, ou "System" quando o arquivamento é automático, ou seja, para Eventos que pedem arquivamento.

4.4.6.3.1.29 ShelveCount
Número de vezes que este Evento foi arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.30 Shelved
Indica se este Evento foi ou não arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.31 ShelvedOutTime
Registra a data e hora do momento em que este Evento é desarquivado, ou zero (30/12/1899) enquanto este
Evento ainda não tenha sido desarquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.32 ShelvedTime
Registra a data e hora do momento em que este Evento é arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.33 ShelveDuration
Tempo, em minutos, que este Evento esteve arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.34 ShelveMaxCount
Número máximo de vezes que este Evento pode ser arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.35 ShelveMaxDuration
Tempo máximo, em minutos, que este Evento pode permanecer arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.36 ShelveReason
Motivo pelo qual este Evento foi arquivado. Esta propriedade é somente de leitura.

4.4.6.3.1.37 Source
Para Eventos de Alarme, informa a expressão utilizada para avaliar as condições de Alarme. Esta propriedade é
somente de leitura.

4.4.6.3.1.38 SubConditionName
Nome da subcondição, se este é um Evento de Alarme. Os valores possíveis para esta propriedade são:
· BM: Alarme de Banda Morta
· DIG: Alarme Digital
· TV: Alarme Taxa de Variação
· LOLO: Alarme Analógico na faixa Muito Baixo
· LO: Alarme Analógico na faixa Baixo
· HI: Alarme Analógico na faixa Alto

Visualização 186
· HIHI: Alarme Analógico na faixa Muito Alto

NOTA
Para Fontes de Alarme do tipo Discreto, esta propriedade assume o nome da Subcondição definida pelo usuário,
disponível na aba Discreto das propriedades deste tipo de Alarme.

Se este Evento não é um Alarme, esta propriedade é igual a uma String vazia. Esta propriedade é somente de leitura.

4.4.6.3.1.39 Unbound
Indica se este Evento está desvinculado de uma Fonte de Alarme. Esta propriedade é somente de leitura.

4.4.6.3.1.40 UserField
Esta propriedade recebe o índice ou o nome de um Campo de Usuário da Coleção de Campos de Usuário da Área
de Alarme (propriedade UserFields) e retorna o objeto correspondente. Para mais informações sobre o objeto
retornado por esta propriedade, consulte o tópico Campo de Usuário de Alarmes. Esta propriedade é somente de
leitura.

4.4.7 Coleção de Filtros


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Filtros
(ConnectionFilterCollection). Este objeto não possui eventos associados.

NOTA
A Coleção de Filtros pode ser acessada através da propriedade Filters dos objetos Filtro de Alarmes e E3Alarm.

4.4.7.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Filtros (ConnectionFilterCollection).

4.4.7.1.1 Add
Add(FilterName)
Adiciona um novo Filtro com o nome informado no parâmetro FilterName e retorna o Filtro criado. Caso o usuário
tente criar um Filtro com um nome já existente, uma mensagem de erro é mostrada. Para gerar um nome
automaticamente, deixe o parâmetro FilterName em branco. Consulte a propriedade geral Name para mais
informações sobre os caracteres permitidos nos nomes de objetos.

4.4.7.1.2 Item
Item(Index)
Retorna um objeto Filtro da Coleção de Filtros, especificado pelo parâmetro Index. Este parâmetro pode ser numérico,
se corresponder ao índice do objeto na Coleção, ou textual, se corresponder ao nome do Filtro (propriedade
FilterName do objeto Filtro).

4.4.7.1.3 Remove
Remove(Index)
Remove um objeto Filtro da Coleção de Filtros através de seu nome ou índice, especificado pelo parâmetro Index. O
Filtro de índice 0 (zero) não pode ser removido. Caso o usuário tente removê-lo, uma mensagem de erro é mostrada.

4.4.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Filtros (ConnectionFilterCollection).

4.4.7.2.1 Count
Contém o número de Filtros na Coleção de Filtros. Esta propriedade é somente de leitura.

187 Visualização
4.4.7.3 Filtro
Esta seção contém informações sobre as propriedades do objeto Filtro da Coleção de Filtros (ConnectionFilter). Este
objeto não possui eventos nem métodos associados.

4.4.7.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Filtro da Coleção de Filtros (ConnectionFilter).

4.4.7.3.1.1 AreaFilter
Controla as Áreas de alarmes visíveis no Filtro. Se o valor não é uma String vazia, são apresentados eventos cujo
nome das Áreas comecem com o texto indicado. Por exemplo, se AreaFilter é igual a "Ana", são mostrados os
alarmes de Áreas como "Analogicos.Producao" ou "Analise", mas não "Digitais.Analise" ou "Digitais.Producao". Quando
a propriedade SimpleAreaFilter está configurada como Falso, a Área de Alarme também permite o uso de caracteres
curingas para a filtragem e múltiplos filtros de Área, separados por dois pontos. Consulte a propriedade AreaFilter
do objeto Filtro de Alarme para informações sobre os caracteres curinga permitidos.
O valor padrão desta propriedade é uma String vazia, ou seja, sem filtragem por Área. Consulte também as
propriedades CustomFilter, SimpleAreaFilter, ShowCriticalPriority, ShowHighPriority, ShowMediumPriority e
ShowLowPriority.

4.4.7.3.1.2 CustomFilter
Permite informar um filtro personalizado para os alarmes, na forma de uma expressão. Consulte a propriedade
CustomFilter do objeto Filtro de Alarmes para informações sobre os campos disponíveis para utilização na expressão
deste filtro. Os campos definidos pelo usuário também podem ser utilizados na expressão do filtro, utilizando-se o
nome definido no Servidor de Alarmes.
Ao todo, as mensagens que aparecem na listagem do Filtro sempre passam pelos seguintes filtros:
· Filtro por tipo, definido na propriedade FilterType
· Filtro por severidade, definido nas propriedades ShowCriticalPriority, ShowLowPriority, ShowMediumPriority e
ShowHighPriority
· Filtro por área, definido nas propriedades AreaFilter e SimpleAreaFilter
· Filtro pela propriedade CustomFilter
· Filtro do sumário de alarmes, equivalente à expressão "Enabled AND (ConditionActive OR (AckRequired AND NOT
Acked))"

Para exemplos de uso desta propriedade, consulte a propriedade CustomFilter do objeto E3Alarm. O valor padrão
desta propriedade é uma String vazia.

4.4.7.3.1.3 FilterName
Nome que identifica este Filtro. Consulte a propriedade geral Name para mais informações sobre os caracteres
permitidos no nome deste objeto.

4.4.7.3.1.4 FilterType
Efetua os filtros de alarme. As opções disponíveis são 1 - OnlyAlarms: Mostra apenas alarmes (padrão), 2 -
OnlyEvents: Mostra apenas eventos ou 3 - AlarmsAndEvents: Mostra tanto alarmes quanto eventos.

4.4.7.3.1.5 IgnoreDiacritics
Se configurada para Verdadeiro, ignora caracteres acentuados na expressão de busca da propriedade
CustomFilter. Caso contrário, os caracteres acentuados na expressão de busca são considerados.

4.4.7.3.1.6 ShowCriticalPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Crítica. O valor padrão
desta propriedade é Verdadeiro.

4.4.7.3.1.7 ShowHighPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Alta. O valor padrão
desta propriedade é Verdadeiro.

Visualização 188
4.4.7.3.1.8 ShowLowPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Baixa. O valor padrão
desta propriedade é Verdadeiro.

4.4.7.3.1.9 ShowMediumPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Média. O valor padrão
desta propriedade é Verdadeiro.

4.4.7.3.1.10 SimpleAreaFilter
Quando esta propriedade é igual a Verdadeiro, o comportamento de filtragem pelo nome de Área de Alarmes é
baseado apenas na coincidência da parte inicial do nome. Quando é igual a Falso, o comportamento leva em conta
todo o nome da Área, mas permite o uso de caracteres curinga e múltiplos filtros de área, que devem ser separados
por dois pontos. Consulte também a propriedade AreaFilter, que especifica o filtro por nome de área. O valor
padrão desta propriedade é Verdadeiro.

4.4.8 Cor do Alarme


Esta seção contém informações sobre métodos e propriedades do objeto Cor do Alarme (E3AlarmColorObject). Este
objeto não possui eventos associados.

NOTA
O objeto Cor do Alarme pode ser acessado utilizando-se as propriedades ColorAckedAlarm, ColorActiveAlarm,
ColorActiveEvent e ColorNAckAlarm do E3Alarm.

4.4.8.1 Métodos
Esta seção contém informações sobre os métodos do objeto Cor do Alarme (E3AlarmColorObject).

4.4.8.1.1 SetConfig
SetConfig([BackgroundColor], [TextColor], [BlinkMode], [TextColor2])
Configura a cor de fundo, de texto, o modo de pisca e a cor do texto quando o modo de pisca é igual a 3 (três) para
o alarme ou severidade. Caso o objeto Cor do Alarme esteja configurando uma severidade específica, ou seja,
diferente de -1 (menos um), os parâmetros informados forçam automaticamente a atualização das propriedades de
redefinição equivalentes (OverrideBackgroundColor para o parâmetro BackgroundColor, OverrideTextColor para o
parâmetro TextColor, OverrideBlinkMode para o parâmetro BlinkMode e TextColor2 para o parâmetro TextColor2 se
a propriedade BlinkMode é igual a três). Se a propriedade Severity é igual a -1 (menos um), então a configuração é
realizada para os valores padrão de cor de fundo, de texto e modo de pisca do alarme, e esta configuração pode ou
não se propagar para cada severidade, dependendo dos valores de redefinição de cada uma das propriedades
equivalentes. Exemplo:
' Configura apenas a propriedade BackgroundColor
' do alarme ativo com severidade alta
Set AlarmeAtivoAlta = Screen.Item("E3Alarm1").ColorActiveAlarm(0)
AlarmeAtivoAlta.SetConfig RGB(0,0,255)

' Configura apenas a propriedade TextColor


' do alarme ativo com severidade média
Set AlarmeAtivoMedia = Screen.Item("E3Alarm1").ColorActiveAlarm(1)
AlarmeAtivoMedia.SetConfig , RGB(255,255,255)

' Configura apenas a propriedade BlinkMode


' do alarme ativo com severidade baixa
Set AlarmeAtivoBaixa = Screen.Item("E3Alarm1").ColorActiveAlarm(2)
AlarmeAtivoBaixa.SetConfig ,,1

' Configura todas as propriedades do alarme ativo


Set AlarmeAtivo = Screen.Item("E3Alarm1").ColorActiveAlarm(-1)
AlarmeAtivo.SetConfig RGB(0,255,0), RGB(0,128,0), 2

4.4.8.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Cor do Alarme (E3AlarmColorObject).

189 Visualização
4.4.8.2.1 BackgroundColor
Define a cor de fundo para o alarme ou severidade.

4.4.8.2.2 BlinkMode
Define o modo de pisca para o alarme ou severidade. Os valores possíveis para esta propriedade são 0: Não
pisca, 1: Pisca o fundo e o texto, 2: Pisca apenas o texto ou 3: Pisca o texto trocando para a cor definida na
propriedade TextColor2.

4.4.8.2.3 OverrideBackgroundColor
Define se a cor de fundo configurada na propriedade BackgroundColor é ou não aplicada à severidade. Se esta
propriedade está configurada em Falso, a severidade usa a cor de fundo definida como padrão para o alarme.

4.4.8.2.4 OverrideBlinkMode
Define se o modo de pisca configurado na propriedade BlinkMode é ou não aplicado à severidade. Se esta
propriedade está configurada em Falso, a severidade usa o modo de pisca definido como padrão para o alarme.

4.4.8.2.5 OverrideTextColor
Define se a cor do texto configurada na propriedade TextColor é ou não aplicada à severidade. Se esta
propriedade está configurada em Falso, a severidade usa a cor do texto configurada como padrão para o alarme.

4.4.8.2.6 Severity
Retorna a severidade de um alarme. Os valores possíveis para esta propriedade são -2: Crítica, -1: Padrão, 0: Alta,
1: Média ou 2: Baixa. Esta propriedade é somente de leitura.

4.4.8.2.7 TextColor
Define a cor do texto para o alarme ou severidade.

4.4.8.2.8 TextColor2
Define a cor do texto para o alarme ou severidade quando a propriedade BlinkMode está configurada para o
valor 3 (três).

4.5 E3Browser
Esta seção contém informações sobre eventos, métodos e propriedades do objeto E3Browser.

4.5.1 Eventos
Esta seção contém informações sobre os eventos do objeto E3Browser.

4.5.1.1 KeyPress
KeyPress(KeyAscii)
Ocorre quando o E3Browser tem o foco de teclado e o usuário pressiona uma tecla, que corresponde a um caractere
que pode ser mostrado em tela (uma tecla ANSI, de código indicado no parâmetro KeyAscii), ou seja, o evento ocorre
quando qualquer das teclas a seguir é pressionada:
· Qualquer caractere do teclado que possa ser impresso
· Tecla CTRL combinada com qualquer caractere do alfabeto padrão
· Tecla CTRL combinada com qualquer caractere especial
· Tecla BACKSPACE
· Tecla ESC

Este evento não ocorre nas seguintes condições:


· Pressionando-se a tecla TAB
· Pressionando-se a tecla ENTER
· Pressionando-se a tecla DEL (essa tecla não é padrão ANSI)

Visualização 190
· Pressionando-se as setas do teclado
· Quando uma tecla move o foco de um objeto para outro

Enquanto o usuário pressiona uma tecla que produz um código ANSI, o E3Browser recebe os eventos KeyDown e
KeyPress repetidamente. Quando o usuário libera a tecla, o evento KeyUp ocorre. Para monitorar o estado físico do
teclado ou manipular teclas não reconhecidas pelo evento KeyPress, tais como teclas de função e navegação, utilize
os eventos KeyDown e KeyUp.

NOTA
Para uma lista com todos os códigos de tecla disponíveis para o parâmetro KeyAscii, consulte o artigo Keys
Enumeration no Microsoft Developer Network.

4.5.1.2 MouseMove
MouseMove()
Ocorre quando o ponteiro do mouse se move sobre o objeto E3Browser.

4.5.1.3 OnDrawRow
OnDrawRow(Selected, Line, TextColor, BackColor)
Este evento possui os seguintes parâmetros:
· Selected: Indica se a linha está selecionada
· Line: Indica o número da linha sendo desenhada
· TextColor: Indica a cor do texto da linha
· BackColor: Indica a cor de fundo do texto

Se a cor é modificada dentro deste evento, esta modificação é usada pelo E3Browser no desenho da linha. Outra
modificação importante é que se o método GetColumnValue é chamado de dentro deste evento, os valores
retornados são os da linha sendo desenhada, e não os da linha selecionada.

4.5.1.4 OnFormatCell
OnFormatCell(Column, FieldName, OriginalValue, FormattedValue)
Este evento permite personalizar o formato do texto das células do E3Browser. Os parâmetros deste evento são os
seguintes:
· Column: Índice da coluna visível do E3Browser, iniciando em 0 (zero). Permite identificar a coluna da célula que
está sendo formatada
· FieldName: Texto com o nome do campo da coluna sendo formatada
· OriginalValue: Valor não formatado da célula, do tipo Variant
· FormattedValue: Valor formatado, do tipo Variant, de acordo com a configuração da coluna do E3Browser. Se
modificado dentro do evento, permite alterar o texto formatado

O exemplo a seguir demonstra a formatação de campos de Alarmes.


Sub E3Browser1_OnFormatCell(Column, FieldName, OriginalValue, FormattedValue)
If Column = 15 Then
If Not IsNull(OriginalValue) Then
FormattedValue = SourceTypeName(OriginalValue)
ElseIf Column = 9 Then
If OriginalValue = 0 Then
FormattedValue = "Alta"
ElseIf OriginalValue = 1 Then
FormattedValue = "Média"
Else
FormattedValue = "Baixa"
End If
End If
End Sub

191 Visualização
4.5.2 Métodos
Esta seção contém informações sobre os métodos do objeto E3Browser.

4.5.2.1 AboutBox
AboutBox()
Este método exibe uma caixa de diálogo com informações sobre versão e copyright do objeto E3Browser.

4.5.2.2 ClearFields
ClearFields()
Limpa a formatação de colunas e linhas do E3Browser.

4.5.2.3 GetColumnValue
GetColumnValue(Index)
Retorna o valor de uma célula, na coluna informada e na linha selecionada. Este método possui o parâmetro Index,
que determina o índice da coluna desejada.

4.5.2.4 Requery
Requery()
Este método atualiza a Consulta, utilizando a configuração atual, e retorna os dados para o E3Browser.

4.5.2.5 RetrieveE3QueryFields
RetrieveE3QueryFields()
Este método lê a estrutura de dados da Consulta e atualiza a formatação do E3Browser, com os campos definidos na
Consulta. Se este método é bem sucedido, retorna Verdadeiro. Caso contrário, retorna Falso. Este método é
especialmente útil quando é preciso usar um único E3Browser para exibir dados de diferentes tabelas ou Consultas.

4.5.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto E3Browser.

4.5.3.1 AllowColumnResize
Habilita ou desabilita a configuração do tamanho das colunas da grade, em tempo de execução. Se esta
propriedade estiver configurada para Falso, o tamanho das colunas é fixo e não pode ser modificado.

4.5.3.2 AllowHeaderSort
Habilita ou desabilita a ordenação pelo cabeçalho das colunas do E3Browser em tempo de execução. O valor
padrão desta propriedade é Verdadeiro.

4.5.3.3 AllowRowResize
Habilita ou desabilita a configuração do tamanho das linhas da grade, em tempo de execução. Se esta propriedade
estiver configurada para Falso, o tamanho das linhas é fixo e não pode ser modificado.

4.5.3.4 ColumnTextAlignment
Determina o alinhamento do texto das colunas do E3Browser. Os valores possíveis para esta propriedade são 0:
taAlignLeft (padrão), 1: taAlignCenter ou 2: taAlignRight. Ao selecionar um valor para esta propriedade, todos os
valores com o mesmo alinhamento na coluna Alinhamento do Texto da lista de campos da aba Consulta da Janela
de Propriedades do E3Browser são modificados para o valor selecionado.

4.5.3.5 ColumnWidth
Determina a largura das colunas do E3Browser, em pixels.

Visualização 192
4.5.3.6 CurSel
Indica a posição atual do cursor do E3Browser, ou seja, o índice da linha em que o cursor está posicionado.

4.5.3.7 E3Query
Retorna o objeto Consulta do E3Browser, para acesso às propriedades deste objeto. Esta propriedade é somente
de leitura.

4.5.3.8 Fields
Retorna a Coleção de Campos do E3Browser, que contém a lista com todos os campos da tabela, tornando
possível a referência através dos itens desta Coleção. Esta propriedade é somente de leitura. O valor padrão desta
propriedade é vazio. Exemplo:
Sub E3Browser1_Click()
' Troca a cor do campo Campo1
Set fields = Screen.Item("E3Browser").Fields
Set campo1 = fields.Item("Campo1")
campo1.BkColor = RGB(255, 0, 0) ' Vermelho
' Mostra quantos campos tem o E3Browser
MsgBox fields.Count
' Mostra o nome dos campos do E3Browser
For Each field In fields
MsgBox field.Name
Next
End Sub

Para mais informações sobre a Coleção retornada nesta propriedade, consulte o tópico Coleção de Campos do
E3Browser.

4.5.3.9 FixedBkColor
Especifica a cor de fundo do cabeçalho do E3Browser. O valor padrão desta propriedade é a cor RGB(240, 240,
240). Esta propriedade corresponde à opção Cor de fundo do cabeçalho na aba Cores da Janela de Propriedades
do E3Browser.

4.5.3.10 FixedColumnWidth
Determina a largura da primeira coluna do E3Browser, em pixels. O valor padrão desta propriedade é 30 pixels.

4.5.3.11 FixedRowFont
Determina a fonte do texto utilizada na linha de cabeçalho do E3Browser. Esta propriedade não pode ser utilizada
em scripts ou em Associações, e é configurada somente via E3 Studio. O valor padrão desta propriedade é a fonte
Arial. Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.

4.5.3.12 FixedRowHeight
Determina a altura, em pixels, da linha de cabeçalho do E3Browser. O valor padrão desta propriedade é 20.

4.5.3.13 FixedTextColor
Especifica a cor do cabeçalho do E3Browser. O valor padrão desta propriedade é preto (RGB(0, 0, 0)). Esta
propriedade corresponde à opção Cor do texto do cabeçalho na aba Cores da Janela de Propriedades do
E3Browser.

4.5.3.14 GridBkColor
Determina a cor de fundo da área de dados do E3Browser. O valor padrão desta propriedade é branco (RGB(255,
255, 255)). Esta propriedade corresponde à opção Cor de fundo do E3Browser na aba Cores da Janela de
Propriedades do E3Browser.

4.5.3.15 GridFont
Determina a fonte utilizada nos textos da área de dados do E3Browser. O valor padrão desta propriedade é a fonte
Arial. Esta propriedade não pode ser utilizada em scripts ou em Associações, e é configurada somente via E3 Studio.
Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.

193 Visualização
4.5.3.16 GridLineColor
Determina a cor das linhas da grade de dados do E3Browser. O valor padrão desta propriedade é prata (RGB(192,
192, 192)). Esta propriedade corresponde à opção Cor da linha da grade na aba Cores da Janela de Propriedades
do E3Browser.

4.5.3.17 GridLinesType
Determina o tipo de linhas a serem desenhadas na grade de dados do E3Browser.
Opções disponíveis para a propriedade GridLinesType
OPÇÃO DESCRIÇÃO
0 - GLNone Sem linhas separadoras

1 - GLHorz Somente linhas horizontais

2 - GLVert Somente linhas verticais

3 - GLBoth Linhas verticais e horizontais (padrão)

4.5.3.18 HeaderTextAlignment
Determina o alinhamento do texto do cabeçalho das colunas do E3Browser. Os valores possíveis para esta
propriedade são 0: bhaLeft (padrão), 1: bhaCenter, 2: bhaRight ou 3: bhaFollowColumn. Ao selecionar a opção
bhaFollowColumn, o texto do cabeçalho das colunas é alinhado conforme especificado na coluna Alinhamento do
Texto da lista de campos da aba Consulta da Janela de Propriedades do E3Browser.

4.5.3.19 HeaderWordWrap
Esta propriedade aplica uma quebra de linha no texto do cabeçalho das colunas do E3Browser, permitindo mostrar
o texto completo do nome da coluna. Esta quebra de linha é aplicada somente onde houver um espaço, tabulação ou
quebra de linha forçada no texto. Configurar esta propriedade em Verdadeiro não altera o valor da propriedade
FixedRowHeight, que controla a altura do cabeçalho das colunas. Caso o texto do cabeçalho não contenha espaços,
tabulações ou quebras de linha forçadas, o texto é truncado e são mostradas reticências no limite da largura da
coluna. Além disto, o alinhamento vertical do texto, normalmente centralizado, é alterado para um alinhamento pelo
topo. O valor padrão desta propriedade é Falso.

4.5.3.20 RefreshTime
Especifica o tempo de atualização da Consulta em relação ao Banco de Dados. Através desta propriedade é possível
verificar as atualizações dos dados no Histórico relacionado, referente a um determinado tempo, estipulado em
milissegundos. Quando esta propriedade é igual a 0 (zero), não há atualização dos dados e estes permanecem
inalterados. O valor desta propriedade deve ser maior que 1000 ms.

4.5.3.21 RowHeight
Define a altura das linhas da E3Browser, em pixels. O valor padrão desta propriedade é 20.

4.5.3.22 SelectRow
Estabelece a possibilidade de seleção das linhas do E3Browser. Se esta propriedade estiver configurada para
Verdadeiro, é possível selecionar as linhas. Do contrário, as linhas não podem ser selecionadas.

4.5.3.23 SourceQuery
Contém a referência para o objeto Consulta ao qual o E3Browser está associado.

NOTA
Para trocar a Consulta do E3Browser por meio de um script, caso a nova Consulta modifique os campos da Consulta
original, além de alterar esta propriedade é preciso utilizar os métodos RetrieveE3QueryFields e Requery.

4.5.3.24 TextBkColor
Especifica a cor de fundo das células de dados do E3Browser. O valor padrão desta propriedade é branco
(RGB(255, 255, 255)). Esta propriedade corresponde à opção Cor de fundo da célula na aba Cores da Janela de

Visualização 194
Propriedades do E3Browser.

4.5.3.25 TextColor
Especifica a cor do texto do E3Browser. O valor padrão desta propriedade é preto (RGB(0, 0, 0)). Esta propriedade
corresponde à opção Cor do texto da célula na aba Cores da Janela de Propriedades do E3Browser.

4.5.3.26 TitleTipBkColor
Especifica a cor do fundo do texto da dica do E3Browser. O valor padrão desta propriedade é branco (RGB(255,
255, 225)). Esta propriedade corresponde à opção Cor de fundo da dica da célula na aba Cores da Janela de
Propriedades do E3Browser.

4.5.3.27 TitleTipTextColor
Especifica a cor do texto da dica do E3Browser. O valor padrão desta propriedade é preto RGB(0, 0, 0). Esta
propriedade corresponde à opção Cor do texto da dica da célula na aba Cores da Janela de Propriedades do
E3Browser.

4.5.3.28 ToolbarBkColor
Especifica a cor de fundo da barra de ferramentas do E3Browser. O valor padrão desta propriedade é a cor
RGB(240, 240, 240). Esta propriedade corresponde à opção Cor de fundo da barra de funções na aba Cores da
Janela de Propriedades do E3Browser.

4.5.3.29 ToolbarFont
Determina a fonte utilizada nos textos da barra de ferramentas do E3Browser. Esta propriedade não pode ser
utilizada em scripts ou em Associações, e é configurada somente via E3 Studio. Consulte o tópico Fonte para mais
informações sobre as subpropriedades desta propriedade.

4.5.3.30 ToolbarForeColor
Especifica a cor de frente da barra de ferramentas do E3Browser. O valor padrão desta propriedade é preto
(RGB(0, 0, 0)). Esta propriedade corresponde à opção Cor do texto da barra de funções na aba Cores da Janela de
Propriedades do E3Browser.

4.5.4 Coleção de Campos do E3Browser


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Campos do E3Browser
(FieldCollection). Este objeto não possui eventos associados.

NOTA
A Coleção de Campos do E3Browser pode ser acessada através da propriedade Fields do E3Browser.

4.5.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Campos do E3Browser (FieldCollection).

4.5.4.1.1 Item
Item(Index)
Retorna um objeto Campo da Coleção de Campos do E3Browser, especificado pelo parâmetro Index. Este parâmetro
pode ser numérico, se corresponder ao índice do objeto na Coleção, ou textual, se corresponder ao nome do Campo,
ou seja, a propriedade Name do objeto Campo do E3Browser.

4.5.4.1.2 Remove
Remove(Index)
Remove um objeto Campo da Coleção de Campos do E3Browser através de seu nome ou índice, especificado pelo
parâmetro Index.

195 Visualização
4.5.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Campos do E3Browser (FieldCollection).

4.5.4.2.1 Count
Contém o número de Campos na Coleção de Campos do E3Browser. Esta propriedade é somente de leitura.

4.5.4.3 Campo do E3Browser


Esta seção contém informações sobre propriedades do objeto Campo do E3Browser (Field). Este objeto não possui
eventos nem métodos associados.

4.5.4.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo do E3Browser (Field).

4.5.4.3.1.1 BkColor
Determina a cor de fundo do Campo do E3Browser. O valor padrão desta propriedade é a cor configurada no
Windows para o item Janela do Painel de Controle (Painel de Controle - Vídeo - Aparência - Avançada).

4.5.4.3.1.2 Color
Retorna a cor do texto do Campo do E3Browser. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.5.4.3.1.3 Format
Configura o formatador usado na coluna do Campo do E3Browser.

4.5.4.3.1.4 Name
Retorna o nome do Campo do E3Browser.

4.5.4.3.1.5 Visible
Habilita ou desabilita a visibilidade do Campo selecionado na Consulta do E3Browser. Se esta propriedade estiver
configurada para Verdadeiro, o Campo é visível no E3Browser. Caso contrário, o Campo não é mostrado no
E3Browser, em tempo de execução. O valor padrão desta propriedade é Verdadeiro.

4.5.4.3.1.6 Width
Retorna a largura do Campo do E3Browser, em pixels.

4.6 E3Chart
Esta seção contém informações sobre eventos, métodos e propriedades do objeto E3Chart.

4.6.1 Eventos
Esta seção contém informações sobre os eventos do objeto E3Chart.

4.6.1.1 OnCursorChange
OnCursorChange()
Ocorre quando o cursor do E3Chart muda de posição. Por exemplo, pode-se criar um script para este evento quando
é necessário mostrar os valores de posição do cursor na Tela. Exemplo:
Sub E3Chart1_OnCursorChange()
Set Chart = Application.GetFrame("").Screen.Item("E3Chart1")
Set Pena = Chart.Pens.Item(0)
' O objeto Text1 deve mostrar a posição atual do cursor
Set Texto = Application.GetFrame("").Screen.Item("Text1")
If Pena.GetCursorPos(aa, bb) Then
Texto.Value = "Posição X = " & aa & "; Posição Y = " & bb
End If
End Sub

Visualização 196
4.6.1.2 OnLegendClick
OnLegendClick(Row, Col, RowData)
Ocorre quando o usuário clica em uma linha da Legenda. Os parâmetros Row e Col indicam, respectivamente, a linha e
a coluna clicadas. O parâmetro RowData é o índice da Pena da Legenda onde ocorreu o clique. Exemplo:
Sub E3Chart1_OnLegendClick(Row, Col, RowData)
Set texto = Screen.Item("Texto1")
texto.Value = Legend.Item(col).Name & " " & _
Pens.Item(RowData).Name
End Sub

4.6.1.3 OnQueryFinish
OnQueryFinish()
Ocorre quando uma ou mais Consultas são encerradas no E3Chart. Quando o evento é gerado, a chamada dos
métodos FitAll ou FitPen pode causar problemas caso se esteja utilizando a Consulta automática, já que estes
métodos ativam outras Consultas até que todos os dados sejam lidos. Neste caso, é recomendado que o valor
passado pelos parâmetros destes métodos seja 1 (um), o que enquadra verticalmente as Penas.

4.6.2 Métodos
Esta seção contém informações sobre os métodos do objeto E3Chart.

4.6.2.1 ClearPenMarks
ClearPenMarks()
Remove as marcas de pesquisa de todas as Penas do E3Chart.

4.6.2.2 CopyConfig
CopyConfig(SourceChart, [Flags])
Este método copia as configurações de um E3Chart para outro. O parâmetro SourceChart indica o E3Chart de origem,
cujas propriedades são copiadas para o E3Chart que chamou o método.

NOTA
No caso dos Relatórios, este método funciona somente com Penas do tipo Histórica.

Por exemplo, para copiar a configuração de um E3Chart que está em uma Tela (ScreenChart) para outro que está
dentro de um Relatório (ReportChart), o seguinte script pode ser adicionado no objeto Report associado ao
Relatório.
Sub OnBeforePrint
Set Chart = _
Report.Sections("PageHeader").Controls("ReportChart")
Chart.CopyConfig(Application.GetFrame()._
Screen.Item("ScreenChart"))
Chart.LoadData()
Chart.FitAll()
End Sub

NOTA
Este método também possui o parâmetro opcional e não usado Flags, somente para fins de compatibilidade com
versões anteriores.

4.6.2.3 FitAll
FitAll([FitStyle])
Enquadra todas as Penas no E3Chart. O parâmetro opcional FitStyle indica o modo de enquadramento das Penas em
tempo de execução e, se omitido, assume o valor 0 (zero):
· 0: Enquadra ambos os Eixos ao mesmo tempo
· 1: Enquadra apenas o Eixo Vertical
· 2: Enquadra apenas o Eixo Horizontal

197 Visualização
4.6.2.4 FitPen
FitPen(Pen, [FitStyle])
Enquadra uma Pena no E3Chart. O parâmetro Pen define a Pena a ser enquadrada no E3Chart (índice ou nome da
Pena). O parâmetro opcional FitStyle indica o modo de enquadramento das Penas em tempo de execução e, se
omitido, assume o valor 0 (zero):
· 0: Enquadra ambos os Eixos ao mesmo tempo
· 1: Enquadra apenas o Eixo Vertical
· 2: Enquadra apenas o Eixo Horizontal

Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Chart.FitPen(1)
Chart.FitPen("Pen1", 1)
' Enquadra a Pen1 somente na vertical
End Sub

4.6.2.5 LoadData
LoadData()
Carrega os dados no E3Chart. Este método é especialmente usado para carregar os dados antes de imprimir, quando
usado em um objeto Relatório.

NOTA
Este método é síncrono somente se a Pena não estiver em modo Consulta Automática.

4.6.2.6 ResetConfig
ResetConfig([Flags])
Remove todas as configurações ajustadas em um E3Chart, devolvendo-o ao estado inicial.

NOTA
Este método também possui o parâmetro opcional e não usado Flags, somente para fins de compatibilidade com
versões anteriores.

4.6.2.7 ShowCursors
ShowCursors()
Ativa o modo Pesquisa de Intervalo. Em tempo de execução, este recurso pode ser acessado clicando com o botão
direito do mouse no E3Chart e selecionando a opção Pesquisar Intervalos do menu contextual.

4.6.2.8 ZoomIn
ZoomIn()
Este método aumenta o zoom no E3Chart, isto é, aproxima a visualização das Penas. Em tempo de execução, este
recurso pode ser acessado clicando com o botão direito do mouse no E3Chart e selecionando a opção Mais Zoom
do menu contextual.

4.6.2.9 ZoomOut
ZoomOut()
Este método diminui o zoom no E3Chart, isto é, afasta a visualização das Penas no E3Chart. Em tempo de execução,
este recurso pode ser acessado clicando com o botão direito do mouse no E3Chart e selecionando a opção Menos
Zoom do menu contextual.

4.6.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto E3Chart.

Visualização 198
4.6.3.1 Axes
Retorna a coleção de Eixos do E3Chart. A partir daí, as propriedades da coleção de Eixos podem ser modificadas.
Esta propriedade é somente de leitura.

4.6.3.2 BackColor
Determina a cor de fundo do E3Chart. Para que esta cor apareça, a propriedade ShowBackground deve estar
configurada como Verdadeiro. O valor padrão desta propriedade é bege (RGB(236, 233, 216)).

4.6.3.3 CursorBegin
Define a posição do cursor inicial, entre 0 (zero) e 1 (um). É necessário executar o método ShowCursors ou habilitar
a opção Pesquisa de Intervalos para que os cursores apareçam.

4.6.3.4 CursorColor
Estabelece a cor do cursor de pesquisa de intervalo. O valor padrão é vermelho (RGB(255, 0, 0)).

4.6.3.5 CursorEnd
Define a posição do cursor final, entre 0 (zero) e 1 (um). É necessário executar o método ShowCursors ou habilitar a
opção Pesquisa de Intervalos para que os cursores apareçam.

4.6.3.6 CursorLineStyle
Estilo de linha do cursor de pesquisa de intervalo. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para CursorLineStyle
OPÇÃO DESCRIÇÃO
0 - LS_Solid Aplica uma linha sólida no cursor de intervalo do E3Chart
(padrão)

1 - LS_Dash Aplica uma linha tracejada no cursor de intervalo do


E3Chart

2 - LS_Dot Aplica uma linha pontilhada no cursor de intervalo do


E3Chart

3 - LS_Dashdot Aplica uma linha traço e ponto no cursor de intervalo do


E3Chart

4 - LS_Dashdotdot Aplica uma linha traço ponto ponto no cursor de


intervalo do E3Chart

5 - LS_Null Aplica uma linha invisível no cursor de intervalo do


E3Chart

4.6.3.7 CursorLineWidth
Estabelece a largura do cursor de intervalo.

4.6.3.8 CursorSearchStyle
Permite que o cursor pesquise os pontos do gráfico, de acordo com as seguintes opções:
· 0 - PointNearest: Pesquisa o ponto mais próximo (padrão)
· 1 - LinearInterpolation: Pesquisa um ponto interpolado
· 2 - PointPrevious: Pesquisa o ponto anterior

4.6.3.9 ForeColor
Determina a cor de frente do E3Chart. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.6.3.10 GridBkColor
Determina a cor de fundo da grade do E3Chart. O valor padrão desta propriedade é branco (RGB(255, 255, 255)).
Exemplo:

199 Visualização
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.GridBkColor
MsgBox "Próxima"
E3Chart1.GridBkColor = RGB(0, 255, 0)
MsgBox "Voltar"
E3Chart1.GridBkColor = Old
End Sub

4.6.3.11 HorAxisTitle
Determina o título do Eixo Horizontal principal. Exemplo:
Sub CommandButton1_Click()
Set E3Chart1= Screen.Item("E3Chart1")
Old = E3Chart1.HorAxisTitle
MsgBox "Próxima"
E3Chart1.HorAxisTitle = "!Teste"
MsgBox "Voltar"
E3Chart1.HorAxisTitle = Old
End Sub

4.6.3.12 HorGrid
Determina o tipo de linha aplicada na grade horizontal do E3Chart. As opções disponíveis estão descritas na tabela
a seguir.
Opções disponíveis para HorGrid
OPÇÃO DESCRIÇÃO
0 - Solid Aplica uma linha sólida na grade horizontal do E3Chart

1 - Dash Aplica uma linha tracejada na grade horizontal do


E3Chart

2 - Dot Aplica uma linha pontilhada na grade horizontal do


E3Chart (padrão)

3 - Dashdot Aplica uma linha traço e ponto na grade horizontal do


E3Chart

4 - Dashdotdot Aplica uma linha traço ponto ponto na grade horizontal


do E3Chart

5 - Invisible Aplica uma linha invisível na grade horizontal do E3Chart

Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.HorGrid
For i = 0 To 5
E3Chart1.HorGrid = i
MsgBox "E3Chart1.HorGrid =" & CStr(i)
Next
MsgBox "Voltar"
E3Chart1.HorGrid = Old
End Sub

4.6.3.13 HorGridColor
Determina a cor da grade horizontal do objeto E3Chart. O valor padrão desta propriedade é cinza (RGB(192, 192,
192)). Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.HorGridColor
MsgBox "Próxima"
E3Chart1.HorGridColor = RGB(255, 0, 0)
MsgBox "Próxima"
E3Chart1.HorGridColor = RGB(0, 0, 255)
MsgBox "Voltar"
E3Chart1.HorGridColor = Old
End Sub

Visualização 200
4.6.3.14 HorMinorTicks
Determina o número de subdivisões das escalas horizontais da grade. O valor padrão desta propriedade é 1 (um).
Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.HorMinorTicks
For i = 0 To 5
E3Chart1.HorMinorTicks = i
MsgBox "Próximo valor"
Next
E3Chart1.HorMinorTicks = Old
End Sub

4.6.3.15 HorScaleBegin
Determina o valor inicial aplicado na escala horizontal principal da grade. Este valor pode ser numérico para
E3Charts XY, ou Data para E3Charts com escala de tempo fixa. Para E3Charts de tempo real, esta propriedade não é
aplicada, sendo então utilizada a propriedade TimeSpan.

4.6.3.16 HorScaleEnd
Determina o valor final aplicado na escala horizontal principal da grade. Este valor pode ser numérico para E3Charts
XY, ou Data para E3Charts com escala de tempo fixa. Para E3Charts de tempo real, esta propriedade não é aplicada,
sendo então utilizada a propriedade TimeSpan. Exemplo:
Sub ComboBox1_Change()
' Define qual consulta deseja mostrar
current_query_index = ListIndex
Set E3Chart1 = Screen.Item("E3Chart1")
i = 0
For Each query In E3Chart1.Queries
If i = current_query_index Then
query.FieldFilter(0) = "" ' Traz tudo
Set current_query = query
Else
query.FieldFilter(0) = "<0" ' Não traz nada para
' não ficar lento
End If
i = i + 1
Next
' Só mostra as penas que usam a consulta atual
For Each pen In E3Chart1.Pens
pen.Visible = (pen.QueryName = current_query.Name)
Next
' Atualiza as consultas
E3Chart1.Queries.UpdateData()
Screen.Item("E3Chart1").HorScaleBegin = Now - 0.001
Screen.Item("E3Chart1").HorScaleEnd = Now
End Sub

4.6.3.17 HorScaleFormat
Contém um texto que representa uma máscara, dentro da qual os valores da escala horizontal são mostrados. Esta
máscara pode representar vários tipos de valores:
· Geral: Não possui formatação específica, adaptando-se automaticamente ao valor especificado
· Número: Apresenta números com parte inteira e fracionária. O usuário pode optar por até 15 casas decimais, por
usar ou não um separador de milhares e por apresentar números negativos com sinal ou entre parênteses. Para
números muito grandes ou muito pequenos, recomenda-se utilizar o formato Científico
· Data: Apresenta valores numéricos de data e hora (quando válidos). Para representar apenas a hora, use o
formato equivalente
· Hora: Apresenta valores numéricos de hora e data (quando válidos). Para representar apenas a data, use o
formato equivalente
· Porcentagem: Multiplica o número por 100 e adiciona o símbolo de porcentagem. Admite até 15 casas decimais
· Científico: Apresenta o número em notação de mantissa e expoente. Ideal para números de magnitude variada.
Admite até 15 casas decimais
· Especial: Permite formatar números inteiros em bases não decimais (hexadecimal, octal ou binária, por exemplo)

201 Visualização
· Outro: Permite editar diretamente o código de formatação desejado, ou selecionar um formato criado
anteriormente

A máscara destes formatos, como exemplificadas no campo Tipo, é exibida na Janela de Propriedades (por exemplo,
d/M/yy H:mm, 0E-00, etc.).

4.6.3.18 HorTickUnit
Determina o número de subdivisões entre as marcas da grade. Quando esta propriedade estiver com o valor 0
(zero), o espaçamento é automático. Exemplo:
Sub SubCommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.HorTickUnit
For i = 0 To 30 Step 10
E3Chart1.HorTickUnit = i
MsgBox "E3Chart1.HorTickUnit = " & CStr(i)
Next
MsgBox "Voltar"
E3Chart1.HorTickUnit = Old
End Sub

4.6.3.19 Legend
Retorna o objeto Legenda do E3Chart. A partir daí, as propriedades da Legenda podem ser modificadas. Esta
propriedade é somente de leitura.

4.6.3.20 MouseMode
Seleciona uma das opções de tempo de execução do menu contextual do E3Chart. Os valores possíveis para essa
propriedade são os seguintes:
· 0 - MouseModeZoom: Coloca o mouse em modo Zoom por área selecionada. Esta opção está disponível nos
gráficos de escala numérica em XY e escala fixa. Equivale a selecionar a opção Caixa de Zoom do menu em
tempo de execução do E3Chart
· 1 - MouseModePan: Coloca o mouse em modo de movimentação das escalas. Equivale a selecionar a opção
Mover do menu em tempo de execução do E3Chart
· 2 - MouseModePanH: Coloca o mouse em modo de movimentação das escalas somente na direção horizontal.
Equivale a selecionar a opção Mover horizontalmente do menu em tempo de execução do E3Chart
· 3 - MouseModeSearch: Coloca o mouse em modo de pesquisa de valores nos dados das Penas. Equivale a
selecionar a opção Pesquisar do menu em tempo de execução do E3Chart (padrão)
· 4 - MouseModeCursors: Habilita a opção de pesquisa de intervalos de tempo. Equivale a selecionar a opção
Pesquisar Intervalos do menu em tempo de execução do E3Chart

4.6.3.21 Padding
Esta propriedade determina a distância, em pixels, entre o gráfico e a borda do E3Chart, conforme pode ser
observado nas figuras seguintes através das setas vermelhas. O valor padrão desta propriedade é 10.

Visualização 202
Propriedade Padding igual a 10

Propriedade Padding igual a 30

4.6.3.22 Pens
Retorna o objeto Coleção de Penas do E3Chart. O objeto Coleção de Penas é utilizado para inserir, remover ou
acessar as Penas disponíveis no E3Chart. Esta propriedade é somente de leitura. Exemplo:
Sub CommandButton1_Click()
For Each pen In Screen.Item("E3Chart1").Pens
pen.Visible = True

203 Visualização
Next
End Sub

4.6.3.23 Queries
Retorna o objeto Coleção de Consultas dentro do E3Chart. O objeto Coleção de Consultas é utilizado para inserir,
remover ou acessar as Consultas disponíveis no E3Chart. Esta propriedade é somente de leitura.

4.6.3.24 RefreshTime
Esta propriedade determina o tempo de atualização do E3Chart.

4.6.3.25 RenderQuality
Controla a qualidade de desenho das Penas do E3Chart. Os valores possíveis para esta propriedade são os
seguintes:
· 0 - rqDefault: Utiliza o modo de qualidade configurado na propriedade RenderQuality da Tela, se diferente de 0
(zero), ou o modo de qualidade configurado na propriedade RenderQuality do Viewer, também se diferente de
0 (zero), nesta ordem. Do contrário, utiliza o modo de qualidade normal (GDI, Graphics Device Interface). Este é o
valor padrão para aplicações criadas em versões anteriores à 4.8
· 1 - rqNormal: Força o modo de qualidade normal (GDI) para o desenho das Penas
· 2 - rqHighQuality: Força o modo de alta qualidade (GDI+) para o desenho das Penas. Este é o valor padrão para
aplicações criadas a partir da versão 4.8

4.6.3.26 ScaleFont
Determina a fonte do texto utilizada na grade. Consulte o tópico Fonte para mais informações sobre as
subpropriedades desta propriedade.

4.6.3.27 ShowBackground
Habilita ou desabilita a visualização do fundo do gráfico. Se a propriedade é igual a Verdadeiro, o fundo do gráfico
é mostrado. Caso contrário, o gráfico permanece com o fundo transparente. A cor selecionada na propriedade
BackColor não aparece se esta propriedade estiver em Falso (opção padrão). Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
E3Chart1.ShowBackground = Not E3Chart1.ShowBackground
End Sub

4.6.3.28 ShowBorder
Habilita ou desabilita uma borda externa no E3Chart, quando a visualização das escalas (propriedades
ShowBottomScale, ShowLeftScale, ShowRightScale e ShowTopScale) está desabilitada. O valor padrão desta
propriedade é Verdadeiro.

4.6.3.29 ShowBottomScale
Se a propriedade estiver configurada para Verdadeiro, o Eixo Horizontal principal é mostrado na base da grade.
Caso contrário, não é mostrado. O valor padrão é Verdadeiro. Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
oldBottomScale = E3Chart1.ShowBottomScale
MsgBox "Mostrar eixo"
E3Chart1.ShowBottomScale = True
MsgBox "Esconder eixo"
E3Chart1.ShowBottomScale = False
MsgBox "Voltar..."
E3Chart1.ShowBottomScale = oldBottomScale
End Sub

4.6.3.30 ShowGridBackground
Habilita ou desabilita a visualização do fundo da grade. Se a propriedade é igual a Verdadeiro (padrão), o fundo da
grade é mostrado. Caso contrário, a grade permanece com o fundo transparente. A cor selecionada na propriedade
GridBkColor não aparece se esta propriedade estiver em Falso. Exemplo:
Sub CommandButton1_Click()
Set Chart1 = Screen.Item("E3Chart1")

Visualização 204
Chart1.ShowGridBackground = Not Chart1.ShowGridBackground
End Sub

4.6.3.31 ShowLeftScale
Se a propriedade estiver configurada para Verdadeiro, o Eixo Vertical principal é mostrado à esquerda da grade.
Caso contrário, permanece invisível. Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Chart.ShowLeftScale = Not Chart.ShowLeftScale
End Sub

4.6.3.32 ShowPopupMenu
Habilita ou desabilita a opção de mostrar o menu em tempo de execução do E3Chart. Se o valor é igual a
Verdadeiro, o menu é mostrado quando o usuário clicar com o botão direito do mouse no gráfico do E3Chart. Se o
valor é igual a Falso, o menu não é mostrado. O valor padrão desta propriedade é Verdadeiro.

4.6.3.33 ShowRightScale
Se a propriedade estiver configurada para Verdadeiro, o Eixo Vertical principal da escala é mostrado à direita da
grade. Caso contrário, permanece invisível. Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Chart.ShowRightScale = Not Chart.ShowRightScale
End Sub

4.6.3.34 ShowTitle
Se a propriedade estiver configurada para Verdadeiro, o título principal do E3Chart é visível. Caso contrário,
permanece invisível. A propriedade Title contém o título que é mostrado no E3Chart. Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
oldTitle = E3Chart1.Title
oldShowTitle = E3Chart1.ShowTitle
E3Chart1.Title = "Teste!"
MsgBox "Mostrar"
E3Chart1.ShowTitle = True
MsgBox "Esconder"
E3Chart1.ShowTitle = False
MsgBox "Voltar"
E3Chart1.Title = oldTitle
E3Chart1.ShowTitle = oldShowTitle
End Sub

4.6.3.35 ShowTopScale
Se a propriedade estiver configurada para Verdadeiro, o Eixo Horizontal principal é mostrado no topo da grade.
Caso contrário, não é mostrado. O valor padrão é Falso. Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Chart.ShowTopScale = Not Chart.ShowTopScale
End Sub

4.6.3.36 TimeSpan
Indica a escala de tempo que aparece no Eixo Horizontal principal do E3Chart, quando este é configurado para
mostrar a escala de tempo real. O valor desta propriedade é sempre em segundos. O valor padrão desta
propriedade é 60.

4.6.3.37 Title
Determina o título principal do E3Chart. Para que o título apareça no E3Chart, a propriedade ShowTitle deve ser
configurada para Verdadeiro.

4.6.3.38 TitleColor
Determina a cor do texto do título do E3Chart.

205 Visualização
4.6.3.39 TitleFont
Determina a fonte do título principal do E3Chart. Consulte o tópico Fonte para mais informações sobre as
subpropriedades desta propriedade.

4.6.3.40 VerAxisTitle
Determina o título do Eixo Vertical principal.

4.6.3.41 VerGrid
Determina o tipo de linha a ser aplicada na grade vertical do E3Chart. As opções disponíveis estão descritas na
tabela a seguir.
Opções disponíveis para VerGrid
OPÇÃO DESCRIÇÃO
0 - Solid Aplica uma linha sólida na grade vertical do E3Chart

1 - Dash Aplica uma linha tracejada na grade vertical do E3Chart

2 - Dot Aplica uma linha pontilhada na grade vertical do E3Chart


(padrão)

3 - Dashdot Aplica uma linha traço e ponto na grade vertical do


E3Chart

4 - Dashdotdot Aplica uma linha traço ponto ponto na grade vertical do


E3Chart

5 - Invisible Aplica uma linha invisível na grade vertical do E3Chart

4.6.3.42 VerGridColor
Determina a cor da linha do Eixo Vertical principal da grade. O valor padrão desta propriedade é cinza (RGB(192,
192, 192)).

4.6.3.43 VerMinorTicks
Determina o número de subdivisões entre as marcas do Eixo Vertical principal da grade. O valor padrão desta
propriedade é 1 (um).

4.6.3.44 VerScaleBegin
Determina o valor no topo no Eixo Vertical principal da grade do E3Chart. O valor padrão desta propriedade é 100.

4.6.3.45 VerScaleEnd
Determina o valor na base do Eixo Vertical principal da grade. O valor padrão desta propriedade é -100.

4.6.3.46 VerScaleFormat
Contém um texto que representa uma máscara, dentro da qual os valores da escala vertical são mostrados. Esta
máscara pode representar vários tipos de valores:
· Geral: Não possui formatação especifica, adaptando-se automaticamente ao valor especificado
· Número: Apresenta números com parte inteira e fracionária. O usuário pode optar por até 15 casas decimais, por
usar ou não um separador de milhares e por apresentar números negativos com sinal ou entre parênteses. Para
números muito grandes ou muito pequenos, recomenda-se utilizar o formato Científico
· Data: Apresenta valores numéricos de data e hora (quando válidos). Para representar apenas a hora, use o
formato equivalente
· Hora: Apresenta valores numéricos de hora e data (quando válidos). Para representar apenas a data, use o
formato equivalente
· Porcentagem: Multiplica o número por 100 e adiciona o símbolo de porcentagem. Admite até 15 casas decimais
· Científico: Apresenta o número em notação de mantissa e expoente. Ideal para números de magnitude variada.
Admite até 15 casas decimais
· Especial: Permite formatar números inteiros em bases não decimais (hexadecimal, octal e binária, por exemplo)

Visualização 206
· Outro: Permite editar diretamente o código de formatação desejado, ou selecionar um formato criado
anteriormente

A máscara destes formatos, como exemplificado no campo Tipo, é exibida na Janela de Propriedades (por exemplo,
d/M/yy H:mm, 0E-00, etc.).

4.6.3.47 VerTickUnit
Determina o número de subdivisões entre as marcas da grade. Quando esta propriedade estiver com o valor 0
(zero), o espaçamento é automático. Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
Old = E3Chart1.VerTickUnit
For i = 0 To 30 Step 10
E3Chart1.VerTickUnit = i
MsgBox "E3Chart1.VerTickUnit = " & CStr(i)
Next
MsgBox "Voltar"
E3Chart1.VerTickUnit = Old
End Sub

4.6.4 Coleção de Consultas


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Consultas
(DispQueryCollection). Este objeto não possui eventos associados.

4.6.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Consultas (DispQueryCollection).

4.6.4.1.1 AddQuery
AddQuery(QueryName, [Unused])
Adiciona uma Consulta na Coleção de Consultas do E3Chart. Este método possui os parâmetros QueryName, que
determina o nome da Consulta que está sendo adicionada, e Unused, que é opcional, obsoleto e não deve ser
informado. Consulte a propriedade geral Name para mais informações sobre os caracteres permitidos nos nomes de
objetos.

4.6.4.1.2 Item
Item(Index)
Este método retorna um objeto Consulta da Coleção de Consultas, especificado pelo índice. Este método possui o
parâmetro Index, que pode ser do tipo numérico (se corresponder ao índice da Consulta) ou texto (se corresponder
ao nome da Consulta).

4.6.4.1.3 Remove
Remove(Index)
Remove o objeto Consulta especificado pelo nome ou pelo índice da Coleção de Consultas. Este método possui o
parâmetro Index, que pode ser do tipo numérico (se corresponder ao índice da Consulta) ou texto (se corresponder
ao nome da Consulta).

4.6.4.1.4 UpdateData
UpdateData()
Atualiza os dados de todas as Consultas. Exemplo:
Sub Texto1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
E3Chart1.Queries.UpdateData()
End Sub

4.6.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Consultas (DispQueryCollection).

207 Visualização
4.6.4.2.1 Count
Contém o número de Consultas do E3Chart. Esta propriedade é somente de leitura.

4.6.5 Coleção de Eixos


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Eixos (AxisCollection). Este
objeto não possui eventos associados.

4.6.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Eixos (AxisCollection).

4.6.5.1.1 AddAxis
AddAxis(AxisName)
Adiciona um novo Eixo com o nome determinado no parâmetro AxisName e retorna o Eixo criado. Caso se tente criar
um Eixo com um nome que já existe, é mostrada uma mensagem de erro. Querendo-se que o nome seja gerado
automaticamente, deve se passar o parâmetro AxisName em branco. Consulte a propriedade geral Name para mais
informações sobre os caracteres permitidos nos nomes de objetos.

4.6.5.1.2 Item
Item(Index)
Retorna um Eixo através de seu nome ou índice, indicado pelo parâmetro Index. O índice 0 (zero) é sempre o Eixo
Horizontal principal, o índice 1 (um) é sempre o Eixo Vertical principal e o índice 2 (dois) é sempre o Eixo Automático
principal.

4.6.5.1.3 Remove
Remove(Index)
Remove o Eixo através de seu nome ou índice, conforme especificado no parâmetro Index. Os Eixos 0 (zero, Eixo
Horizontal), 1 (um, Eixo Vertical) e 2 (dois, Eixo Automático) não podem ser removidos. Caso se tente removê-los, uma
mensagem de erro é exibida.

4.6.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Eixos (AxisCollection).

4.6.5.2.1 AutoAxis
Retorna o Eixo Automático principal. Este Eixo também participa da lista de Eixos. Esta propriedade é somente de
leitura.

4.6.5.2.2 Count
Retorna o número de Eixos do E3Chart, incluindo os Eixos principais (Horizontal, Vertical e Automático). Esta
propriedade é somente de leitura.

4.6.5.2.3 HorAxis
Retorna o Eixo Horizontal principal. Este Eixo também participa da lista de Eixos. Esta propriedade é somente de
leitura.

4.6.5.2.4 VerAxis
Retorna o Eixo Vertical principal. Este Eixo também participa da lista de Eixos. Esta propriedade é somente de
leitura.

4.6.5.3 Eixo
Esta seção contém informações sobre métodos e propriedades do objeto Eixo (Axis). Este objeto não possui eventos
associados.

Visualização 208
4.6.5.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Eixo (Axis).

NOTA
As propriedades AutoAxis, HorAxis e VerAxis são propriedades da Coleção de Eixos que acessam os Eixos padrão
Automático, Horizontal e Vertical, respectivamente. Por exemplo, ao invés de utilizar
"Chart.Axes.Item('EixoHorizontal')", pode-se utilizar "Chart.Axes.HorAxis". Os demais Eixos criados pelo usuário devem
ser acessados por seus nomes usando o método Item.

4.6.5.3.1.1 GetHistoricPeriod
GetHistoricPeriod(Begin, End)
Retorna o intervalo de tempo mostrado na escala histórica. O parâmetro Begin indica a data inicial da escala histórica
e End indica a data final.

4.6.5.3.1.2 GetMinMax

GetMinMax(Min, Max)
Retorna nos parâmetros Min e Max os valores mínimo e máximo da escala numérica, respectivamente.

4.6.5.3.1.3 GetRealTimePeriod
GetRealTimePeriod(Period)
Retorna a unidade de tempo configurada na escala de tempo real. O parâmetro Period recebe o valor da escala de
tempo. As unidades de tempo disponíveis estão descritas na tabela a seguir.
Unidades de tempo disponíveis
VALOR DESCRIÇÃO
0 - tuSeconds Unidade de tempo em segundos

1 - tuMinutes Unidade de tempo em minutos

2 - tuHours Unidade de tempo em horas

3 - tuDays Unidade de tempo em dias

4 - tuWeeks Unidade de tempo em semanas

5 - tuMonths Unidade de tempo em meses

6 - tuYears Unidade de tempo em anos

4.6.5.3.1.4 GetTickSpacing
GetTickSpacing(TickSpacing)
Retorna a unidade de tempo configurada para o espaçamento entre as divisões da escala (ticks) indicado pelo
parâmetro TickSpacing. Os valores retornados por este método estão descritos no método GetRealTimePeriod.

4.6.5.3.1.5 SetHistoricPeriod
SetHistoricPeriod(Begin, End)
Configura o período de tempo para a escala histórica. O parâmetro Begin determina o período inicial da escala e End
determina o período final da escala.

4.6.5.3.1.6 SetMinMax
SetMinMax(Min, Max)
Configura os valores mínimo e máximo da escala numérica. O valor mínimo é determinado pelo parâmetro Min e o
máximo por Max.

209 Visualização
4.6.5.3.1.7 SetRealTimePeriod

SetRealTimePeriod(Times, TimeUnit)
Ajusta o intervalo de tempo definido no parâmetro Times na unidade da escala definida pelo parâmetro TimeUnit. As
opções disponíveis para o parâmetro TimeUnit estão descritas no método GetRealTimePeriod. O Eixo permanece
sendo atualizado sempre neste modo (tempo real).

4.6.5.3.1.8 SetTickSpacing
SetTickSpacing(TickSpacing, TimeUnit)
Configura o espaçamento entre as divisões da escala (ticks) determinado pelo parâmetro TickSpacing usando a
unidade de tempo indicada pelo parâmetro TimeUnit. Caso a escala seja numérica, a unidade de tempo não é
considerada. As opções disponíveis para o parâmetro TimeUnit estão descritas no método GetRealTimePeriod.

4.6.5.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Eixo (Axis).

NOTA
As propriedades AutoAxis, HorAxis e VerAxis são propriedades da Coleção de Eixos que acessam os Eixos padrão
Automático, Horizontal e Vertical, respectivamente. Por exemplo, ao invés de utilizar
"Chart.Axes.Item('EixoHorizontal')", pode-se utilizar "Chart.Axes.HorAxis". Os demais Eixos criados pelo usuário devem
ser acessados por seus nomes usando o método Item.

4.6.5.3.2.1 Color
Determina a cor principal do Eixo.

4.6.5.3.2.2 EnableScaleColor
Esta propriedade, quando habilitada, especifica que a escala é desenhada com a mesma cor da Pena selecionada.
Esta propriedade só está disponível para Eixos criados automaticamente para Penas do tipo Automática e seu valor
padrão é Verdadeiro.

4.6.5.3.2.3 EnableTextColor
Esta propriedade, quando habilitada, especifica que o texto do Eixo tem a mesma cor da escala configurada na
propriedade Color. Se desabilitada, o texto do Eixo tem a mesma cor configurada na propriedade ForeColor do
E3Chart. O valor padrão desta propriedade é Falso.

4.6.5.3.2.4 Format
Determina a formatação dos valores do Eixo. Os formatos permitidos nesta propriedade estão descritos no Manual
do Usuário do E3, no tópico Telas e Objetos de Tela - Formatação de Valores, ou em branco para selecionar o
modo Automático. Esta propriedade permite utilizar o caractere de barra vertical (|) na String de formatação como
uma quebra de linha.
Se a formatação do Eixo é selecionada como Automática (Janela de Propriedades do Eixo, aba Escala, grupo
Formatação) e o tipo de escala é selecionado como Mostrar último período (tempo real) ou Intervalo de tempo
(histórico), o formato de data e hora obedece a configuração regional do usuário do Windows. Se o tipo de escala é
selecionado como Escala numérica, utiliza-se a formatação automática de números.

4.6.5.3.2.5 GridColor
Determina a cor das linhas da grade. O valor padrão desta propriedade é prata (RGB(192, 192, 192)).

4.6.5.3.2.6 GridStyle
Determina o estilo da linha da grade. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para GridStyle
OPÇÃO DESCRIÇÃO
0 - solid O estilo da linha da grade é sólida

Visualização 210
OPÇÃO DESCRIÇÃO
1 - dash O estilo da linha da grade é pontilhada

2 - dot O estilo da linha da grade é tracejada (padrão)

3 - dashdot O estilo da linha da grade é pontilhada e tracejada

4 - dashdotdot O estilo da linha da grade é traço-ponto-ponto

5 - invisible Não há linhas visíveis na grade (invisível)

4.6.5.3.2.7 Inverse
Inverte a ordem dos valores mínimo e máximo na escala numérica. Normalmente, em escalas verticais, o valor
mínimo aparece abaixo e o valor máximo acima. Nas escalas horizontais, o valor mínimo aparece na esquerda e o
valor máximo na direita. Quando a propriedade Inverse está configurada para Verdadeiro, no entanto, esta ordem é
invertida, valores máximos abaixo ou à esquerda e valores mínimos acima ou à direita.

4.6.5.3.2.8 MinorTicks
Determina o número total de subdivisões entre as escalas.

4.6.5.3.2.9 Mirror
Indica o espelhamento do Eixo. Se a propriedade estiver configurada para Verdadeiro, o Eixo é espelhado no lado
oposto do Eixo original. Caso contrário, o Eixo permanece na mesma posição.

4.6.5.3.2.10 Name
Determina o nome do Eixo. Consulte a propriedade geral Name para mais informações sobre os caracteres
permitidos no nome deste objeto.

4.6.5.3.2.11 NormalBandColor
Determina a cor da banda de referência. O valor padrão desta propriedade é cinza (RGB(128, 128, 128)).

4.6.5.3.2.12 NormalBandHighValue
Determina o valor superior da banda de referência.

4.6.5.3.2.13 NormalBandLowValue
Determina o valor inferior da banda de referência.

4.6.5.3.2.14 NormalBandVisible
Determina a visibilidade da banda de referência. O valor padrão desta propriedade é Falso, ou seja, a banda de
referência não é visível.

4.6.5.3.2.15 Position
Determina a posição do Eixo em relação à grade do E3Chart. As opções disponíveis estão descritas na tabela a
seguir.
Opções disponíveis para Position
OPÇÃO DESCRIÇÃO
0 - axpLeft O Eixo é posicionado à esquerda da escala

1 - axpRight O Eixo é posicionado à direita da escala (padrão)

2 - axpTop O Eixo é posicionado no topo da escala

3 - axpBottom O Eixo é posicionado na base da escala

4.6.5.3.2.16 ReferenceLineColor
Determina a cor da linha de referência. O valor padrão desta propriedade é cinza (RGB(128, 128, 128)).

211 Visualização
4.6.5.3.2.17 ReferenceLineStyle
Determina o estilo da linha de referência. Os valores possíveis para esta propriedade são 0: Sólida, 1: Tracejada, 2:
Pontilhada, 3: Traço-Ponto ou 4: Traço-Ponto-Ponto. O valor padrão desta propriedade é 0: Sólida.

4.6.5.3.2.18 ReferenceLineValue
Determina o valor usado como referência para a linha.

4.6.5.3.2.19 ReferenceLineVisible
Determina a visibilidade da linha de referência. O valor padrão desta propriedade é Falso, ou seja, a linha de
referência não é visível.

4.6.5.3.2.20 ReferenceLineWidth
Determina a espessura da linha de referência. O valor padrão desta propriedade é 1 (um) pixel.

4.6.5.3.2.21 ScaleType
Determina o tipo de escala mostrada pelo Eixo. As opções disponíveis neste item estão descritas na tabela a
seguir.
Opções disponíveis para ScaleType
OPÇÃO DESCRIÇÃO
0 - atNumberScale Escala numérica (padrão)

1 - atLastPeriod Mostra último período (Tempo Real)

2 - atPeriod Intervalo de tempo (Histórica)

4.6.5.3.2.22 ShowGrid
Determina se as linhas da grade são visíveis ou não. Se a propriedade estiver configurada para Verdadeiro, as
linhas da grade são mostradas. Caso contrário, as linhas são escondidas.

4.6.5.3.2.23 Title
Determina o título do Eixo.

4.6.5.3.2.24 UsePenEUAsTitle
Esta propriedade, quando habilitada, copia a unidade de engenharia da Pena selecionada e a utiliza como título do
Eixo, sobrescrevendo a propriedade Title. Esta propriedade só está disponível para Eixos criados automaticamente
para Penas do tipo Automática e seu valor padrão é Verdadeiro.

4.6.5.3.2.25 Visible
Determina a visibilidade do Eixo na grade. Se a propriedade estiver configurada para Verdadeiro, o Eixo é visível na
grade. Caso contrário, o Eixo permanece invisível.

4.6.6 Coleção de Penas


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Penas (DispPenCollection). Este
objeto não possui eventos associados.

4.6.6.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Penas (DispPenCollection).

NOTA
A Coleção de Penas do E3Chart deve ser acessada através da propriedade Pens.

Visualização 212
4.6.6.1.1 AddPen
AddPen(PenName)
Este método adiciona uma nova Pena ao E3Chart, retornando a Pena criada. Consulte a propriedade geral Name para
mais informações sobre os caracteres permitidos nos nomes de objetos. Exemplo:
Sub CommandButton1_Click()
' Cria uma pena sem nome.
Set Pen = Screen.Item("E3Chart1").Pens.AddPen("")
MsgBox Pen.Name
End Sub

SubCommandButton1_DblClick()
' Cria uma pena com o nome "Pen1".
' Se o nome existir, a pena é incrementada.

Set Pen = Screen.Item("E3Chart1").Pens.AddPen("Pen1")


MsgBox Pen.Name
End Sub

Sub CommandButton2_Click()
' Cria uma pena e associa a TagDemo1.
Set Chart = Screen.Item("E3Chart1")
Set Pen = Chart.Pens.AddPen("")
MsgBox Pen.Name
Pen.UsetimeStamp = True
Pen.YLink = "Dados.TagDemo1"
Pen.Connect()
End Sub

4.6.6.1.2 ChangePenPos
ChangePenPos(Source, Dest)
Modifica a ordem de desenho das Penas no E3Chart. Este método possui os seguintes parâmetros:
· Source: Determina o índice da Pena a ser movida, começando em um
· Dest: Determina o destino da Pena, começando em um

Uma situação em que este método é especialmente útil é quando tem-se uma Pena com o desenho de linha e outra
com o desenho de área. Se a Pena de área é desenhada depois da Pena de linha, aquela pode esconder esta última.
A solução então seria inverter a ordem de desenho destas Penas. Exemplo:
Sub CommandButton1_Click()
' Move a Pena 1 para a posição 2.
Screen.Item("E3Chart1").Pens.ChangePenPos(1, 2)
End Sub

4.6.6.1.3 Item
Item(Index)
Este método retorna um objeto Pena desta Coleção de Penas, especificado pelo índice. Este método possui o
parâmetro Index, que pode ser do tipo numérico se corresponder ao índice da Pena ou texto se corresponder ao
nome da Pena. Exemplo:
Sub CommandButton1_Click()
' Obtém a primeira Pena.
Set Pen1 = Screen.Item("E3Chart1").Pens.Item(0)
End Sub

4.6.6.1.4 Remove
Remove(Index)
Remove uma Pena desta Coleção de Penas, especificada pelo nome ou pelo índice. Este método possui o parâmetro
Index, que pode ser do tipo numérico se corresponder ao índice da Pena ou texto se corresponder ao nome da Pena.

213 Visualização
4.6.6.1.5 SetCursorPos
SetCursorPos(X, [Range])
Posiciona o cursor de cada Pena do E3Chart. Equivale a utilizar o método SetCursorPos de cada uma das Penas desta
Coleção.

4.6.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Penas (DispPenCollection).

4.6.6.2.1 Count
Contém o número de Penas inseridas no E3Chart. Esta propriedade é somente de leitura.

4.6.6.3 Pena
Esta seção contém informações sobre métodos e propriedades do objeto Pena (DispChartPen). Este objeto não
possui eventos associados.

4.6.6.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Pena (DispChartPen).

4.6.6.3.1.1 AddPoint
AddPoint(ValueX, ValueY, [Quality])
Adiciona um ponto ao final do buffer de tempo real. O tamanho do buffer só é válido após a conexão da Pena. Se a
Pena é criada no E3 Studio a conexão é automática, mas se é criada via script é necessário utilizar o método Connect
após sua criação. Este método deve ser usado com Penas do tipo Tempo Real, e com a propriedade UseTimeStamp
em Falso. O parâmetro opcional Quality indica a qualidade do ponto a ser inserido. Se este parâmetro não é
informado, a qualidade do ponto é considerada boa (192). O número de pontos que podem ser adicionados a uma
Pena está relacionado ao tamanho do buffer (propriedade BufferSize da Pena).

4.6.6.3.1.2 Clear
Clear()
Apaga os dados do buffer de tempo real, sem diminuir seu tamanho. Este método não desconecta Associações nem
remove dados históricos.

NOTA
Este método não tem efeito em Penas do tipo Automática.

4.6.6.3.1.3 Connect
Connect()
Este método conecta a Pena ao servidor para receber os dados de tempo real, associando as propriedades XLink e
YLink. Se a Pena já está conectada, este método permanece inativo. Exemplo:
Sub CommandButton1_Click()
Set Pen1 = Screen.Item("E3Chart1").Pens.Item("Pen1")
Pen1.Disconnect()
Pen1.Connect()
End Sub

4.6.6.3.1.4 Disconnect
Disconnect()
Este método limpa os dados atuais e permite que a Pena não receba mais os dados de tempo real do seu Tag
associado. Se a Pena já está desconectada, este método permanece inativo. Quando este método é usado em uma
Pena do tipo Histórica e Tempo Real (propriedade DataSourceType igual a 2), remove-se a parte de tempo real,
permanecendo a parte histórica. Em tempo de execução, para que os dados de tempo real sejam mostrados
novamente é preciso utilizar o método Connect. Exemplo:
Sub CommandButton1_Click()
Set Pen1 = Screen.Item("E3Chart1").Pens.Item("Pen1")

Visualização 214
Pen1.Disconnect()
Pen1.Connect()
End Sub

4.6.6.3.1.5 GetCursorPos
GetCursorPos(X, Y)
Retorna a posição em que o cursor interceptou a Pena no E3Chart. Este método possui os parâmetros X e Y, que
correspondem às coordenadas x e y do cursor. Se este método é bem-sucedido retorna Verdadeiro, caso contrário
retorna Falso. Exemplo:
Sub CommandButton1_Click()
For Each pen In Chart.Pens
If pen.GetCursorPos(aa, bb) Then
strResult = strResult & pen.Name_
& " := " & CSTr(CDate(aa)) + _
"y " + CStr(bb) + vbNewLine
End If
Next
MsgBox strResult
End Sub

4.6.6.3.1.6 GetPoint
GetPoint(ValueX, ValueY)
Retorna as coordenadas X e Y do ponto mais próximo ao valor de entrada em ValueX. O parâmetro ValueX informa o
valor de referência para a busca do ponto, e depois recebe o valor efetivo da coordenada X do ponto mais próximo
encontrado. O parâmetro ValueY retorna o valor efetivo da coordenada Y do ponto mais próximo encontrado. Este
método retorna Verdadeiro se encontrou um ponto, e Falso caso contrário.

4.6.6.3.1.7 SetCursorPos
SetCursorPos(X, [Range])
Posiciona o cursor da Pena do E3Chart. O parâmetro X indica em qual posição o cursor deve ser posicionado, similar
ao comportamento de mover o cursor na pesquisa com o mouse. O cursor é movido para a posição mais próxima
indicada por X. O parâmetro Range é opcional e usado como validação. Se omitido, seu valor é igual a -1.0 (menos
um). O cursor só é movido se o ponto válido estiver dentro do intervalo. Qualquer valor negativo indica que o
intervalo passado não deve ser usado. Exemplo:
' Existindo um ponto válido em (x = 1, y = 10)
' e outro em (x = 4, y = 20).
SetCursorPos(2) ' move o cursor para o ponto (1, 10)
SetCursorPos(4) ' move o cursor para o ponto (4, 20)

' Quando range é usado, o cursor só é movido


' se ponto estiver dentro do range.
' Não vai mover o cursor, porque 2 está mais de 0.5 unidade
' distante do ponto mais próximo, que é 1.
SetCursorPos(2, 0.5)
' Envia o cursor para o ponto (1, 10).
SetCursorPos(2, 4)

Este método retorna Verdadeiro se o cursor foi movido, caso contrário retorna Falso.

4.6.6.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Pena (DispChartPen).

4.6.6.3.2.1 AutoQuery
Quando esta propriedade está configurada para Verdadeiro, diz-se que a Pena é do tipo Consulta Automática. O
objetivo deste tipo de Pena é diminuir o consumo de memória e o tempo de consulta. Para isto, a Pena aplica filtros
no campo E3Timestamp para trazer somente os dados necessários para dentro da área do E3Chart. Toda vez que o
período visível do E3Chart é alterado, a Pena de Consulta Automática traz os dados que estão faltando para
completar o desenho daquele período. Além disto, a Pena de Consulta Automática também completa os dados
históricos que estão faltando para conectar as partes histórica e de tempo real da Pena. Se por acaso os dados
históricos não chegarem após trinta segundos, a Consulta Automática é cancelada naquele trecho. Consulte também a
propriedade MaxGapTime para maiores detalhes.

215 Visualização
Devido ao modo como a Consulta Automática aplica filtros para o campo E3Timestamp, este tipo de Pena não está
disponível para consultas de Storage e código SQL personalizados pelo usuário, ou seja, mesmo que a propriedade
AutoQuery esteja configurada para Verdadeiro, esta propriedade não tem efeito se a Consulta é do tipo Storage.
Uma das formas de reconhecer a Consulta Automática é o desenho hachurado na tela do E3Chart. Toda vez que
aparecem hachuras no desenho, significa que naquele período está ocorrendo uma Consulta Automática. Quando o
contorno da parte hachurada estiver na cor vermelha, significa que a Consulta Automática daquele trecho está
falhando. Neste caso, o E3Chart refaz a Consulta do trecho com problemas.

NOTA
Diferentemente da parte de tempo real, onde cada Pena possui seu próprio buffer de dados, a parte histórica da
Pena é armazenada na Consulta e é compartilhada entre as Penas. Por exemplo, quando uma Consulta tem os
campos E3Timestamp, Campo1 e Campo2, estes dados permanecem armazenados na Consulta e estão à
disposição para as Penas que compartilham aquela Consulta. Com isto, a parte comum, geralmente o campo
E3Timestamp, pode ser usada por duas Penas diferentes sem que os dados sejam duplicados. No caso das Penas
de Consultas Automáticas, duas Penas diferentes podem usar a mesma tabela e, devido a escalas diferentes, podem
carregar períodos diferentes da Consulta. Nesta situação, cada Pena herda automaticamente a parte carregada pela
outra Pena.
O objeto Consulta não pode funcionar simultaneamente em modo Automático e Não Automático. Isto significa
também que se Penas diferentes, uma do tipo Consulta Automática e outra do tipo Consulta Não Automática,
queiram compartilhar a mesma Consulta, esta Consulta vai se adaptar à primeira Pena que utilizá-la, ou seja, a
propriedade AutoQuery não garante que a Consulta é do tipo Automático, dependendo também de outros fatores.

4.6.6.3.2.2 AverageY
Informa a média da Pena no intervalo, caso a propriedade EnableCalc esteja habilitada. Caso o E3Chart esteja no
modo de Pesquisa de Intervalos, mostra a média neste intervalo. Do contrário, mostra a média no intervalo entre o
início e o fim no Eixo Horizontal. Valores com qualidade ruim não são considerados caso a propriedade
ShowBadPoints esteja desabilitada. Esta propriedade é somente de leitura.

4.6.6.3.2.3 BkColor
Determina a cor de fundo usada em uma Pena cuja propriedade PenType seja igual a 3 (três, Área). O valor padrão
desta propriedade é branco (RGB(255, 255, 255)).

4.6.6.3.2.4 BufferSize
Determina o número de pontos mantidos em uma Pena do tipo Tempo Real. Após este valor, os dados mais
antigos são descartados. Esta propriedade é considerada somente após a conexão da Pena. Para maiores
informações, veja o método Connect. O valor padrão desta propriedade é 1000, e deve ser sempre maior que 0
(zero). Exemplo:
Sub CommandButton1_Click()
Set Pen1 = Screen.Item("E3Chart1").Pens.Item("Pen1")
Pen1.Disconnect()
Pen1.BufferSize = 5000
Pen1.Connect()
End Sub

4.6.6.3.2.5 Color
Determina a cor da linha da Pena no E3Chart. O valor padrão desta propriedade é vazio.

4.6.6.3.2.6 DataSourceType
Determina a origem dos dados de uma Pena. As opções disponíveis para esta propriedade estão descritas na
tabela a seguir.
Opções disponíveis para a propriedade DataSourceType
OPÇÃO DESCRIÇÃO
0 - Tempo Real Indica uma conexão desta Pena a um Tag atualizado em
tempo real

1 - Histórica Indica uma conexão desta Pena aos dados recebidos de


uma Consulta

Visualização 216
OPÇÃO DESCRIÇÃO
2 - Histórica e Tempo Real Indica uma conexão desta Pena a Tags de tempo real e
dados históricos simultaneamente

3 - Automática Indica uma conexão automática desta Pena a um


servidor, conforme um período de tempo selecionado no
Eixo Horizontal

Quando esta propriedade é igual a 0 (zero, Tempo Real), as propriedades XLink e YLink informam os links utilizados,
ou então a propriedade UseTimeStamp informa que a propriedade XLink não é usada, estando em seu lugar a
estampa de tempo da propriedade YLink. Quando esta propriedade é igual a 1 (um, Histórica), as propriedades
XField e YField informam os campos da tabela a serem usados. A propriedade QueryName indica o nome da tabela
usada. Quando esta propriedade é igual a 2 (dois, Histórica e Tempo Real), as opções 0 (zero) e 1 (um) funcionam
simultaneamente para a Pena. Quando esta propriedade é igual a 3 (três, Automática), a Pena é plotada utilizando um
Eixo automático, que recebe os limites mínimos e máximos a partir das configurações da unidade de engenharia do
Tag no servidor.

NOTA
Em tempo de execução, quando esta propriedade é alterada e a Pena deixar de mostrar os dados de tempo real, é
preciso utilizar o método Connect para que estes dados sejam mostrados novamente.

Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
MsgBox "Clique em OK para criar a Pena."
Set Pen = E3Chart1.Pens.AddPen("Pen1")
Pen.DataSourceType = 0 ' Tempo real
Pen.YLink = "Dados.TagDemo1"
Pen.UseTimeStamp = True ' Em X usa a estampa de tempo
Pen.Color = RGB(255, 0, 0)
Pen.Docstring = "Teste"
MsgBox "Clique em OK para conectar."
Pen.Connect() ' Começa a receber os dados
MsgBox "Clique em OK para enquadrar."
E3Chart1.FitPen(0)
MsgBox "Clique em OK para remover a Pena."
E3Chart1.Pens.Remove(Pen.Name)
End Sub

4.6.6.3.2.7 DigitalData
Determina o estilo de plotagem digital. Se esta propriedade está configurada em Verdadeiro, o estilo de plotagem
digital assume que a variação do dado seja de forma digital, ou seja, que seu valor em relação ao último variou
instantaneamente. Caso contrário, a variação é considerada linear e os pontos são unidos por um segmento de reta.
O valor padrão desta propriedade é Verdadeiro. Esta propriedade não tem efeito se a propriedade
EnableAutoPlotMode está configurada em Verdadeiro.

4.6.6.3.2.8 EnableAutoPlotMode
Habilita o modo automático de ligação dos pontos de uma Pena do tipo Automática. O valor padrão desta
propriedade é Verdadeiro. Ao configurar esta propriedade em Verdadeiro, a propriedade DigitalData não é utilizada
na ligação dos pontos. Se houver necessidade de sobrescrever a forma de ligação dos pontos de uma Pena
recebidos de um servidor, pode-se configurar esta propriedade em Falso e configurar a propriedade DigitalData
para a forma desejada, ou seja, configurar em Verdadeiro para uma ligação digital e em Falso para uma ligação
analógica.

4.6.6.3.2.9 EnableCalc
Habilita ou desabilita o cálculo da média, mínimos e máximos dentro do intervalo.

4.6.6.3.2.10 EnableHighLimit
Habilita ou desabilita a verificação do limite alto.

217 Visualização
4.6.6.3.2.11 EnableLowLimit
Habilita ou desabilita a verificação do limite baixo.

4.6.6.3.2.12 EU
Esta propriedade é utilizada para identificar a unidade de engenharia que o valor representa, como por exemplo
graus, metros, KW/h, etc.

4.6.6.3.2.13 HighlightMaxGapTime
Especifica se a linha que conecta visualmente a parte histórica e a parte de tempo real de uma Pena do tipo
Histórica e Tempo Real (definida em MaxGapTime) deve ter uma cor (definida na propriedade MaxGapTimeColor) e
um estilo (definido na propriedade MaxGapTimeStyle) diferenciados. O valor padrão desta propriedade é Falso.

4.6.6.3.2.14 HighLimit
Determina o limite de alarme alto.

4.6.6.3.2.15 InterpolatedBeginY
Informa o valor do ponto interpolado onde o cursor inicial cruza com a Pena. Esta propriedade é somente de leitura.

4.6.6.3.2.16 InterpolatedEndY
Informa o valor do ponto interpolado onde o cursor final cruza com a Pena. Esta propriedade é somente de leitura.

4.6.6.3.2.17 LimitPenBkColor
Determina a cor de fundo da Pena quando em alarme. O valor padrão desta propriedade é vermelho (RGB(255, 0,
0)).

4.6.6.3.2.18 LimitPenColor
Determina a cor da Pena quando em alarme. O valor padrão desta propriedade é vermelho (RGB(255, 0, 0)).

4.6.6.3.2.19 LowLimit
Determina o limite de alarme baixo.

4.6.6.3.2.20 MaxGapTime
Permite especificar um tempo limite, em segundos, a ser considerado para a conexão visual entre a parte histórica e
a parte de tempo real de uma Pena do tipo Histórica e Tempo Real. O valor padrão desta propriedade é 0 (zero).

NOTA
Esta propriedade está disponível a partir da versão 3.5. Para aplicações criadas em versões anteriores e abertas na
versão 3.5, o valor da propriedade é sempre 0 (zero).

4.6.6.3.2.21 MaxGapTimeColor
Permite configurar a cor da conexão visual entre a parte histórica e a parte de tempo real de uma Pena do tipo
Histórica e Tempo Real, definida na propriedade MaxGapTime. O valor padrão desta propriedade é vermelho
(RGB(255, 0, 0)).

4.6.6.3.2.22 MaxGapTimeStyle
Especifica o estilo da linha que estabelece uma conexão visual entre a parte histórica e a parte de tempo real de
uma Pena do tipo Histórica e Tempo Real, configurada na propriedade MaxGapTime. Os valores possíveis para esta
propriedade são os seguintes:
· 0: Sólida
· 1: Tracejada
· 2: Pontilhada (padrão)
· 3: Traço - Ponto

Visualização 218
· 4: Traço - Ponto - Ponto
· 5: Invisível

NOTA
A opção 5 (Invisível) desta propriedade só pode ser selecionada via script.

4.6.6.3.2.23 MaxY
Informa o valor máximo da Pena no intervalo, caso a propriedade EnableCalc esteja habilitada. Caso o E3Chart
esteja no modo de Pesquisa de Intervalos, mostra a média nesse intervalo. Do contrário, mostra a média no intervalo
entre o início e o fim no Eixo Horizontal. Valores com qualidade ruim não são considerados caso a propriedade
ShowBadPoints esteja desabilitada. Esta propriedade é somente de leitura.

4.6.6.3.2.24 MinY
Informa o valor mínimo da Pena no intervalo, caso a propriedade EnableCalc esteja habilitada. Caso o E3Chart
esteja no modo de Pesquisa de Intervalos, mostra a média nesse intervalo. Do contrário, mostra a média no intervalo
entre o início e o fim no Eixo Horizontal. Valores com qualidade ruim não são considerados caso a propriedade
ShowBadPoints esteja desabilitada. Esta propriedade é somente de leitura.

4.6.6.3.2.25 Name
Determina o nome da Pena. Consulte a propriedade geral Name para mais informações sobre os caracteres
permitidos no nome deste objeto.

4.6.6.3.2.26 PenLineStyle
Determina o estilo de linha da Pena. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade PenLineStyle
OPÇÃO DESCRIÇÃO
0 - LsSolid Linha sólida (padrão)

1 - LsDash Linha tracejada

2 - LsDot Linha pontilhada

3 - LsDashDot Linha traço-ponto

4 - LsDashDotDot Linha traço-ponto-ponto

5 - LsNull Sem linha

NOTA
A utilização de um valor diferente de 0 (zero, LsSolid) nesta propriedade, combinada com a utilização da
propriedade Width com valores maiores do que 1 (um), pode degradar a performance de desenho da Pena.

4.6.6.3.2.27 PenType
Determina o tipo de desenho da Pena no E3Chart:
· 0: Linha (padrão)
· 1: Ponto
· 2: Ponto e Linha
· 3: Área

4.6.6.3.2.28 QueryName
Determina o nome da Consulta que a Pena está utilizando. Esta propriedade é utilizada se a propriedade
DataSourceType está configurada em 1 (um, Histórico).

219 Visualização
4.6.6.3.2.29 ScaleX
Esta propriedade indica a escala X do E3Chart a qual a Pena está associada. A escala configurada para esta
propriedade tem orientação horizontal, ou seja, pode estar posicionada no topo ou na base do E3Chart. Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Set Pen = Chart.Pens.AddPen("PenaDoTagDemo2")
Pen.XLink = "Dados.TagDemo2"
Pen.UseTimeStamp = True
' A escala deve existir previamente.
Pen.ScaleX = "EscalaParaTagDemo2"
Pen.Connect()
End Sub

Esta propriedade não tem efeito quando a propriedade UseAutomaticAxis está configurada para Verdadeiro.

4.6.6.3.2.30 ScaleY
Esta propriedade indica a escala Y do E3Chart a qual a Pena está associada. A escala configurada para esta
propriedade tem orientação vertical, estando posicionada à esquerda ou à direita do E3Chart. Exemplo:
Sub CommandButton1_Click()
Set Chart = Screen.Item("E3Chart1")
Set Pen = Chart.Pens.AddPen("PenaDoTagDemo2")
Pen.YLink = "Dados.TagDemo2"
Pen.UseTimeStamp = True
' A escala deve existir previamente.
Pen.ScaleY = "EscalaParaTagDemo2"
Pen.Connect()
End Sub

Esta propriedade não tem efeito quando a propriedade UseAutomaticAxis está configurada para Verdadeiro.

4.6.6.3.2.31 ScanValue
Define o tempo de leitura esperado do Tag da Pena do tipo Tempo Real. Este valor é levado em conta no modo de
desenho analógico. Quando o valor ultrapassa o valor determinado por esta propriedade, considera-se que o valor
do Tag não foi alterado no intervalo. De outra forma, quando o valor desta propriedade é igual a 0 (zero), os dados
da Pena são sempre conectados com uma reta ligando os dois pontos, como se o valor estivesse variando de forma
linear. A unidade desta propriedade é em milissegundos.

4.6.6.3.2.32 ShowAverage
Habilita a exibição da média da Pena no E3Chart. Esta propriedade só tem efeito caso a propriedade EnableCalc
esteja habilitada.

4.6.6.3.2.33 ShowBadPoints
Quando esta propriedade está desabilitada, os pontos com qualidade ruim não são plotados. Se a Pena estiver
traçando linhas, as linhas que passam pelos pontos de qualidade ruim não são conectadas. Para que a qualidade dos
pontos seja levada em consideração na parte histórica da Pena, o campo nomecampo_quality deve estar selecionado
na Consulta do E3Chart. Quando esta propriedade está habilitada, todos os pontos são plotados normalmente.

4.6.6.3.2.34 ShowMinMax
Habilita a exibição dos pontos mínimo e máximo da Pena no E3Chart. Esta propriedade só tem efeito caso a
propriedade EnableCalc esteja habilitada.

4.6.6.3.2.35 UseAutomaticAxis
Esta propriedade, quando configurada em Verdadeiro, permite que a Pena seja plotada utilizando um Eixo
automático, que recebe os limites mínimos e máximos das configurações da unidade de engenharia do Tag no
servidor. Neste caso, as propriedades ScaleX (Eixo Horizontal) e ScaleY (Eixo Vertical) não são utilizadas.

4.6.6.3.2.36 UseTimeStamp
Determina que seja utilizado, para o Eixo Horizontal, o valor da estampa de tempo associada ao Eixo Vertical.
Consulte um exemplo na propriedade DataSourceType.

Visualização 220
4.6.6.3.2.37 Visible
Determina se a Pena está visível no E3Chart. Se esta propriedade está configurada para Verdadeiro, a Pena é visível
em tempo de execução. Caso contrário, a Pena permanece invisível. Exemplo:
Sub CommandButton1_Click()
Set Pen1 = Screen.Item("E3Chart1").Pens.Item("Pen1")
Pen1.Visible = Not Pen1.Visible
End Sub

4.6.6.3.2.38 Width
Determina a largura da linha da Pena no E3Chart. O valor padrão desta propriedade é 0 (zero).

NOTA
A utilização de valores maiores do que 1 (um) nesta propriedade, combinada com a utilização da propriedade
PenLineStyle com um valor diferente de 0 (zero, LsSolid), pode degradar a performance de desenho da Pena.

4.6.6.3.2.39 XField
Nome do campo da Consulta usado para plotar um dado em uma escala horizontal. Esta propriedade é usada para
Penas do tipo Histórica.

4.6.6.3.2.40 XLink
Nome do link usado para plotar um dado em uma escala horizontal. Quando o valor desta propriedade é alterado,
a Pena é automaticamente desconectada. Após a configuração, use o método Connect para que a Pena comece a
receber os dados relativos a este link. Esta propriedade é usada para Penas do tipo Tempo Real.

4.6.6.3.2.41 XMaxY
Informa o valor X relativo ao ponto MaxY. Esta propriedade é somente de leitura.

4.6.6.3.2.42 XMinY
Informa o valor X relativo ao ponto MinY. Esta propriedade é somente de leitura.

4.6.6.3.2.43 YField
Nome do campo da Consulta usado para plotar um dado em uma escala vertical. Esta propriedade é usada para
Penas do tipo Histórica.

4.6.6.3.2.44 YLink
Nome do link usado para plotar um dado em uma escala vertical. Quando o valor desta propriedade é alterado, a
Pena é automaticamente desconectada. Após a configuração, use o método Connect para que a Pena comece a
receber os dados relativos a este link.

4.6.7 Legenda
Esta seção contém informações sobre métodos e propriedades do objeto Legenda (Legend). Este objeto não possui
eventos associados.

4.6.7.1 Métodos
Na Legenda, podem ser selecionadas várias colunas. Cada coluna mostra um tipo de informação e possui um nome e
um valor correspondente. A seguir, tem-se a tabela da descrição das colunas possíveis na Legenda.
Opções disponíveis para identificação das colunas
OPÇÃO VALOR NOME DESCRIÇÃO
Cor da Pena 6 Color Mostra a cor da Pena

Descrição da Pena 5 Description Mostra a propriedade


DocString da Pena

DifX 15 DiffX Mostra a diferença entre os


cursores inicial e final

221 Visualização
OPÇÃO VALOR NOME DESCRIÇÃO
DifY 16 DiffY Mostra a diferença entre os
pontos interpolados inicial
e final no Eixo Y

EscalaX 8 ScaleX Mostra o nome da escala


associada ao Tag X

EscalaY 9 ScaleY Mostra o nome da escala


associada ao Tag Y

EscalaYMáx 20 ScaleYMax Mostra o valor máximo da


escala vertical

EscalaYMín 21 ScaleYMin Mostra o valor mínimo da


escala vertical

Estado 7 Status Mostra o status da Pena

FimX 14 XEnd Mostra a posição final do


cursor

FimY 18 YEnd Mostra o ponto interpolado


onde o cursor final cruza a
Pena

InícioX 13 XBegin Mostra a posição inicial do


cursor

InícioY 17 YBegin Mostra o ponto interpolado


onde o cursor inicial cruza a
Pena

MáximoY 12 MaxY Mostra o valor máximo da


Pena no intervalo

MédiaY 10 AverageY Mostra o valor médio da


Pena no intervalo

MínimoY 11 MinY Mostra o valor mínimo da


Pena no intervalo

Nome da pena 0 Name Mostra o nome da Pena

Nome do tag X 1 TagX Mostra o nome do Tag X


associado à Pena

Nome do tag Y 2 TagY Mostra o nome do Tag Y


associado à Pena

Unidade 19 EU Mostra a unidade


associada à Pena

Valor do tag X 3 TagXValue Mostra o valor do Tag X


associado à Pena. Este
valor é mostrado quando o
gráfico está no modo de
Pesquisa

Valor do tag Y 4 TagYValue Mostra o valor do Tag Y


associado à Pena. Este
valor é mostrado quando o
gráfico está no modo de
Pesquisa

4.6.7.1.1 ChangeColumnPos
ChangeColumnPos(Source, Dest)
Troca a posição entre duas colunas. Possui os seguintes parâmetros:
· Source: Índice da coluna a ser movida para Dest

Visualização 222
· Dest: Índice da coluna a ser movida para Source

Exemplo:
Sub CommandButton1_Click()
Screen.Item("E3Chart1").Legend.ChangeColumnPos 1, 2
End Sub

4.6.7.1.2 InsertColumn
InsertColumn(Col, Index)
Insere uma nova coluna na Legenda. Este método possui os seguintes parâmetros:
· Col: Identifica a coluna a ser inserida (ver a tabela Opções disponíveis para identificação das colunas, no início
do tópico Métodos da Legenda)
· Index: Determina a posição em que a coluna vai ser inserida

Exemplo:
Sub CommandButton1_Click()
'Mostra o nome da Pena
Screen.Item("E3Chart1").Legend.InsertColumn 0, 0
End Sub

Sub CommandButton1_Click()
'Mostra a cor da Pena
Screen.Item("E3Chart1").Legend.InsertColumn "Color", 0
End Sub

4.6.7.1.3 Item
Item(Col)
Retorna uma coluna da Legenda pelo nome ou pelo índice. O parâmetro Col determina o índice ou o nome da coluna
(ver a tabela Opções disponíveis para identificação das colunas, no início do tópico Métodos da Legenda).

4.6.7.1.4 RemoveColumn
RemoveColumn(Col)
Remove uma coluna. Este método possui o parâmetro Col, que determina a coluna a ser removida (veja a tabela
Opções disponíveis para identificação das colunas, no início do tópico Métodos da Legenda).

4.6.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Legenda (Legend).

4.6.7.2.1 BackColor
Configura ou retorna a cor de fundo da Legenda. O valor padrão desta propriedade é branco (RGB(255, 255, 255)).

4.6.7.2.2 BorderStyle
Esta propriedade determina o estilo de borda que é aplicada à Legenda do E3Chart. As opções disponíveis para
esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para BorderStyle
OPÇÃO DESCRIÇÃO
0 - lbsFlat Aplica uma borda plana na Legenda

1 - lbsRaised Aplica uma borda com um destaque na parte superior


esquerda e uma sombra na parte inferior direita da
Legenda

2 - lbsSunken Aplica uma borda com uma sombra na parte superior


esquerda e um destaque na parte inferior direita da
Legenda (padrão)

3 - lbsEtched Aplica uma borda que parece estar esculpida ao redor


da extremidade da Legenda

223 Visualização
OPÇÃO DESCRIÇÃO
4 - lbsBump Aplica uma borda com um ressalto na parte inferior
direita e parece plano na parte superior esquerda da
Legenda

4.6.7.2.3 Count
Retorna o número de colunas da Legenda.

4.6.7.2.4 EnableTextColor
Esta propriedade, quando habilitada, especifica que o texto da Legenda tem a mesma cor da Pena, configurada na
propriedade Color. O valor padrão desta propriedade é Falso.

4.6.7.2.5 Font
Esta propriedade permite configurar o nome, o estilo e o tamanho da fonte da Legenda. O valor padrão desta
propriedade é a fonte Tahoma.

4.6.7.2.6 HeaderBackColor
Define a cor de fundo das colunas do cabeçalho da Legenda.

4.6.7.2.7 HeaderBorderStyle
Define o estilo das bordas das colunas do cabeçalho da Legenda. As opções disponíveis para esta propriedade
estão descritas na tabela a seguir.
Opções disponíveis para HeaderBorderStyle
OPÇÃO DESCRIÇÃO
0 - lbsFlat Aplica uma borda plana na coluna do cabeçalho

1 - lbsRaised Aplica uma borda com um destaque na parte superior


esquerda e uma sombra na parte inferior direita da
coluna do cabeçalho

2 - lbsSunken Aplica uma borda com uma sombra na parte superior


esquerda e um destaque na parte inferior direita da
coluna do cabeçalho (padrão)

3 - lbsEtched Aplica uma borda que parece estar esculpida ao redor


da extremidade da coluna do cabeçalho

4 - lbsBump Aplica uma borda com um ressalto na parte inferior


direita e parece plano na parte superior esquerda da
coluna do cabeçalho

4.6.7.2.8 HeaderTextColor
Define a cor do texto das colunas do cabeçalho da Legenda.

4.6.7.2.9 LegendPos
Indica a posição da Legenda no E3Chart. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para LegendPos
OPÇÃO DESCRIÇÃO
0 - lgTop Mostra a Legenda no topo

1 - lgLeft Mostra a Legenda à esquerda

2 - lgBottom Mostra a Legenda na base (padrão)

3 - lgRight Mostra a Legenda à direita

Visualização 224
4.6.7.2.10 ShowAllPens
Quando a propriedade é igual a Verdadeiro, todas as Penas do E3Chart são mostradas na Legenda. A propriedade
Visible da Pena é ignorada. Quando em Falso, somente as Penas com a propriedade Visible igual a Verdadeiro são
mostradas. Exemplo:
Sub CommandButton1_Click()
Set E3Chart1 = Screen.Item("E3Chart1")
E3Chart1.Legend.ShowAllPens = Not _
E3Chart1.Legend.ShowAllPens
End Sub

4.6.7.2.11 ShowBackground
Habilita a visualização de uma cor de fundo para a Legenda, configurada na propriedade BackColor. Caso esta
propriedade esteja configurada para Falso, a Legenda mostra como fundo a cor definida na propriedade BackColor
do E3Chart.

4.6.7.2.12 ShowHeader
Determina a visibilidade do título da Legenda (cabeçalho). Se a propriedade é configurada para Verdadeiro, o título
da Legenda é mostrado. Caso contrário, o título permanece invisível.

4.6.7.2.13 Size
Determina o tamanho da Legenda. Este tamanho pode significar a altura ou largura, dependendo da posição da
Legenda.

4.6.7.2.14 TextColor
Esta propriedade especifica a cor da fonte do texto a ser exibido na Legenda. Nos scripts, utilize o método RGB do
VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto (RGB(0, 0,
0)).

4.6.7.2.15 Visible
Determina a visibilidade da Legenda. Se a opção estiver configurada como Verdadeiro, a Legenda é visível no
E3Chart. Caso contrário, permanece invisível.

4.6.7.3 Coluna da Legenda


Esta seção contém informações sobre propriedades do objeto Colunas da Legenda (LegendColumn). Este objeto não
possui eventos nem métodos associados.

4.6.7.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Colunas da Legenda (LegendColumn).

4.6.7.3.1.1 Caption
Permite definir um título para a Coluna.

4.6.7.3.1.2 Column
Retorna o identificador da Coluna. Veja a tabela Opções disponíveis para identificação das colunas, no início do
tópico Métodos da Legenda. Esta propriedade é somente de leitura.

4.6.7.3.1.3 Format
Configura o formatador usado na Coluna.

4.6.7.3.1.4 Index
Retorna a posição da Coluna na Legenda. Esta propriedade é somente de leitura.

4.6.7.3.1.5 Name
Determina o nome da Coluna. O nome das Colunas pode ser visto na Tabela de Identificação das Colunas, no
início do tópico Métodos da Legenda. Esta propriedade é somente de leitura.

225 Visualização
4.6.7.3.1.6 TextAlign
Retorna o alinhamento do texto da Coluna. As opções disponíveis para esta propriedade estão descritas na tabela
a seguir.
Opções disponíveis para TextAlign
OPÇÃO DESCRIÇÃO
0 - taLeft Alinhamento à esquerda (padrão)

1 - taRight Alinhamento à direita

2 - taCenter Alinhamento centralizado

4.6.7.3.1.7 Width
Retorna a largura da Coluna.

4.7 E3Playback
Esta seção contém informações sobre métodos e propriedades do objeto E3Playback. Este objeto não possui eventos
associados.

4.7.1 Métodos
Esta seção contém informações sobre os métodos do objeto E3Playback.

4.7.1.1 Pause
Pause()
Congela o relógio de playback no tempo atual.

4.7.1.2 Play
Play()
Inicia a reprodução dos dados no horário atual de playback, avançando o relógio de acordo com a velocidade de
reprodução atual.

4.7.1.3 Stop
Stop()
Interrompe o playback, dados de Tags e alarmes são removidos das Telas e nenhuma nova consulta é feita ao Banco
de Dados.

4.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto E3Playback.

4.7.2.1 CurrentTime
Mostra a data e a hora atual do objeto E3Playback. Esta propriedade é somente de leitura.

4.7.2.2 DBServer
Indica o nome do objeto Banco de Dados que contém os dados históricos do aplicativo.

4.7.2.3 InitialScreen
Indica a Tela que é mostrada inicialmente no E3Playback. Se esta propriedade for deixada em branco, é utilizada a
Tela ou Quadro configurado na propriedade InitialScreen do objeto Viewer.

4.7.2.4 PlaybackState
Informa o estado atual do objeto E3Playback. Esta propriedade é somente de leitura e suas opções estão descritas
na tabela a seguir.

Visualização 226
Opções da propriedade PlaybackState
OPÇÃO DESCRIÇÃO
0 - Parado O relógio de playback está parado (padrão)

1 - Reproduzindo O relógio de playback está se movendo

2 - Pausado O relógio de playback está pausado

4.8 Relatórios
Esta seção contém informações sobre eventos, métodos e propriedades do objeto Relatório (Report).

4.8.1 Eventos
Esta seção contém informações sobre os eventos do objeto Relatório (Report).

4.8.1.1 OnAfterPrint
OnAfterPrint()
Disparado após uma Seção ter sido montada no Relatório. Pode-se utilizar este evento para atualizar qualquer
contador cuja utilização seja necessária depois do Relatório ser completado.

4.8.1.2 OnBeforePrint
OnBeforePrint()
Disparado antes de uma Seção ter sido montada no Relatório. Pode-se utilizar este evento para modificar o valor de
um objeto no Relatório antes que este seja impresso. Recomenda-se que os campos da Consulta do Relatório não
sejam acessados quando este evento estiver em uso.

4.8.1.3 OnDataInitialize
OnDataInitialize()
Disparado antes do evento OnReportStart. Este evento permite acrescentar e configurar campos à coleção Fields de
um Relatório antes de sua geração. Exemplo:
Sub OnDataInitialize()
Fields.Add "Nome"
Fields.Add "Setor"
Fields.Add "Código"
End Sub

4.8.1.4 OnError
OnError(Number, Description, SCode, Source, HelpFile, HelpContext, CancelDisplay)
Disparado por um erro interno no Relatório. Se este evento não é tratado, o E3 mostra uma mensagem de erro
genérica.
Parâmetros do evento OnError
NOME DESCRIÇÃO
Number Número inteiro identificador do erro

Description String com a descrição do erro

SCode Inteiro com o código de erro do subsistema OLE (não


utilizado)

Source String com o objeto origem do erro

HelpFile String com o nome e caminho do arquivo de ajuda

HelpContext Número inteiro de contexto do tópico de ajuda referente


ao erro

CancelDisplay Booleano que indica se o erro deve ser mostrado em


uma caixa de mensagem

227 Visualização
4.8.1.5 OnFetchData
OnFetchData(eof)
Disparado toda vez que um novo registro é processado. Este evento é utilizado para executar um script que
modifique os valores dos campos adicionados ao Relatório em um script associado ao evento OnDataInitialize. O
parâmetro eof tem o valor padrão Verdadeiro e indica que após o script o processamento do registro atual do
Relatório é encerrado.

4.8.1.6 OnFormat
OnFormat()
Disparado depois que os dados são lidos e carregados no Relatório, mas antes da Seção ser preparada para
impressão. Este evento pode ser utilizado para modificar o layout da Seção do Relatório ou de qualquer outro objeto.

4.8.1.7 OnHyperlink
OnHyperlink(Button, Link)
Disparado ao clicar em um link no Relatório. Pode-se utilizar este evento para executar um script que redirecione um
link ou para configurar um link no Relatório. O parâmetro Button indica qual botão foi clicado, normalmente 1 (um), e
o parâmetro Link determina qual o endereço de destino do link.

4.8.1.8 OnNoData
OnNoData()
Disparado quando não há dados a imprimir no Relatório. Pode-se utilizar este evento para executar um script que
mostre uma mensagem de erro na tela, acusando a falta de dados para imprimir e cancelando o Relatório.

4.8.1.9 OnPageEnd
OnPageEnd()
Disparado ao final da impressão de cada página do Relatório.

4.8.1.10 OnPageStart
OnPageStart()
Disparado no início da impressão de cada página do Relatório.

4.8.1.11 OnPrintProgress
OnPrintProgress(PageNumber)
Disparado enquanto uma página do Relatório está sendo impressa. O parâmetro PageNumber indica o número da
página atual.

4.8.1.12 OnReportEnd
OnReportEnd()
Disparado no final da geração do Relatório, após finalizar a impressão.

4.8.1.13 OnReportStart
OnReportStart()
Disparado no início da geração do Relatório, antes de começar a impressão.

4.8.2 Métodos
Esta seção contém informações sobre os métodos do objeto Relatório (Report).

Visualização 228
4.8.2.1 Export
Export([ExportFilter], [ExportFileName])
Exporta um Relatório para o arquivo especificado no parâmetro ExportFileName de acordo com o filtro especificado
no parâmetro ExportFilter. Este parâmetro indica o formato para a exportação. As opções disponíveis para o
parâmetro ExportFilter são as seguintes:
· PDF: Exporta os dados para o formato PDF (Portable Document Format)
· Excel: Exporta os dados para o formato de uma planilha do Excel
· HTML: Exporta os dados para o formato HTML (Hyper Text Markup Language)
· TEXT: Exporta os dados para o formato Texto
· RTF: Exporta os dados para o formato RTF (Rich Text Format)
· TIFF: Exporta os dados para o formato TIFF (Tag Image File Format)

Ao informar o nome de um filtro e omitir o nome do arquivo, os dados são exportados utilizando-se as propriedades
em comum de cada filtro para um arquivo nomeado de forma automática e salvo no diretório do Domínio, exceto
para os filtros HTML, TEXT e RTF, onde o nome do arquivo de saída deve ser informado. Pode-se modificar as
propriedades comuns de um filtro de exportação utilizando o método GetExportFilter antes de exportar os dados.
Exemplo:
Sub Button1_Click()
Set report = Application.LoadReport("[Relatório3]")
Select case Application._
SelectMenu("PDF|Excel|HTML|Texto|RTF|TIFF|Texto(CSV)")
Case 1
Report.Export "PDF", "c:\reports\report.pdf"
MsgBox "Exportado para o formato PDF!"
Case 2
Report.Export "Excel", "c:\reports\report.xls"
MsgBox "Exportado para o formato XLS!"
Case 3
Report.Export "HTML", "c:\reports\report.html"
MsgBox "Exportado para o formato HTML!"
Case 4
Report.Export "Text", "c:\reports\report.txt"
MsgBox "Exportado para o formato Texto!"
Case 5
Report.Export "RTF", "c:\reports\report.rtf"
MsgBox "Exportado para o formato RTF!"
Case 6
Report.Export "TIFF", "c:\reports\report.tiff"
MsgBox "Exportado para o formato TIFF!"
Case 7
Set reportFilter = report.GetExportFilter("TEXT")
reportFilter.FileName = "c:\reports\report2.txt"
reportFilter.TextDelimiter = ","
report.Export reportFilter
MsgBox "Exportado para of formato Texto usando um filtro!"
End Select
End Sub

4.8.2.2 GetExportFilter
GetExportFilter(FilterName)
Retorna um objeto que especifica a personalização dos parâmetros de exportação de um Relatório. Este método
possui o parâmetro FilterName, que indica o tipo de formato para a exportação. As opções disponíveis para o
parâmetro FilterName são as seguintes:
· PDF: Exporta os dados para o formato PDF (Portable Document Format)
· Excel: Exporta os dados para o formato de planilha do Excel
· HTML: Exporta os dados para o formato HTML (Hyper Text Markup Language)
· TEXT: Exporta os dados para o formato Texto
· RTF: Exporta os dados para o formato RTF (Rich Text Format)
· TIFF: Exporta os dados para o formato TIFF (Tag Image File Format)

229 Visualização
Depois de obtido o filtro, as propriedades descritas na tabela a seguir podem ser modificadas.
Propriedades disponíveis em um filtro de exportação
PROPRIEDADE FILTRO DESCRIÇÃO
AutoRowHeight Excel Em Verdadeiro (padrão), configura a
altura da linha automaticamente. Em
Falso, configura a altura para o maior
elemento na linha

BorderSpace Excel Espaçamento mínimo entre as células.


O valor padrão é de 59 twips

CreateCSSFile HTML Em Verdadeiro, gera um arquivo CSS


no diretório indicado por
HTMLOutputPath

DoubleBoundaries Excel Em Verdadeiro, indica que os


elementos alinhados à direita devem
repor os alinhados à esquerda na
mesma coluna. Caso contrário, deixe
em Falso para liberar mais espaço

ExportRange HTML Indica uma faixa de páginas para


serem exportadas, como por
exemplo "1, 2, 3-9, 14"

FaxExport TIFF Objeto que permite exportar os


dados no formato RFC 1314 TIFF

FileName Todos Informa o nome do arquivo para o


qual os dados são exportados

GenPageBreaks HTML Em Verdadeiro, posiciona quebras de


página abaixo do elemento mais
inferior em cada página do Relatório

HTMLOutputPath HTML Caminho padrão para os arquivos


HTML

JPGQuality PDF Indica o nível de qualidade das


imagens exportadas, entre 0 (zero) e
100

MinColumnWidth Excel Tamanho mínimo da coluna. O valor


padrão é 1011 twips

MinRowHeight Excel Tamanho mínimo da linha

MultiSheet Excel Em Verdadeiro, cada página no


Relatório vai para uma planilha
separada

PageDelimiter TEXT Configura ou retorna o caractere


delimitador entre páginas

SuppressEmptyLines TEXT Retira ou insere linhas vazias, para


efeito de layout

TextDelimiter HTML Configura ou retorna o caractere


delimitador entre os textos

TrimEmptySpace Excel Em Verdadeiro, o espaço vertical


entre os elementos é eliminado. O
padrão é Falso

Unicode TEXT Determina se o texto é salvo em


formato Unicode (16 bits) ou não

Visualização 230
PROPRIEDADE FILTRO DESCRIÇÃO
WebCacheOutput HTML Em Verdadeiro, o Relatório é
exportado para o serviço de
WebCache. Caso contrário (padrão),
não é exportado

4.8.2.3 Print
Print()
Imprime um Relatório.

4.8.2.4 PrintPreview
PrintPreview([Left], [Top], [Width], [Height])
Gera uma prévia de impressão de Relatório na tela. Se o Relatório é mostrado corretamente na tela, retorna
Verdadeiro. Caso o usuário clique em Cancel ou aconteça algum erro, retorna Falso. Os parâmetros Left e Top indicam
a posição da prévia de impressão, em pixels, a partir do canto superior esquerdo da tela. Os parâmetros Width e
Height indicam o tamanho da prévia de impressão na tela, em pixels ou em Himetric. Todos os parâmetros são
opcionais. Exemplo:
Sub CommandButton1_Click()
Set report = Application.LoadReport("[Relatório1]")
Inicio = Application.GetObject("Dados.Grafico.datai").Value
Final = Application.GetObject("Dados.Grafico.dataf").Value
report.Item("Consulta1").SetVariableValue "Ini", Inicio
report.Item("Consulta1").SetVariableValue "Fim", Final
report.PrintPreview()
End Sub

NOTAS
· Este método não está disponível para Relatórios carregados usando o método LoadReport do Servidor.
· Este método corresponde ao Pick Imprimir Relatório.
· Se os parâmetros Left e Top não são definidos, a prévia de impressão é mostrada na posição (0, 0).
· Se os parâmetros Width e Height não são definidos, a prévia de impressão é criada com o tamanho de 500 x 500
pixels e a janela é aberta maximizada. Se apenas um dos parâmetros é definido, o outro parâmetro é configurado
para 500 pixels e a janela não é aberta maximizada.
· Os valores de tamanho neste método podem ser informados como números ou Strings. No caso de números, são
considerados em pixels. No caso de Strings, se acompanhados da unidade "hm", são interpretados como
Himetric. Qualquer outro caso é considerado em pixels.

4.8.2.5 Query
Query()
Retorna o objeto Consulta atualmente selecionado no Relatório. Para mais informações a respeito deste objeto, veja o
capítulo Consultas. Exemplo:
Sub Rect_Click()
Set Query = Application.LoadReport("[Relatório3]").Query()
Query.SetVariableValue("Chave1", "XYZ")
End Sub

4.8.3 Propriedades
Para criar um script no Relatório, utiliza-se o Editor de Scripts do Relatório, aberto ao clicar em Editor de Scripts e,
para visualizar o Relatório, clique em Gerar Relatório, Ambas opções estão localizadas na barra de ferramentas do
Relatório.
Os scripts do Relatório utilizam alguns procedimentos, dependendo do objeto ou da Seção onde se deseja incluir o
código. Por exemplo:
Report.Sections("PageHeader").Controls("E3Chart1")._
GridBkColor= RGB(255, 0, 255).

Onde:
· PageHeader: Nome da Seção onde o objeto está incluído no Relatório

231 Visualização
· E3Chart1: Nome do objeto que está dentro da Seção especificada, neste caso PageHeader
· GridBkColor: Nome da propriedade do objeto, neste caso E3Chart1
· RGB(255, 0, 255): Parâmetro ou ação da propriedade. Neste caso, mudar a cor de fundo do gráfico para rosa

Sendo assim, para criar um script no Relatório use o seguinte conceito:


Report.Sections("NomeDaSeção").Controls("NomeDoObjeto")._
NomeDaPropriedade = parâmetros_da_propriedade

NOTA
O objeto Relatório (Report) encapsula um objeto ActiveReports (ou AR), que é o Relatório propriamente dito.

4.8.3.1 Caption
Contém o título do Relatório que aparece na barra de título da janela de visualização (preview). O valor padrão
desta propriedade é uma String vazia.

4.8.4 Layout
Esta seção contém informações sobre propriedades do objeto Layout do Relatório (ActiveReport). Este objeto não
possui eventos nem métodos associados.

4.8.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Layout do Relatório (ActiveReport).

NOTA
As propriedades aqui descritas são parte do objeto ActiveReport (ou AR) que é encapsulado no objeto Relatório.
Estas propriedades são válidas apenas dentro do escopo do AR e não podem ser acessadas fora deste objeto.

4.8.4.1.1 _PageBottomMargin
Determina a margem inferior do Relatório, em twips (um twip é igual a 1/1440 de uma polegada). O valor padrão
desta propriedade é 1440 (uma polegada ou 2,54 cm).

4.8.4.1.2 _PageLeftMargin
Determina a margem esquerda do Relatório, em twips (um twip é igual a 1/1440 de uma polegada). O valor padrão
desta propriedade é 1440 (uma polegada ou 2,54 cm).

4.8.4.1.3 _PageRightMargin
Determina a margem direita do Relatório, em twips (um twip é igual a 1/1440 de uma polegada). O valor padrão
desta propriedade é 1440 (uma polegada ou 2,54 cm).

4.8.4.1.4 _PageTopMargin
Determina a margem superior do Relatório, em twips (um twip é igual a 1/1440 de uma polegada). O valor padrão
desta propriedade é 1440 (uma polegada ou 2,54 cm).

4.8.4.1.5 AllowSplitters
Permite que a tela de visualização do Relatório seja dividida em duas partes. Esta propriedade não pode ser
alterada com o objeto ativo. Se a propriedade estiver configurada para Falso (valor padrão), a barra para divisão não
aparece na tela.

4.8.4.1.6 documentName
Determina o nome do documento para o Relatório. Este nome aparece no gerenciador de impressão e pode ser
usado para identificar mais facilmente o Relatório. O valor padrão desta propriedade é "ActiveReports Document".

4.8.4.1.7 MaxPages
Estabelece o número máximo de páginas para o Relatório. Quando este número é alcançado, o E3 para de
processar o documento. O valor padrão desta propriedade é 10.

Visualização 232
4.8.4.1.8 ParentReport
Esta propriedade é uma variável de uso interno e contém uma referência para o objeto Relatório. Esta propriedade
é somente de leitura e válida apenas para os eventos OnDataInitialize e OnReportEnd.

4.8.4.1.9 PrintWidth
Determina a largura da área de impressão do Relatório, em twips. Se o tamanho do Relatório é mudado em tempo
de execução, a largura de impressão também deve ser ajustada, para garantir que o Relatório ocupe toda a área de
impressão. O tamanho da área de impressão deve também incluir a largura das margens, para que o Relatório não
ultrapasse o tamanho do papel. Se isto acontecer, o erro é assinalado por uma linha pontilhada vermelha impressa
em cada página do Relatório.

4.8.4.1.10 RulerVisible
Quando configurada em Verdadeiro, esta propriedade indica que são mostradas uma régua vertical e outra
horizontal na janela de visualização do Relatório. Do contrário, as réguas permanecem invisíveis.

4.8.4.1.11 ScriptDebuggerEnabled
Habilita ou desabilita o depurador do ActiveReports (JIT), para depurar os scripts associados aos Relatórios. Este
depurador não está disponível em todo o E3, apenas nos Relatórios.

4.8.4.1.12 ScriptLanguage
Indica a linguagem usada para interpretar os scripts associados a um Relatório. A linguagem padrão é o VBScript,
mas JScript também pode ser utilizada.

4.8.4.1.13 ShowParameterUI
Habilita ou desabilita os parâmetros da caixa de diálogo da Consulta, que aparece quando o Relatório é executado.
Se esta propriedade estiver configurada para Verdadeiro, os parâmetros da caixa de diálogo da Consulta são
mostrados. Caso contrário, estes parâmetros não são mostrados.

4.8.4.1.14 Status
Retorna o status do Relatório. Esta propriedade é somente de leitura. As opções disponíveis para esta
propriedades estão descritas na tabela a seguir.
Opções disponíveis para a propriedade Status
OPÇÃO DESCRIÇÃO
0 - DDStatIdle Indica que o Relatório está fechado (padrão)

1 - DDStartRunning Indica que o Relatório está em execução

2 - DDStartCompleted Indica que o Relatório está completo

3 - DDStartCancelled Indica que o Relatório foi cancelado

4.8.4.1.15 TOCEnabled
Habilita ou desabilita o sumário do Relatório. Se esta propriedade estiver configurada para Verdadeiro, o sumário
do Relatório é habilitado. Do contrário, o Relatório não tem sumário. O valor padrão desta propriedade é Verdadeiro.

4.8.4.1.16 TOCVisible
Determina a visibilidade do sumário do Relatório. Se esta propriedade estiver configurada para Verdadeiro, o
sumário do Relatório é mostrado. Do contrário, o sumário permanece invisível. O valor padrão desta propriedade é
Verdadeiro.

4.8.4.1.17 ToolbarVisible
Habilita ou desabilita a barra de ferramentas da janela de prévia de impressão do Relatório. Se esta propriedade
estiver configurada para Verdadeiro, a barra é habilitada. Do contrário, não há barra de ferramentas nesta janela.

233 Visualização
4.8.4.1.18 UserData
Configura ou retorna informações específicas do usuário. Esta propriedade é similar à propriedade Tag do Visual
Basic, mas é exportada e salva em um arquivo .rpx. Pode ser usada para salvar e carregar qualquer informação
personalizada necessária ao desenho do Relatório.

4.8.4.1.19 Version
Retorna o número da versão do produto. Esta propriedade é somente de leitura.

4.8.4.1.20 WaterMark
Adiciona uma imagem de fundo, ou marca d'água, ao Relatório. As marcas d'água são textos ou figuras que
aparecem sob o texto do documento. Normalmente, estes textos ou figuras tornam o documento visualmente mais
interessante.

Exemplo de marca
d'água
O valor padrão desta propriedade é vazio (sem texto ou imagem).

4.8.4.1.21 WaterMarkAlignment
Determina o alinhamento da marca d'água no Relatório. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade WaterMarkAlignment
OPÇÃO DESCRIÇÃO
0 - ddPATopLeft Alinha a imagem ao topo e à esquerda

1 - ddPATopRight Alinha a imagem ao topo e à direita

2 - ddPACenter Alinha a imagem ao centro (padrão)

3 - ddPABottomLeft Alinha a imagem à base e à esquerda

4 - ddPABottonRight Alinha a imagem à base e à direita

4.8.4.1.22 WaterMarkPrintOnPages
Indica o número das páginas do Relatório que recebem a marca d'água. A sintaxe utilizada pode incluir uma única
página, uma extensão de páginas ou mesmo uma combinação de ambos, como por exemplo 1, 5-8, 9, 10-15.

4.8.4.1.23 WaterMarkSizeMode
Configura o efeito do tamanho da marca d'água na página do Relatório. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade WaterMarkSizeMode
OPÇÃO DESCRIÇÃO
0 - ddSMClip A marca d'água é mostrada no Relatório no seu tamanho
original

1 - ddSMStretch A marca d'água preenche toda a página do Relatório

2 - ddSMZoom A marca d'água é aumentada até atingir o tamanho da


página do Relatório

Visualização 234
4.8.5 Objetos
Esta seção contém informações sobre propriedades dos Objetos do Relatório. Estes objetos não possuem eventos
nem métodos associados.

4.8.5.1 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns aos objetos do Relatório.

4.8.5.1.1 BackColor
Especifica a cor de fundo de um objeto no Relatório. O efeito desta propriedade só é visível se a propriedade
BackStyle estiver configurada como 1 - ddBKNormal. O valor padrão desta propriedade é branco (RGB(255, 255,
255)).

NOTA
Esta propriedade não é válida para os objetos Linha e Quebra de Página.

4.8.5.1.2 BackStyle
Especifica o estilo do fundo dos objetos do Relatório. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - ddBKTransparent: Transparente (padrão, mostra a cor definida pela propriedade BackColor da Seção)
· 1 - ddBKNormal: Normal (mostra a cor definida pela propriedade BackColor do objeto)

NOTA
Esta propriedade não é válida para os objetos Linha, Código de Barras, Quebra de Página e Tabela.

4.8.5.1.3 height
Esta propriedade determina a altura de um objeto no Relatório.

NOTA
Esta propriedade não é válida para os objetos Linha e Quebra de Página.

4.8.5.1.4 left
Retorna o valor do posicionamento esquerdo de um objeto no Relatório.

NOTA
Esta propriedade não é válida para os objetos Linha e Quebra de Página.

4.8.5.1.5 Name
Determina o nome de um objeto. O valor padrão desta propriedade é uma String vazia.

4.8.5.1.6 Tag
Retorna o tipo do Tag associado a um objeto, isto é, Boolean, String, Integer, etc. Esta propriedade é somente de
leitura.

4.8.5.1.7 top
Retorna o valor do topo de um objeto. Esta propriedade é somente de leitura.

NOTA
Esta propriedade não é válida para o objeto Linha.

235 Visualização
4.8.5.1.8 Visible
Determina a visibilidade de um objeto no Relatório. Se esta propriedade estiver configurada para Verdadeiro, o
objeto é visível no Relatório. Caso contrário, o objeto está oculto. O valor padrão desta propriedade é Verdadeiro.

NOTA
Esta propriedade não é válida para o objeto Quebra de Página.

4.8.5.1.9 width
Esta propriedade determina a largura de um objeto no Relatório.

NOTA
Esta propriedade não é válida para os objetos Linha e Quebra de Página.

4.8.5.2 Código de Barras


Esta seção contém informações sobre propriedades do objeto Código de Barras do Relatório (BarCode). Este objeto
não possui eventos nem métodos associados.

4.8.5.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Código de Barras do Relatório (BarCode).

4.8.5.2.1.1 Alignment
Determina o alinhamento do texto do objeto Código de Barras no Relatório. As opções disponíveis para esta
propriedade são as seguintes:
· 0 - ddTXLeft: Alinha o texto à esquerda do objeto
· 1 - ddTXRight: Alinha o texto à direita do objeto
· 2 - ddTXCenter: Alinha o texto ao centro do objeto (padrão)

4.8.5.2.1.2 BarWidth
Determina a largura das barras do Código de Barras. Configurando a largura para 1 (um), a barra do objeto é
expandida em até 15 pontos, e assim por diante. Quanto maior o número configurado na propriedade, maior a
largura da barra do código de barras. O valor padrão desta propriedade é 1 (um).

4.8.5.2.1.3 Caption
Contém o texto do objeto Código de Barras propriamente dito. O valor padrão desta propriedade é uma String
vazia.

4.8.5.2.1.4 CaptionPosition
Especifica a posição do texto da propriedade Caption no objeto Código de Barras. As opções disponíveis para
esta propriedade são as seguintes:
· 0 - ddbcCaptionNone: O texto da propriedade Caption não aparece no Código de Barras (padrão)
· 1 - ddbcCaptionAbove: O texto da propriedade Caption aparece acima do Código de Barras
· 2 - ddbcCaptionBelow: O texto da propriedade Caption aparece abaixo do Código de Barras

4.8.5.2.1.5 DataField
Configura ou retorna o dado associado ao objeto Código de Barras. Este dado associado pode ser um campo da
tabela no Banco de Dados fornecido pelo objeto Consulta, uma expressão matemática com campos da Consulta e
funções do VBScript (neste caso, o campo deve ser precedido do símbolo de igual) ou um Tag ou propriedade do E3.
Neste caso, o valor atual da variável é mostrado ao realizar a impressão. O valor padrão desta propriedade é uma
String vazia.

NOTA
O servidor deve estar em execução para que o valor da variável possa ser capturado.

Visualização 236
4.8.5.2.1.6 Direction
Determina a orientação espacial dos Códigos de Barras. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade Direction
OPÇÃO DESCRIÇÃO
0 - ddbcLeftToRight O Código de Barras é direcionado da esquerda para a
direita (padrão)

1 - ddbcRightToLeft O Código de Barras é direcionado da direita para a


esquerda

2 - ddbcTopToBottom O Código de Barras é direcionado de cima para baixo

3 - ddbcBottomToTop O Código de Barras é direcionado de baixo para cima

4.8.5.2.1.7 EnableCheckSum
Habilita ou desabilita a leitura do valor de checksum (caractere de objeto do Código de Barras). Se esta
propriedade estiver configurada para Falso, somente códigos com checksum são afetados.

4.8.5.2.1.8 Font
Determina a fonte do objeto Código de Barras no texto estabelecido pela propriedade Caption. O valor padrão
desta propriedade é "Arial". Consulte o tópico Fonte para mais informações sobre as subpropriedades desta
propriedade.

NOTA
Esta propriedade não é usada em scripts ou em Associações, sendo editada somente via E3 Studio.

4.8.5.2.1.9 ForeColor
Especifica a cor de preenchimento de frente do objeto Código de Barras. Nos scripts, utilize o método RGB do
VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto (RGB(0, 0,
0)).

4.8.5.2.1.10 Style
Determina o estilo do Código de Barras. As opções disponíveis para esta propriedade estão descritas na tabela a
seguir.
Opções disponíveis para a propriedade Style
OPÇÃO DESCRIÇÃO
0 - ddbcNone Estilo de código de barras padrão

1 - ddbcAnsi39 Estilo de código de barras ANSI 3 de 9 (Código 39).


Utiliza letras, números, -,*, $, /, +, %, etc.

2 - ddbcAnsi39x Estilo de código de barras ANSI estendido 3 de 9


(Código estendido 39). Utiliza caracteres completos ASCII

3 - ddbcCode_2_of_5 Estilo de código de barras 2 de 5. Utiliza somente


números

4 - ddbcCode25intlv Estilo de código de barras intercalado 2 de 5. Utiliza


somente números

5 - ddbcCode25mat Estilo de código de barras Matriz 25

6 - ddbcCode39 Estilo de código de barras Código 39. Utiliza letras,


números, -,*, $, /, +, %, etc.

7 - ddbcCode39x Estilo de código de barras Código 39 estendido. Utiliza


caracteres completos ASCII

237 Visualização
OPÇÃO DESCRIÇÃO
8 - ddbcCode_128_a Estilo de código de barras Código 128 A. Utiliza
números, pontuação, ou letras

9 - ddbcCode_128_b Estilo de código de barras Código 128 B. Utiliza Strings,


números, pontuação ou letras

10 - ddbcCode_128_c Estilo de código de barras Código 128 C. Utiliza somente


números

11 - ddbcCode_128auto Estilo de código de barras Código 128 Automático.


Utiliza caracteres completos ASCII. Seleciona
automaticamente códigos entre 128 A, B e C para
configurar no código de barras o valor menor

12 - ddbcCode_93 Estilo de código de barras Código 93. Utiliza letras,


números, -,*,$, /,+,%, etc.

13 - ddbcCode_93x Estilo de código de barras Código 93 estendido. Utiliza


caracteres completos ASCII

14 - ddbcMSI Estilo de código de barras Código MSI. Utiliza somente


números

15 - ddbcPostNet Estilo de código de barras PostNet. Utiliza somente


números com um dígito de verificação

16 - ddbcCodabar Estilo de código de barras Codabar. Utiliza A, B, C, D, +, -


, :, /, ou números

17 - ddbcEAN_8 Estilo de código de barras EAN-8. Utiliza somente


números (sete números e dígito de verificação)

18 - ddbcEAN_13 Estilo de código de barras EAN-13. Utiliza somente


números (12 números e dígito de verificação)

19 - ddbcUPC_A Estilo de código de barras UPC-A. Utiliza somente


números (11 números e dígito de verificação)

20 - ddbcUPC_EO Estilo de código de barras UPC-E1. Utiliza somente


números. Usado para símbolos de compressão-zero
UPC. Na propriedade Caption, pode-se digitar seis
dígitos do código UPC-E ou 11 dígitos. Se um código
com 11 dígitos é inserido, o código de barras converte
para seis dígitos UPC-E, se possível. Senão, converte-se
de 11 para seis dígitos UPC-E e nada é mostrado

21 - ddbcUPC_E1 Estilo de código de barras UPC-E1. Utiliza somente


números. A largura da entrada de dados do UPC E1 é de
seis caracteres numéricos

22 - ddbcRM4SCC Estilo de código de barras Royal Mail RM4SCC. Utiliza


somente letras e números com dígito de verificação. Este
código de barras é utilizado no Reino Unido

23 - ddbcUCCEAN128 Estilo de código de barras UCC/EAN_128. Utiliza


caracteres completos ASCII. A versão especial do código
128 é usado na aplicação HIBC

4.8.5.3 E3Chart
Esta seção contém informações sobre propriedades do objeto E3Chart do Relatório.

4.8.5.3.1 Propriedades
Exemplo de utilização das propriedades do E3Chart em um Relatório
Os scripts a seguir devem ser criados na Seção PageHeader do Relatório, utilizando o evento OnBeforePrint.
Exemplos:
Sub OnBeforePrint
' Usando um E3Chart em um Relatório

Visualização 238
Set chart = _
Report.Sections("PageHeader").Controls("E3Chart1")
chart.LoadData()
chart.FitAll
End Sub

Sub OnBeforePrint
' Este script copia as configurações do objeto
' E3Chart chartfrom para o E3Chart chart
' que é utilizado no Relatório.
Set chartfrom = _
Application.GetFrame().Screen.Item("E3Chart1")
Set chart = _
Report.Sections("PageHeader").Controls("E3Chart2")
chart.CopyConfig(chartfrom)
chart.LoadData()
chart.FitAll
End Sub

NOTA
A descrição das propriedades do E3Chart no Relatório são as mesmas explicadas no tópico Visualização - E3Chart
- Propriedades.

4.8.5.4 Elipse, Retângulo e Retângulo Arredondado


Esta seção contém informações sobre propriedades dos objetos Elipse, Retângulo e Retângulo Arredondado do
Relatório (Shape). Estes objetos não possuem eventos nem métodos associados.

4.8.5.4.1 Propriedades
Esta seção contém informações sobre as propriedades dos objetos Elipse, Retângulo e Retângulo Arredondado do
Relatório (Shape).

4.8.5.4.1.1 LineColor
Especifica a cor da linha dos objetos Elipse, Retângulo e Retângulo Arredondado. O valor padrão desta
propriedade é preto (RGB(0, 0, 0)).

4.8.5.4.1.2 LineStyle
Determina o estilo da linha dos objetos Elipse, Retângulo e Retângulo Arredondado. As opções disponíveis para
esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade LineStyle
OPÇÃO DESCRIÇÃO
0 - ddLSTransparent A linha permanece transparente

1 - ddLSSolid A linha aparece sólida (padrão)

2 - ddLSDash A linha aparece tracejada

3 - ddLSDot A linha aparece pontilhada

4 - ddLSDashDot A linha aparece com um padrão de traço e ponto

5 - ddLSDashDotDot A linha aparece com um padrão de traço, ponto e ponto

4.8.5.4.1.3 LineWeight
Especifica a largura da linha dos objetos Elipse, Retângulo e Retângulo Arredondado. Configurando a largura para 1
(um), a linha do objeto é expandida em até 15 pontos. Configurando a largura para 2 (dois), a linha é expandida em
até 30 pontos, e assim por diante. Quanto maior o número configurado na propriedade, maior a largura do objeto. O
valor padrão desta propriedade é 1 (um).

4.8.5.4.1.4 Shape
Permite alterar a forma dos objetos Elipse, Retângulo e Retângulo Arredondado. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.

239 Visualização
Opções disponíveis para a propriedade Shape
OPÇÃO DESCRIÇÃO
0 - ddSHRectangle Formato retangular

1 - ddSHEllipse Formato elíptico ou circular

2 - ddSHRoundRect Formato de retângulo arredondado

4.8.5.5 Figura
Esta seção contém informações sobre propriedades do objeto Figura do Relatório (Image). Este objeto não possui
eventos nem métodos associados.

4.8.5.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Figura do Relatório (Image).

4.8.5.5.1.1 DataField
Configura ou retorna o dado associado ao objeto Figura. Este dado associado pode ser um campo da tabela no
Banco de Dados fornecido pelo objeto Consulta, uma expressão matemática com campos da Consulta e funções do
VBScript (neste caso, o campo deve ser precedido do símbolo de igual) ou um Tag ou propriedade do E3. Neste
caso, o valor atual da variável é mostrado ao realizar a impressão. O valor padrão desta propriedade é uma String
vazia.

NOTA
O servidor deve estar em execução para que o valor da variável possa ser capturado.

4.8.5.5.1.2 ForeColor
Especifica a cor do preenchimento do fundo do objeto Figura. Nos scripts, utilize o método RGB do VBScript para
formar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.8.5.5.1.3 hyperLink
Especifica um link atribuído ao texto. Para utilizar este recurso, use o evento OnHyperlink. O valor padrão desta
propriedade é uma String vazia.

4.8.5.5.1.4 LineColor
Especifica a cor da linha do objeto Figura. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.8.5.5.1.5 LineStyle
Determina o estilo da linha do objeto Figura. As opções disponíveis para esta propriedade estão descritas na
tabela a seguir.
Opções disponíveis para a propriedade LineStyle
OPÇÃO DESCRIÇÃO
0 - ddLSTransparent A linha permanece transparente (padrão)

1 - ddLSSolid A linha aparece sólida

2 - ddLSDash A linha aparece tracejada

3 - ddLSDot A linha aparece pontilhada

4 - ddLSDashDot A linha aparece com um padrão de traço e ponto

5 - ddLSDashDotDot A linha aparece com um padrão de traço, ponto e ponto

4.8.5.5.1.6 LineWeight
Especifica a largura da linha do objeto Figura. Configurando a largura para 1 (um), a linha do objeto Figura é
expandida em até 15 pontos, e assim por diante. Quanto maior o número configurado na propriedade, maior a
largura do objeto Figura. O valor padrão desta propriedade é 1 (um).

Visualização 240
4.8.5.5.1.7 Picture
Especifica o arquivo de imagem para o objeto Figura. As extensões permitidas são .bmp, .gif, .jpg, .cur, .ico, .emf e
.wmf. O valor padrão desta propriedade é uma String vazia.

4.8.5.5.1.8 PictureAlignment
Determina o alinhamento da imagem no objeto Figura. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade PictureAlignment
OPÇÃO DESCRIÇÃO
0 - ddPATopLeft Alinha a imagem no topo esquerdo do objeto

1 - ddPATopRight Alinha a imagem no topo direito do objeto

2 - ddPACenter Alinha a imagem no centro do objeto (padrão)

3 - ddPABottomLeft Alinha a imagem à esquerda do objeto

4 - ddPABottomRight Alinha a imagem à direita do objeto

4.8.5.5.1.9 SizeMode
Especifica o tamanho do objeto Figura. As opções disponíveis para esta propriedade estão descritas na tabela a
seguir.
Opções disponíveis para a propriedade SizeMode
OPÇÃO DESCRIÇÃO
0 - ddSMClip Mostra o objeto Figura no seu tamanho atual (padrão)

1 - ddSMStretch Ajusta o objeto Figura de acordo com a sua área

2 - ddSMZoom Ajusta a altura ou a largura da imagem do objeto Figura


dentro da área especificada, sem distorcê-la

4.8.5.6 Linha
Esta seção contém informações sobre propriedades do objeto Linha do Relatório (Line). Este objeto não possui
eventos nem métodos associados.

4.8.5.6.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Linha do Relatório (Line).

4.8.5.6.1.1 LineColor
Esta propriedade especifica a cor da linha do objeto Linha. O valor padrão desta propriedade é preto (RGB(0, 0,
0)).

4.8.5.6.1.2 LineStyle
Esta propriedade determina o estilo da linha do objeto. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade LineStyle
OPÇÃO DESCRIÇÃO
0 - ddLSTransparent A linha permanece transparente

1 - ddLSSolid A linha aparece sólida (padrão)

2 - ddLSDash A linha aparece tracejada

3 - ddLSDot A linha aparece pontilhada

4 - ddLSDashDot A linha aparece com um padrão de traço e ponto

5 - ddLSDashDotDot A linha aparece com um padrão de traço, ponto e ponto

241 Visualização
4.8.5.6.1.3 LineWeight
Esta propriedade especifica a largura da linha do objeto. Configurando a largura para 1 (um), a linha do objeto é
expandida em até 15 pontos. Configurando a largura para 2 (dois), a linha do objeto é expandida em até 30 pontos, e
assim por diante. Quanto maior o número configurado na propriedade, maior a largura do objeto. O valor padrão
desta propriedade é 1 (um).

4.8.5.6.1.4 X1
Esta propriedade habilita ou desabilita a posição do ponto inicial da linha no eixo X. O valor padrão desta
propriedade é vazio.

4.8.5.6.1.5 X2
Esta propriedade determina a posição do ponto final da linha no eixo X. O valor padrão desta propriedade é vazio.

4.8.5.6.1.6 Y1
Esta propriedade determina a posição do ponto inicial da linha no eixo Y. O valor padrão desta propriedade é
vazio.

4.8.5.6.1.7 Y2
Esta propriedade determina a posição do ponto final da linha no eixo Y. O valor padrão desta propriedade é vazio.

4.8.5.7 Quebra de Página


Esta seção contém informações sobre propriedades do objeto Quebra de Página do Relatório (PageBreak). Este
objeto não possui eventos nem métodos associados.

4.8.5.7.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Quebra de Página do Relatório (PageBreak).

4.8.5.7.1.1 Enabled
Esta propriedade habilita ou desabilita o objeto Quebra de Página no Relatório. Se esta propriedade estiver
configurada para Verdadeiro, o objeto é habilitado no Relatório. Caso contrário, o objeto permanece desabilitado. O
valor padrão desta propriedade é Verdadeiro.

4.8.5.8 SetPoint
Esta seção contém informações sobre propriedades do objeto SetPoint do Relatório (Field). Este objeto não possui
eventos nem métodos associados.

4.8.5.8.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto SetPoint do Relatório (Field).

4.8.5.8.1.1 Alignment
Determina o alinhamento do texto no objeto SetPoint. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - ddTXLeft: Alinhamento à esquerda (padrão)
· 1 - ddTXRight: Alinhamento à direita
· 2 - ddTXCenter: Alinhamento centralizado

4.8.5.8.1.2 CanGrow
Determina a aplicação do efeito de stretch ao texto do objeto SetPoint. Caso a largura ou altura do objeto sejam
aumentadas, o texto acompanha esta variação. Se esta propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e largura do objeto. Caso contrário, o objeto permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

Visualização 242
4.8.5.8.1.3 CanShrink
Determina a aplicação do efeito de encolhimento ao texto do objeto SetPoint. Caso a largura ou altura do objeto
sejam diminuídas, o texto acompanha esta variação. Se esta propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e largura do objeto. Caso contrário, o objeto permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

4.8.5.8.1.4 ClassName
Retorna a classe do objeto SetPoint. Esta propriedade é somente de leitura.

4.8.5.8.1.5 DataField
Configura ou retorna o dado associado ao objeto SetPoint. Este dado associado pode ser um campo da tabela no
banco de dados fornecido pelo objeto Consulta, uma expressão matemática com campos da Consulta e funções do
VBScript (neste caso, o campo deve ser precedido do símbolo de igual) ou um Tag ou propriedade do E3. Neste caso
o valor atual da variável é mostrado ao realizar a impressão. O valor padrão desta propriedade é vazio.

NOTA
O servidor deve estar em execução para que o valor da variável possa ser capturado.

4.8.5.8.1.6 Font
Esta propriedade determina a fonte do texto no objeto SetPoint. O valor padrão desta propriedade é uma String
vazia. Esta propriedade não pode ser utilizada em scripts ou em Associações e é configurada somente via E3 Studio.
Consulte o tópico Fonte para mais informações sobre as subpropriedades desta propriedade.

4.8.5.8.1.7 ForeColor
Esta propriedade especifica a cor de fundo do objeto SetPoint. Nos scripts, utilize o método RGB do VBScript para
montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto (RGB(0, 0, 0)).

4.8.5.8.1.8 hyperLink
Esta propriedade determina o link que é atribuído ao texto do SetPoint. Para utilizar este recurso, use o evento
OnHyperlink.

4.8.5.8.1.9 MultiLine
Esta propriedade indica se o texto tem múltiplas linhas (Verdadeiro) ou se é uma caixa de texto simples (Falso). Este
comportamento pode ser visualizado quando o E3 Viewer está em execução. O valor padrão desta propriedade é
Falso.

4.8.5.8.1.10 OutputFormat
Configura ou retorna a formatação do texto da propriedade Text, utilizado nas configurações das funções de
formatação FormatCurrency, FormatDateTime, FormatNumber e FormatPercent do VBScript.

4.8.5.8.1.11 Style
Retorna o estilo do texto configurado no objeto SetPoint. Esta propriedade é somente de leitura.

4.8.5.8.1.12 SummaryDistinctField
Determina o nome do campo que é usado pela função selecionada na propriedade SummaryFunc. Esta
propriedade só é válida se a função definida em SummaryFunc é do grupo de funções Distinct Summary, o qual
abrange as funções de números 9 até 15, e quando a propriedade SummaryType tem valor diferente de 0 (zero).

4.8.5.8.1.13 SummaryFunc
Determina o tipo de função que é usada para processar os valores do campo especificado na propriedade
DataField, como listado na tabela a seguir. Esta propriedade só é válida quando a propriedade SummaryType tem
valor diferente de 0 (zero).

243 Visualização
Opções disponíveis para a propriedade SummaryFunc
OPÇÃO DESCRIÇÃO
0 - ddSFSum Calcula a soma de todos os valores dentro do intervalo
de totais especificado (padrão para grupo, página ou
Relatório)

1 - ddSFAvg Calcula a média de todos os valores dentro do intervalo


de totais especificado (grupo, página ou Relatório)

2 - ddSFCount Conta o número de valores dentro do intervalo de totais


especificado (grupo, página ou Relatório)

3 - ddSFMin Mostra o menor valor (valor mínimo) dentro do intervalo


de totais especificado (grupo, página ou Relatório)

4 - ddSFMax Mostra o maior valor (valor máximo) dentro do intervalo


de totais especificado (grupo, página ou Relatório)

5 - ddSFVar Calcula a variância dos valores dentro do intervalo de


totais especificado (grupo, página ou Relatório)

6 - ddSFVarP Calcula a variância populacional dos valores dentro do


intervalo de totais especificado (grupo, página ou
Relatório)

7 - ddSFStdDev Calcula o desvio padrão dos valores dentro do intervalo


de totais especificado (grupo, página ou Relatório)

8 - ddSFStdDevP Calcula o desvio padrão populacional dos valores dentro


do intervalo de totais especificado (grupo, página ou
Relatório)

9 - ddSFDSum Calcula a soma de todos os valores distintos dentro do


intervalo de totais especificado (grupo, página ou
Relatório)

10 - ddSFDAvg Calcula a média baseada nos valores distintos dentro do


intervalo de totais especificado (grupo, página ou
relatório)

11 - ddSFDCount Conta o número dos valores distintos dentro do intervalo


de totais especificado (grupo, página ou Relatório)

12 - ddSFDVar Calcula a variância dos valores distintos dentro do


intervalo de totais especificado (grupo, página ou
Relatório)

13 - ddSFDVarP Calcula a variância populacional dos valores distintos


dentro do intervalo de totais especificado (grupo, página
ou Relatório)

14 - ddSFDStdDev Calcula o desvio padrão dos valores dentro do intervalo


de totais especificado (grupo, página ou Relatório)

15 - ddSFDStdDevP Calcula o desvio padrão populacional dos valores


distintos dentro do intervalo de totais especificado
(grupo, página ou Relatório)

4.8.5.8.1.14 SummaryGroup
Esta propriedade só é válida quando a propriedade SummaryType é igual a 3 - SubTotal. Esta propriedade indica
qual o nome da Seção GroupHeader que é usada para controlar os subtotais, ou seja, a cada mudança de valor no
GroupHeader, o somatório é reiniciado.

NOTA
Quando esta propriedade é utilizada, as propriedades CanShrink e CanGrow permanecem desabilitadas.

Visualização 244
4.8.5.8.1.15 SummaryRunning
Determina se é realizado o total de somatórios acumulados, de acordo com as seguintes opções:
· 0 - ddSRNone: Não realiza o cálculo de total (padrão)
· 1 - ddSRGroup: Calcula os totais acumulados para cada intervalo de totais especificado
· 2 - ddSRAll: Calcula o total acumulado para todos os valores do Relatório, independente do agrupamento

Esta propriedade só é válida quando a propriedade SummaryType tem valor diferente de 0 (zero).

4.8.5.8.1.16 SummaryType
Determina o tipo ou o nível de totalização a ser gerado. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade SummaryType
OPÇÃO DESCRIÇÃO
0 - ddSMNone Sem geração de somatório (padrão)

1 - ddSMGrandTotal Especifica que é totalizado todo o conteúdo do Relatório

2 - ddSMPageTotal Especifica que é gerado um subtotal por página

3 - ddSMSubTotal Especifica que é gerado um subtotal para cada grupo,


definido na propriedade SummaryGroup

4 - ddSMPageCount Especifica o contador de páginas

4.8.5.8.1.17 text
Determina o texto que é atribuído ao objeto SetPoint.

4.8.5.8.1.18 VerticalAlignment
Determina o alinhamento vertical do objeto SetPoint. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - ddTXTop: Alinhamento pelo topo (padrão)
· 1 - ddTXMiddle: Alinhamento pelo centro
· 2 - ddTXBottom: Alinhamento pela base

4.8.5.8.1.19 WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto SetPoint. Para que esta propriedade funcione, a propriedade MultiLine deve ser
obrigatoriamente igual a Verdadeiro. Se é igual a Falso, a configuração white-space:nowrap aparece na propriedade
Style.

4.8.5.9 Tabela
Esta seção contém informações sobre propriedades do objeto Tabela do Relatório (Frame). Este objeto não possui
eventos nem métodos associados.

4.8.5.9.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tabela do Relatório (Frame).

4.8.5.9.1.1 CanGrow
Determina a aplicação do efeito de stretch ao texto do objeto Tabela. Caso a largura ou altura do objeto sejam
aumentadas, o texto acompanha esta variação. Se a propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e largura do objeto. Caso contrário, o objeto permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

245 Visualização
4.8.5.9.1.2 CanShrink
Determina a aplicação do efeito de encolhimento ao texto do objeto Tabela. Caso a largura ou altura do objeto
sejam diminuídas, o texto acompanha esta variação. Se a propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e largura do objeto. Caso contrário, o objeto permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

4.8.5.9.1.3 CloseBorder
Esta propriedade habilita ou desabilita a visualização da linha da borda da base da Tabela, caso ultrapasse mais de
uma página no Relatório.

4.8.5.9.1.4 left
Esta propriedade retorna o valor do posicionamento esquerdo do objeto Tabela no Relatório. O valor padrão desta
propriedade é vazio.

4.8.5.10 Texto
Esta seção contém informações sobre propriedades do objeto Texto do Relatório (Label). Este objeto não possui
eventos nem métodos associados.

4.8.5.10.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Texto do Relatório (Label).

4.8.5.10.1.1 Alignment
Esta propriedade determina o alinhamento do texto. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - ddTXLeft: Alinhamento à esquerda (padrão)
· 1 - ddTXRight: Alinhamento à direita
· 2 - ddTXCenter: Alinhamento centralizado

4.8.5.10.1.2 Angle
Esta propriedade indica o ângulo do texto. O valor da propriedade deve ser especificado em décimos de graus, ou
seja, para que o texto seja mostrado em um ângulo de 45 graus, o valor deve ser igual à 450. O valor padrão desta
propriedade é 0 (zero, posicionamento horizontal).

4.8.5.10.1.3 Caption
Esta propriedade contém o texto do objeto. O valor padrão desta propriedade é uma String vazia.

4.8.5.10.1.4 ClassName
Esta propriedade permite especificar uma classe CSS global (indicada em uma folha de estilos CSS externa) a ser
aplicada ao texto. Uma classe CSS (Cascading Style Sheet) é um padrão de formatação que determina tipos e tamanhos
de fonte ou alinhamento e espaçamento de parágrafos, entre outras características. Através de CSS, pode-se aplicar
um padrão de formatação pré-definido a um texto, agilizando e unificando a apresentação dos textos. Para aplicar um
estilo específico, pode-se utilizar a propriedade Style. O valor padrão desta propriedade é o estilo Normal.

4.8.5.10.1.5 Font
Esta propriedade indica o nome da fonte (tipo das letras) do texto. O valor padrão desta propriedade é uma
String vazia (o E3 usa o padrão do sistema operacional). Consulte o tópico Fonte para mais informações sobre as
subpropriedades desta propriedade.

NOTA
Esta propriedade não pode ser utilizada em scripts ou Associações, é configurada somente via E3 Studio e só pode
ser modificada em tempo de configuração.

Visualização 246
4.8.5.10.1.6 ForeColor
Esta propriedade especifica a cor de preenchimento do fundo do objeto Texto. Nos scripts, utilize o método RGB
do VBScript para montar a cor a ser associada a esta propriedade. O valor padrão desta propriedade é preto
(RGB(0, 0, 0)).

4.8.5.10.1.7 hyperLink
Esta propriedade determina um link que é atribuído ao objeto Texto. Para utilizar este recurso, use o evento
OnHyperlink. O valor padrão desta propriedade é uma String vazia.

4.8.5.10.1.8 MultiLine
Esta propriedade indica se o texto tem múltiplas linhas (Verdadeiro) ou se é uma caixa de texto simples (Falso). Este
comportamento pode ser visualizado quando o E3 Viewer está em execução. O valor padrão desta propriedade é
Falso.

4.8.5.10.1.9 Style
Esta propriedade permite especificar um estilo CSS (Cascading Style Sheet) para o texto, em substituição ao estilo
global. O valor desta propriedade deve ser uma String CSS válida, caso contrário a propriedade é ignorada. O valor
padrão desta propriedade é uma String vazia (o E3 usa o padrão do sistema operacional). Exemplo:
Sub Report1_OnBeforePrint
Label1.Style = "font-family: Times; font-weight: bold;_
text-align: center; color: RGB(255, 255, 0)"
End Sub

4.8.5.10.1.10 VerticalAlignment
Esta propriedade determina o alinhamento vertical do texto. As opções disponíveis para esta propriedade são as
seguintes:
· 0 - ddTXTop: Alinhamento pelo topo (padrão)
· 1 - ddTXMiddle: Alinhamento centralizado
· 2 - ddTXBottom: Alinhamento pela base

4.8.5.10.1.11 WordWrap
Habilita ou desabilita uma quebra de linha no texto, caso a área disponível para o texto ultrapasse os limites
determinados no objeto. Para que esta propriedade funcione, a propriedade MultiLine deve ser obrigatoriamente
igual a Verdadeiro.

4.8.6 Seção
Esta seção contém informações sobre propriedades comuns do objeto Seção do Relatório (Section). Este objeto não
possui eventos nem métodos associados.

4.8.6.1 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns do objeto Seção do Relatório (Section).

4.8.6.1.1 BackColor
Especifica a cor de fundo da Seção do Relatório. O efeito desta propriedade só é visível se a propriedade
BackStyle estiver configurada como 1 - ddBKNormal. O valor padrão desta propriedade é branco (RGB(255, 255,
255)).

4.8.6.1.2 BackStyle
Especifica o estilo de fundo da Seção do Relatório. As opções disponíveis para esta propriedade são as seguintes:
· 0 - ddBKTransparent: Fundo transparente (padrão)
· 1 - ddBKNormal: Fundo normal

247 Visualização
4.8.6.1.3 CanGrow
Determina a aplicação do efeito de stretch à Seção do Relatório. Caso a largura ou a altura da Seção sejam
aumentadas, o texto acompanha esta variação. Se esta propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e de largura da Seção. Caso contrário, a Seção permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

4.8.6.1.4 CanShrink
Determina a aplicação do efeito de encolhimento à Seção do Relatório. Caso a largura ou a altura da Seção sejam
diminuídas, o texto acompanha esta variação. Se esta propriedade estiver configurada para Verdadeiro, o texto
acompanha as variações de altura e largura da Seção. Caso contrário, a Seção permanece com as configurações
iniciais. O valor padrão desta propriedade é Verdadeiro.

4.8.6.1.5 ColumnLayout
Determina se a Seção Group Footer utiliza o mesmo layout das colunas configuradas na Seção Detail. Se esta
propriedade estiver configurada para Verdadeiro, o número de colunas na Seção Detail se reflete na Seção Group
Header ou na Seção Group Footer associadas. Caso contrário, permanece com as configurações padrão. O valor
padrão desta propriedade é Verdadeiro.

4.8.6.1.6 height
Determina a altura da Seção da página do Relatório. O valor padrão desta propriedade é 360.

4.8.6.1.7 IsRepeating
Determina a repetição da Seção na última página do Relatório. Se esta propriedade estiver configurada para
Verdadeiro, a Seção é repetida na última página. Caso contrário, não há repetição. Esta propriedade é somente de
leitura.

4.8.6.1.8 KeepTogether
Determina se as Seções do Relatório são impressas como um único bloco na mesma página. O valor padrão desta
propriedade é Falso.

4.8.6.1.9 Name
Indica o nome da Seção no Relatório.

4.8.6.1.10 NewColumn
Insere uma nova quebra de coluna antes ou depois da impressão de uma Seção no Relatório. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade NewColumn
OPÇÃO DESCRIÇÃO
0 - ddNPNone Não há quebra de página na Seção (padrão)

1 - ddNPBefore Inicia a impressão da Seção em uma nova página

2 - ddNPAfter Inicia uma nova página depois de imprimir a Seção

3 - ddNPBeforeAfter Inicia a impressão em uma nova página e uma nova


página depois de imprimir a Seção

4.8.6.1.11 NewPage
Insere uma quebra de página no Relatório. As opções disponíveis para esta propriedade estão descritas na tabela
a seguir.
Opções disponíveis para a propriedade NewPage
OPÇÃO DESCRIÇÃO
0 - ddNPNone Não há quebra de página na Seção (padrão)

1 - ddNPBefore Inicia a impressão em uma nova página

Visualização 248
OPÇÃO DESCRIÇÃO
2 - ddNPAfter Inicia uma nova página depois da impressão da Seção

3 - ddNPBeforeAfter Inicia a impressão em uma nova página e inicia uma nova


página depois de imprimir a Seção

4.8.6.1.12 Type
Retorna o tipo da Seção. Esta propriedade é somente de leitura. As opções disponíveis para esta propriedade
estão descritas na tabela a seguir.
Opções disponíveis para a propriedade Type
OPÇÃO DESCRIÇÃO
0 - ddSTReportHeader Seção do tipo Report Header (cabeçalho de Relatório)

1 - ddSTReportFooter Seção do tipo Report Footer (rodapé de Relatório)

2 - ddSTPageHeader Seção do tipo Page Header (cabeçalho de página)

3 - ddSTPageFooter Seção do tipo Page Footer (rodapé de página)

4 - ddSTGroupHeader Seção do tipo Group Header (cabeçalho de grupo)

5 - ddSTGroupFooter Seção do tipo Group Footer (rodapé de grupo)

6 - ddSTDetail Seção do tipo Detail (área para o conteúdo do


Relatório)

4.8.6.1.13 UnderlayNext
Determina se a Seção deve imprimir uma Seção depois da outra, consecutivamente. Se esta propriedade estiver
configurada para Verdadeiro, a Seção seguinte começa a impressão a partir da coordenada superior da Seção na
página do Relatório. Caso contrário, este recurso não é utilizado. O valor padrão desta propriedade é Falso.

4.8.6.1.14 Visible
Habilita ou desabilita a visibilidade da Seção no Relatório. Se esta propriedade estiver configurada para Verdadeiro,
a Seção é visível no Relatório. Caso contrário, não é visível. O valor padrão desta propriedade é Verdadeiro.

4.8.6.2 Detail
Esta seção contém informações sobre propriedades do objeto Detail do Relatório. Este objeto não possui eventos
nem métodos associados.

4.8.6.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Detail do Relatório.

4.8.6.2.1.1 ColumnCount
Determina o número de colunas na Seção Detail do Relatório. A largura de cada coluna deve ser igual à área
imprimível do Relatório, dividida pelo número de colunas. O valor padrão desta propriedade é 1 (um).

4.8.6.2.1.2 ColumnDirection
Esta propriedade determina a direção da impressão das colunas da Seção Detail. As opções disponíveis para esta
propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade ColumnDirection
OPÇÃO DESCRIÇÃO
0 - ddCDDownAcross Imprime cada coluna da Seção Detail de cima para baixo
e depois passa para a próxima coluna à direita (padrão)

1 - ddCDAcrossDown Imprime cada coluna da Seção Detail da direita para a


esquerda e assim por diante

O layout é determinado de acordo com a opção configurada, conforme mostrado nas figuras a seguir.

249 Visualização
Opção ddCDDownAccross

Opção ddCDAccrossDown

4.8.6.2.1.3 ColumnSpacing
Determina o espaçamento da coluna na Seção Detail. O valor padrão desta propriedade é 0 (zero).

4.8.6.2.1.4 DataField
Retorna os dados dos campos do Relatório. Define um campo obrigatório para um grupo dentro do conteúdo da
Seção Detail. Este valor é ajustado ao nome de todos os campos na fonte de dados do Relatório ou ao nome de um
campo personalizado que está inserido na coleção de campos. Quando esta propriedade é ajustada, o Relatório cria
um grupo novo cada vez que o valor do campo muda nos registros de dados da Seção Detail. Esta propriedade é
somente de leitura.

4.8.6.3 Group Footer


Esta seção contém informações sobre propriedades do objeto Group Footer do Relatório. Este objeto não possui
eventos nem métodos associados.

4.8.6.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Group Footer do Relatório.

Visualização 250
4.8.6.3.1.1 PrintAtBottom
Determina se a Seção GroupFooter ou o rodapé do Relatório são impressos no pé da página. Se esta propriedade
estiver configurada para Verdadeiro e o Relatório contiver um rodapé de página, a Seção GroupFooter e o rodapé
do Relatório são impressos acima da Seção Rodapé de página. Configurando mais de uma Seção para imprimir o pé
da página do Relatório permite que as Seções seguintes do rodapé sejam impressas em páginas separadas.

4.8.6.4 Group Header


Esta seção contém informações sobre propriedades do objeto Group Header do Relatório. Este objeto não possui
eventos nem métodos associados.

4.8.6.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Group Header do Relatório.

4.8.6.4.1.1 GrpKeepTogether
Determina se a Seção Group Header é impressa como um bloco único na mesma página do Relatório. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade GrpKeepTogether
OPÇÃO DESCRIÇÃO
0 - ddGrpNone A página pode ser quebrada imediatamente depois de
uma Seção Group Header (padrão)

1 - ddGrpFirstDetail A Seção Group Header é impressa com a primeira Seção


Detail da mesma página ou coluna do Relatório

2 - ddGrpAll As Seções Group Header, Detail e Footer de grupo são


impressas juntas na mesma página do Relatório

4.8.6.4.1.2 Repeat
Determina se a Seção Group Header é impressa novamente depois de ser associada à Seção Detail quando há
múltiplas páginas, colunas ou quebras de páginas no Relatório. As opções disponíveis para esta propriedade estão
descritas na tabela a seguir.
Opções disponíveis para a propriedade Repeat
OPÇÃO DESCRIÇÃO
0 - ddRepeatNone Não há reimpressão do grupo de cabeçalho (padrão)

1 - ddRepeatOnPage Imprime o grupo de cabeçalhos no topo da página


conforme as especificações da Seção Detail

2 - ddRepeatOnColumn Imprime o grupo de cabeçalhos no topo da coluna da


página do Relatório conforme as especificações da
Seção Detail

3 - ddRepeatAll Imprime o grupo de cabeçalhos e os demais objetos no


topo da página do Relatório conforme as especificações
da Seção Detail

4.9 TrendAnalysis
Esta seção contém informações sobre métodos e propriedades do objeto TrendAnalysis (ITrendAnalysisObject). Este
objeto não possui eventos associados.

4.9.1 Métodos
Esta seção contém informações sobre os métodos do objeto TrendAnalysis (TrendAnalysisObject).

251 Visualização
4.9.1.1 AddDisplay
AddDisplay([Title], [DisplayPosition])
Adiciona uma Exibição nova no TrendAnalysis. O parâmetro opcional Title indica o título da Exibição. Se omitido, utiliza
um título padrão incremental. O parâmetro opcional DisplayPosition indica a posição desta Exibição em relação à
Exibição selecionada, caso o TrendAnalysis esteja aberto, ou em relação à última Exibição adicionada, caso o
TrendAnalysis esteja fechado. Os valores possíveis para este parâmetro são -1: tadpDefault (menos um, padrão), 0:
tadpLeft (à esquerda), 1: tadpRight (à direita), 2: tadpTop (acima) ou 3: tadpBottom (abaixo). O valor padrão (-1,
menos um) usa um cálculo interno para definir a posição da Exibição. Este método retorna Verdadeiro se a Exibição
foi adicionada com sucesso ou Falso caso contrário. O código a seguir contém um exemplo de uso deste método.
Sub CommandButton1_Click()
Set TA = Application.GetTrendAnalysis("Popup")
TA.AddPen "Dados1.TagDemo1"
TA.AddPlotArea
TA.AddPen "Dados1.TagDemo2"
TA.AddDisplay "TelaDireita", 1
TA.AddPlotArea
TA.AddPen "Dados1.TagDemo3"
TA.AddDisplay "TelaEmbaixo", 3
TA.Show
End Sub

4.9.1.2 AddPen
AddPen(PenPath, [ErrorDetails])
Adiciona uma Pena na última área de plotagem adicionada. O parâmetro PenPath corresponde ao caminho de um Tag
no E3. O parâmetro opcional de retorno ErrorDetails contém uma String detalhando o erro desta operação. Este
método retorna Verdadeiro se a Pena foi adicionada com sucesso ou Falso caso contrário. Consulte o método
AddDisplay para um exemplo deste método.

4.9.1.3 AddPlotArea
AddPlotArea()
Adiciona uma área de plotagem na Exibição selecionada, caso o TrendAnalysis esteja aberto, ou na última Exibição,
caso o TrendAnalysis esteja fechado. Este método retorna Verdadeiro se a área de plotagem foi adicionada com
sucesso ou Falso caso contrário. Consulte o método AddDisplay para um exemplo deste método.

4.9.1.4 CenterWindow
CenterWindow()
Centraliza a janela do TrendAnalysis. Se a janela já está aberta, é centralizada imediatamente. Consulte o método
SetWindowPlacement para mais informações sobre o posicionamento de janelas TrendAnalysis.

4.9.1.5 Close
Close()
Fecha a janela do TrendAnalysis.

4.9.1.6 Load
Load(Configuration, [ConfigStatus], [ErrorDetails])
Carrega uma configuração salva pelo método Save no parâmetro Configuration. Este método retorna Verdadeiro se a
operação de carregamento foi bem-sucedida ou Falso caso contrário. O parâmetro opcional de retorno ConfigStatus
indica o resultado da operação de carregamento. Se o método retorna Verdadeiro, ou seja, a operação foi bem-
sucedida, este parâmetro retorna o valor 0: A configuração foi carregada com sucesso. Se o método retorna Falso, ou
seja, a operação não foi bem-sucedida, este parâmetro retorna os valores 1: A configuração não carregou
corretamente, 2: O conteúdo da configuração é inválido ou 3: Esta configuração requer uma versão mais recente. O
parâmetro opcional de retorno ErrorDetails contém uma String detalhando o erro da operação de carregamento. O
código a seguir contém um exemplo de utilização deste método.
Set TA = Application.GetTrendAnalysis("TrendAnalysis")
Dim loadResult, errorMsg, errorDetails

loadResult = TA.Load(Screen.Item("TextBox3").Value, ConfigStatus, errorDetails)


If loadResult = False Then
Visualização 252
If ConfigStatus <> 0 Then
Select Case ConfigStatus
Case 1
errorMsg = "Erro (1): A configuração não foi carregada corretamente."
Case 2
errorMsg = "Erro (2): O conteúdo da configuração é inválido."
Case 3
errorMsg = "Erro (3): Esta configuração requer uma versão mais recente"
End Select
errorMsg = errorMsg & vbCrLf & "Detalhes: " & errorDetails
MsgBox errorMsg
End If
Else
TA.Show
End If

NOTA
Utilizar o método Show em um objeto TrendAnalysis cujo carregamento da configuração não tenha sido bem-
sucedido apenas mostra uma janela em branco.

4.9.1.7 Save
Save()
Salva e retorna a configuração do objeto TrendAnalysis. O valor de retorno deste método pode ser usado no método
Load para recarregar esta configuração em usos subsequentes deste objeto.

4.9.1.8 SetWindowPlacement
SetWindowPlacement([PosX], [PosY], [SizeX], [SizeY])
Informa a posição e o tamanho da janela do TrendAnalysis. Se nenhuma posição ou tamanho é especificado, o
posicionamento desta janela obedece o modo automático:
· O tamanho inicial é o mínimo e, nas vezes subsequentes em que a janela é aberta, este tamanho inicial é
armazenado e reutilizado
· A posição inicial é centralizada e, nas vezes subsequentes em que a janela é aberta, esta posição inicial é
armazenada e reutilizada

NOTA
A informação de posição e tamanho da janela é salva no Registro do Windows, por usuário, e é específica de cada
janela do TrendAnalysis.

Este método pode ser chamado com o TrendAnalysis visível ou não. Se a janela já está visível, é movida e
redimensionada imediatamente. Do contrário, a última posição e tamanho são armazenados para serem utilizados
quando a janela é novamente aberta.
Todos os parâmetros são opcionais, mas só são válidos se informados aos pares, PosX com PosY e SizeX com SizeY.
Caso somente os parâmetros de posição sejam informados, PosX e PosY, o tamanho não é afetado. Da mesma forma,
se apenas os parâmetros de tamanho são informados, SizeX e SizeY, a posição não é afetada.
Resumo do comportamento da janela TrendAnalysis
MODO AUTOMÁTICO POSIÇÃO NÃO TAMANHO NÃO
ESPECIFICADA ESPECIFICADO
Tamanho Mínimo ou último -- Mínimo
armazenado

Posição Centralizada ou última Centralizada --


armazenada

4.9.1.9 Show
Show()
Mostra a janela do TrendAnalysis, se não está visível. Se a janela já existe, apenas recebe o foco.

253 Visualização
4.9.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto TrendAnalysis (TrendAnalysisObject).

4.9.2.1 IsOpened
Informa se existe uma janela do TrendAnalysis aberta ou não. Esta propriedade é somente de leitura.

4.9.2.2 Title
Retorna o título da janela do TrendAnalysis. Esta propriedade é somente de leitura.

Visualização 254
CAPÍTULO
Objetos de Servidor
5
Esta seção contém informações sobre as propriedades comuns aos objetos de Servidor. Estes objetos não possuem
eventos nem métodos comuns. Os objetos que compartilham propriedades de Servidor são os seguintes:
· Alarmes
· Banco de Dados
· Coleção de Campos de Usuário de Alarmes
· Drivers
· Fórmulas
· Históricos
· Informações do Servidor
· Objetos em Tempo de Configuração
· Objetos em Tempo de Execução do Servidor
· Servidor de Dados
· Storage

5.1 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns a todos os objetos de Servidor.

5.1.1 IsAlarmArea
Habilita ou desabilita a funcionalidade de Área de Alarme para os objetos de Servidor. Esta propriedade não está
disponível nos objetos Área de Alarmes, Campo do Histórico, Campo do Storage, Coleção de Campos do Histórico
(objeto Fields), Coleção de Campos do Storage (objeto Fields), Fonte de Alarmes e Servidor de Alarmes. O valor
padrão desta propriedade é Falso. Ao habilitar esta propriedade, o objeto passa a contar com as mesmas
propriedades de uma Área de Alarme.

5.1.2 Propriedades Comuns a Objetos de Servidor como Áreas de


Alarme
Esta seção contém informações sobre propriedades comuns a objetos de servidor que se comportam como Áreas de
Alarme.

5.1.2.1 ActiveAlarms
Determina o número de alarmes ativos em um objeto. Esta propriedade é somente de leitura.

5.1.2.2 ActiveCritAlarms
Indica o número de alarmes ativos com severidade Crítica em um objeto. Esta propriedade é somente de leitura.

5.1.2.3 ActiveCritNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Crítica em um objeto. Esta propriedade é somente
de leitura.

5.1.2.4 ActiveHighAlarms
Indica o número de alarmes ativos com severidade Alta em um objeto. Esta propriedade é somente de leitura.

5.1.2.5 ActiveHighNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Alta em um objeto. Esta propriedade é somente de
leitura.

5.1.2.6 ActiveLowAlarms
Indica o número de alarmes ativos com severidade Baixa em um objeto. Esta propriedade é somente de leitura.

255 Objetos de Servidor


5.1.2.7 ActiveLowNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Baixa em um objeto. Esta propriedade é somente de
leitura.

5.1.2.8 ActiveMedAlarms
Indica o número de alarmes ativos com severidade Média em um objeto. Esta propriedade é somente de leitura.

5.1.2.9 ActiveMedNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Média em um objeto. Esta propriedade é somente
de leitura.

5.1.2.10 ActiveNACKAlarms
Indica o número de alarmes não reconhecidos em um objeto. Esta propriedade é somente de leitura.

5.1.2.11 Alarm
Indica a existência de alarmes ativos em um objeto. Se o valor desta opção é Verdadeiro, existe pelo menos um
alarme ativo no objeto e a propriedade ActiveAlarms realiza a leitura no servidor, indicando a quantidade de alarme
ativos. Caso contrário, a propriedade ActiveNACKAlarms realiza a leitura dos alarmes sem reconhecimento. Esta
propriedade é somente de leitura.

5.1.2.12 AlarmVerify
Habilita a verificação de todos os alarmes em um objeto. Depois de habilitada esta propriedade, se a propriedade
ActiveAlarms possuir um valor maior que 0 (zero), o servidor verifica tanto os alarmes ativos quanto os sem
reconhecimento, listando estes últimos pela propriedade ActiveNACKAlarms. Esta propriedade é útil para evitar-se o
efeito de avalanche de alguns sistemas, onde o acontecimento de um evento gera uma grande quantidade de alarmes
correlacionados.

5.1.2.13 InactiveCritNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Crítica em um objeto. Esta propriedade é
somente de leitura.

5.1.2.14 InactiveHighNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Alta em um objeto. Esta propriedade é
somente de leitura.

5.1.2.15 InactiveLowNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Baixa em um objeto. Esta propriedade é
somente de leitura.

5.1.2.16 InactiveMedNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Média em um objeto. Esta propriedade é
somente de leitura.

5.1.2.17 InactiveNACKAlarms
Determina o número total de alarmes inativos e não reconhecidos em um objeto. Esta propriedade é somente de
leitura.

5.1.2.18 UserFields
Retorna um objeto que é uma coleção de Campos de Usuário de Alarmes de um objeto de Servidor. Consulte o
tópico Coleção de Campos de Usuário de Alarmes para maiores informações sobre a coleção de objetos retornados
por esta propriedade. Esta propriedade é somente de leitura.

Objetos de Servidor 256


5.2 Alarmes
Esta seção contém informações sobre eventos, métodos e propriedades dos objetos Configuração de Alarmes, Áreas
de Alarme, Fontes de Alarme e Servidor de Alarmes.

5.2.1 Áreas de Alarme


Esta seção contém informações sobre propriedades do objeto Área de Alarme (Area). Este objeto não possui eventos
nem métodos associados.

5.2.1.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Área de Alarme (Area).

5.2.1.1.1 ActiveAlarms
Determina o número de alarmes ativos em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.2 ActiveCritAlarms
Indica o número de alarmes ativos com severidade Crítica em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.3 ActiveCritNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Crítica em uma Área. Esta propriedade é somente de
leitura.

5.2.1.1.4 ActiveHighAlarms
Indica o número de alarmes ativos com severidade Alta em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.5 ActiveHighNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Alta em uma Área. Esta propriedade é somente de
leitura.

5.2.1.1.6 ActiveLowAlarms
Indica o número de alarmes ativos com severidade Baixa em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.7 ActiveLowNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Baixa em uma Área. Esta propriedade é somente de
leitura.

5.2.1.1.8 ActiveMedAlarms
Indica o número de alarmes ativos com severidade Média em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.9 ActiveMedNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Média em uma Área. Esta propriedade é somente de
leitura.

5.2.1.1.10 ActiveNACKAlarms
Indica o número de alarmes sem reconhecimento em uma Área. Esta propriedade é somente de leitura.

5.2.1.1.11 Alarm
Indica a existência de alarmes ativos dentro de uma Área. Se o valor desta opção é Verdadeiro, existe ao menos um
alarme ativo dentro da Área, e a propriedade ActiveAlarms realiza a leitura no sistema, indicando a quantidade de
alarme ativos. Caso contrário, a propriedade ActiveNACKAlarms executa a leitura dos alarmes sem reconhecimento.
Esta propriedade é somente de leitura.

257 Objetos de Servidor


5.2.1.1.12 AlarmVerify
Habilita a verificação de todos os alarmes em uma Área. Depois de habilitada esta propriedade, se a propriedade
ActiveAlarms possui um valor maior que 0 (zero), o sistema verifica tanto os alarmes ativos quanto aqueles sem
reconhecimento, listando estes últimos pela propriedade ActiveNACKAlarms. Esta propriedade é útil para evitar-se o
efeito de avalanche de alguns sistemas, onde o acontecimento de um evento gera uma grande quantidade de alarmes
correlacionados.

5.2.1.1.13 InactiveCritNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Crítica em uma Área. Esta propriedade é
somente de leitura.

5.2.1.1.14 InactiveHighNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Alta em uma Área. Esta propriedade é
somente de leitura.

5.2.1.1.15 InactiveLowNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Baixa em uma Área. Esta propriedade é
somente de leitura.

5.2.1.1.16 InactiveMedNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Média em uma Área. Esta propriedade é
somente de leitura.

5.2.1.1.17 InactiveNACKAlarms
Determina o número total de alarmes inativos e não reconhecidos em uma Área. Esta propriedade é somente de
leitura.

5.2.1.1.18 UserFields
Retorna um objeto que é uma coleção de Campos de Usuário de Alarmes de uma Área de Alarme. Consulte o
tópico Coleção de Campos de Usuário de Alarmes para mais informações sobre a coleção de objetos retornados
por esta propriedade. Esta propriedade é somente de leitura.

5.2.2 Configuração de Alarmes


O objeto Configuração de Alarmes (AlarmConfig) não possui eventos, métodos ou propriedades específicos
associados, somente métodos e propriedades gerais. Estes podem ser visualizados nas seções Eventos, Métodos e
Propriedades Gerais dos Objetos.

5.2.3 Fontes de Alarme


Esta seção contém informações sobre métodos e propriedades comuns ao objeto Fonte de Alarme. Este objeto não
possui eventos comuns associados.

NOTA
Quando um objeto Fonte de Alarme é desabilitado ou desativado, as propriedades ActiveNACKAlarm, Alarm,
CurrentSeverity, CurrentSubConditionName, FormattedValue, RawAlarm e Value assumem seus valores padrão,
indicando que a Fonte de Alarme não está vinculada a uma mensagem de alarme ativa. Neste caso, os valores das
propriedades Alarm e ActiveNACKAlarm são propagados para os contadores das Áreas superiores.
Para que as propriedades citadas recebam um valor diferente do padrão, é necessário que as seguintes condições
estejam presentes:
· A Fonte de Alarme deve estar habilitada e ativada
· As Áreas de Alarme, e todos os objetos hierarquicamente superiores, devem estar habilitadas e ativadas
· O Servidor de Alarmes deve estar ativado

Objetos de Servidor 258


5.2.3.1 Métodos Comuns
Esta seção contém informações sobre os métodos comuns aos objetos Fontes de Alarme.

5.2.3.1.1 Ack
Ack([ActorID])
Executa o reconhecimento de um alarme configurado no objeto Fonte de Alarmes. Este método retorna um Booleano
que indica o sucesso ou não da operação. O parâmetro ActorID informa o nome do usuário responsável pelo
reconhecimento dos alarmes. Este parâmetro é opcional e, se omitido, assume o logon do usuário do E3 Viewer,
"Anonymous" se não há usuário logado ou "System" se a chamada do método originou-se no servidor.

5.2.3.1.2 GetAlarm
GetAlarm()
Retorna um objeto que permite o acesso às configurações específicas de cada tipo de alarme. Este objeto permite
verificar ou modificar em tempo de execução as propriedades de um determinado alarme. Dependendo do tipo de
alarme, este método retorna um objeto com as propriedades descritas nas tabelas a seguir.
Propriedades de um objeto Alarme Analógico
PROPRIEDADE DESCRIÇÃO
Delay Tempo de atraso para este alarme, em milissegundos,
tanto na entrada quanto na saída da condição

Hi Habilita ou desabilita a verificação deste alarme com


nível de severidade Alto

HiAckRequired Indica se há necessidade de reconhecimento para o nível


de severidade Alto deste alarme

HiHi Habilita ou desabilita a verificação deste alarme com


nível de severidade Muito Alto

HiHiAckRequired Indica se há necessidade de reconhecimento para o nível


de severidade Muito Alto deste alarme

HiHiLimit Limite para o nível de severidade Muito Alto deste


alarme

HiHiMessageText Texto da mensagem para o nível de severidade Muito


Alto deste alarme

HiHiSeverity Importância do nível de severidade Muito Alto deste


alarme. Os valores possíveis para esta propriedade são
-2: Crítica, 0: Alta, 1: Média ou 2: Baixa

HiLimit Limite para o nível de severidade Alto deste alarme

HiMessageText Texto da mensagem para o nível de severidade Alto


deste alarme

HiSeverity Importância do nível de severidade Alto deste alarme.


Os valores possíveis para esta propriedade são -2:
Crítica, 0: Alta, 1: Média ou 2: Baixa

LevelDeadBand Banda morta para os limites do nível deste alarme

LevelReturnMessageText Mensagem de retorno deste alarme

Lo Habilita ou desabilita a verificação deste alarme com


nível de severidade Baixo

LoAckRequired Indica se há necessidade de reconhecimento para o nível


de severidade Baixo deste alarme

LoLimit Limite para o nível de severidade Baixo deste alarme

LoLo Habilita ou desabilita a verificação deste alarme com


nível de severidade Muito Baixo

259 Objetos de Servidor


PROPRIEDADE DESCRIÇÃO
LoLoAckRequired Indica se há necessidade de reconhecimento para o nível
de severidade Muito Baixo deste alarme

LoLoLimit Limite para o nível de severidade Muito Baixo deste


alarme

LoLoMessageText Texto da mensagem para o nível de severidade Muito


Baixo deste alarme

LoLoSeverity Importância do nível de severidade Muito Baixo deste


alarme. Os valores possíveis para esta propriedade são
-2: Crítica, 0: Alta, 1: Média ou 2: Baixa

LoMessageText Texto da mensagem para o nível de severidade Baixo


deste alarme

LoSeverity Importância do nível de severidade Baixo deste alarme.


Os valores possíveis para esta propriedade são -2:
Crítica, 0: Alta, 1: Média ou 2: Baixa

Name Nome deste alarme

Propriedades de um objeto Alarme Banda Morta


PROPRIEDADE DESCRIÇÃO
DeadBand Habilita ou desabilita a verificação deste alarme

DeadBandAckRequired Indica se há necessidade de reconhecimento para este


alarme

DeadBandLimit Limite para este alarme

DeadBandMessageText Texto da mensagem deste alarme

DeadBandReturnMessageText Mensagem de retorno deste alarme

DeadBandSetPoint Limite de banda morta deste alarme. Cada vez que o


valor do Tag associado ultrapassa o valor desta
propriedade para mais ou para menos do valor de
DeadBandLimit, este alarme ocorre

DeadBandSeverity Importância deste alarme. Os valores possíveis para esta


propriedade são -2: Crítica, 0: Alta, 1: Média ou 2: Baixa

Delay Tempo de atraso para este alarme, em milissegundos,


tanto na entrada quanto na saída da condição

Name Nome deste alarme

Propriedades de um objeto Alarme Digital


PROPRIEDADE DESCRIÇÃO
Delay Tempo de atraso para este alarme, em milissegundos,
tanto na entrada quanto na saída da condição

Digital Habilita ou desabilita a verificação deste alarme

DigitalAckRequired Indica se há necessidade de reconhecimento para este


alarme

DigitalLimit Limite para este alarme

DigitalMessageText Texto da mensagem deste alarme

DigitalReturnMessageText Mensagem de retorno deste alarme

DigitalSeverity Severidade deste alarme. Os valores possíveis para esta


propriedade são -2: Crítica, 0: Alta, 1: Média ou 2: Baixa

Objetos de Servidor 260


PROPRIEDADE DESCRIÇÃO
Name Nome deste alarme

Propriedades de um objeto Alarme Discreto


PROPRIEDADE DESCRIÇÃO
Delay Tempo de atraso para este alarme, em milissegundos,
tanto na entrada quanto na saída da condição

DiscreteReturnMessageText Mensagem de retorno deste alarme

Name Nome deste alarme

SubConditions Coleção de Subcondições deste alarme. Consulte a


tabela a seguir para uma descrição das propriedades
disponíveis nos objetos Subcondição desta coleção,
acessíveis utilizando o método Item

Propriedades de um objeto Subcondição de um Alarme Discreto


PROPRIEDADE DESCRIÇÃO
AckRequired Indica se há necessidade de reconhecimento para esta
Subcondição

Caption Descrição desta Subcondição

Enabled Habilita ou desabilita esta Subcondição

Kind Comportamento desta Subcondição. Os valores


possíveis para esta propriedade são 0: Alarme, 1:
Evento ou 2: Retorno

Limit Valor da fonte do alarme para gerar esta Subcondição

Message Mensagem do evento quando esta Subcondição está


ativa

Name Nome desta Subcondição

Severity Importância desta Subcondição. Os valores possíveis


para esta propriedade são -2: Crítica, 0: Alta, 1: Média
ou 2: Baixa

Propriedades de um objeto Alarme Taxa de Variação


PROPRIEDADE DESCRIÇÃO
Delay Tempo de atraso para este alarme, em milissegundos,
tanto na entrada quanto na saída da condição

Name Nome deste alarme

ROC Habilita ou desabilita a verificação deste alarme

ROCAckRequired Indica se há necessidade de reconhecimento para este


tipo de alarme

ROCLimit Limite para este alarme. Para que este alarme ocorra,
basta que o valor do Tag associado ultrapasse este
valor em um segundo

ROCMessageText Texto da mensagem deste alarme

ROCReturnMessageText Mensagem de retorno deste alarme

ROCSeverity Importância deste alarme. Os valores possíveis para esta


propriedade são -2: Crítica, 0: Alta, 1: Média ou 2: Baixa

261 Objetos de Servidor


Exemplo de uso deste método:
Sub Botao1_Click()
'Clicar neste botão muda o nível
'de severidade Baixo de um alarme analógico
Set alm = Application.GetObject("Conf1.Area1.Analog1")_
.GetAlarm()
alm.LoLimit = 10.2
End Sub

NOTA
As propriedades relativas a cada tipo de alarme podem ser acessadas diretamente por scripts e Associações, bem
como visualizadas na Lista de Propriedades do objeto, não mais sendo obrigatória a edição via método GetAlarm.

5.2.3.2 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns aos objetos Fonte de Alarme.

5.2.3.2.1 ActiveNACKAlarm
Indica se uma Fonte de Alarme foi ou não reconhecida desde a última ativação. Esta propriedade é somente de
leitura e o valor padrão é Falso.

5.2.3.2.2 Alarm
Indica se há alarmes ativos em uma Fonte de Alarme ou não. Esta propriedade é somente de leitura e o valor
padrão é Falso.

5.2.3.2.3 AlarmVerify
Habilita ou não a verificação de uma Fonte de Alarme, ou seja, a geração do alarme.

5.2.3.2.4 AreaNameOverride
Determina um nome alternativo para a Área que contém uma Fonte de Alarme. O valor padrão desta propriedade é
uma String vazia.

NOTAS
· Quando esta propriedade está vazia, o nome da Fonte de Alarme é composto dos nomes dos objetos Área
hierarquicamente superiores.
· Esta propriedade, mesmo quando preenchida, não influencia nos contadores da Áreas de Alarme
hierarquicamente superiores, que continuam contando os alarmes desta Fonte de Alarme.
· Se esta propriedade é alterada em tempo de execução, o novo valor só entra em vigor quando ocorre o próximo
alarme nesta Fonte de Alarme.

5.2.3.2.5 CurrentSeverity
Indica a última severidade do alarme ativo. Os valores possíveis são -2: Crítica, 0: Alta, 1: Média ou 2: Baixa. Esta
propriedade é somente de leitura e o valor padrão é -1 (menos um), ou seja, a Fonte de Alarme não está ativa.

5.2.3.2.6 CurrentSubConditionName
Determina o nome da última condição de alarme ativa. Esta propriedade é somente de leitura. As opções
disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para CurrentSubConditionName
OPÇÃO DESCRIÇÃO
LOLO Alarme Analógico na faixa Muito Baixa

LO Alarme Analógico na faixa Baixa

HI Alarme Analógico na faixa Alta

HIHI Alarme Analógico na faixa Muito Alta

BM Alarme de Banda Morta

Objetos de Servidor 262


OPÇÃO DESCRIÇÃO
TV Alarme Taxa de Variação

DIG Alarme Digital

O valor padrão desta propriedade é uma String vazia.

NOTA
Para Fontes de Alarme do tipo Discreto, esta propriedade assume o nome da Subcondição definida pelo usuário, na
aba Discreto das propriedades deste tipo de Alarme.

5.2.3.2.7 Delay
Especifica um tempo de atraso para o alarme, em milissegundos, tanto na entrada quanto na saída da condição.
Quando esta propriedade está em 0 (zero, que é sempre o valor padrão), não é aplicado nenhum atraso. Quando
esta propriedade é diferente de 0 (zero), o alarme só é ativado ou desativado se permanece na mesma condição por
um tempo maior ou igual ao especificado.

5.2.3.2.8 DoubleAckRequired
Quando configurada como Verdadeiro, indica que o alarme pode ser reconhecido tanto quando está ativo como
quando passa a inativo, ou seja, pode ser reconhecido duplamente. Quando configurada como Falso, indica que o
alarme só pode ser reconhecido uma vez, e ao ser reconhecido sai da lista de alarmes. Alarmes que não necessitem
reconhecimento (propriedade AckRequired) não possibilitam esta personalização. Aplicações anteriores à versão 2.5
vêm com esta propriedade configurada como Falso.

5.2.3.2.9 Event
Indica que um alarme é do tipo Evento, que são alarmes reconhecidos pelo usuário "System" ao serem ativados.
Portanto, ao ser reconhecido nada acontece, ou seja, não tem efeito algum, assim como não incrementa o número de
alarmes ativos nem o número de alarmes não reconhecidos. Esta propriedade não pode ser alterada com o objeto
ativo.

5.2.3.2.10 ExcludeSuppressedOnAreaCounters
Quando configurada para Verdadeiro, desconsidera os alarmes suprimidos de uma Área de Alarme nos contadores
gerais de alarmes. O valor padrão desta propriedade é Falso.

5.2.3.2.11 Format
Esta propriedade especifica um formato para uma Fonte de Alarme e permite mudar a forma como os dados são
apresentados sem mudar o valor existente. Esta propriedade pode ser editada manualmente ou configurada através
da janela de formatação. O uso é semelhante aos formatadores usados nas planilhas de dados, seguindo a mesma
sintaxe básica. São suportados os tipos de dados descritos na tabela a seguir.
Tipos de dados suportados pela propriedade Format
TIPO DE DADOS DESCRIÇÃO
Numérico Saída decimal, científica, hexadecimal, binária ou octal

Texto Textos em geral

Booleano Valores Booleanos

Data e Hora Calendário Gregoriano

5.2.3.2.12 FormattedValue
Contém o valor do alarme definido na propriedade Value e formatado de acordo com a propriedade Format. Esta
propriedade é somente de leitura e o valor padrão é Null.

5.2.3.2.13 RawAlarm
Indica se o alarme deve estar ativo, independente da espera. Quando a espera é igual a 0 (zero), o valor desta
propriedade é igual ao valor da propriedade Alarm. Esta propriedade é somente de leitura e o valor padrão é Falso.

263 Objetos de Servidor


5.2.3.2.14 Source
Contém a expressão que deve ser avaliada para determinar se o alarme deve ocorrer ou não.

5.2.3.2.15 SuppressedAlarmsConfigured
Indica que a Fonte ou Subcondição de Alarme está configurada para permitir o arquivamento de alarmes. Esta
propriedade é somente de leitura.

5.2.3.2.16 UserFields
Retorna um objeto que é uma coleção de Campos de Usuário de Alarmes de uma Fonte de Alarme. Consulte o
tópico Coleção de Campos de Usuário de Alarmes para mais informações sobre a coleção de objetos retornados
por esta propriedade. Esta propriedade é somente de leitura.

5.2.3.2.17 Value
Contém o valor que foi avaliado para determinar se um alarme ocorre ou não. O valor padrão desta propriedade é
Null.

5.2.3.3 Fonte de Alarme Analógico


Esta seção contém informações sobre propriedades do objeto Fonte de Alarme Analógico (AnalogLevelAlarm). Este
objeto não possui eventos nem métodos associados.

NOTA
Quando o valor da propriedade Event, comum a todas as Fontes de Alarme, está configurado para Verdadeiro, as
propriedades HiEvent, HiHiEvent, LoEvent e LoLoEvent não podem ser modificadas, ou seja, todas as
subcondições do alarme se comportam como eventos.

5.2.3.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte de Alarme Analógico (AnalogLevelAlarm).

5.2.3.3.1.1 Hi
Habilita ou desabilita a verificação de alarmes do tipo Hi.

5.2.3.3.1.2 HiAckRequired
Indica se o alarme do tipo Hi requer reconhecimento.

5.2.3.3.1.3 HiAllowShelving
Indica se o alarme do tipo Hi pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.3.1.4 HiEvent
Define se a subcondição Hi do Alarme deve ser tratada como um evento. Se a propriedade Event, comum às
Fontes de Alarme, está configurada para Verdadeiro, esta propriedade não pode ser modificada e o valor permanece
sempre em Verdadeiro. Esta propriedade não pode ser alterada com o objeto ativo.

5.2.3.3.1.5 HiHi
Habilita ou desabilita a verificação de alarmes do tipo HiHi.

5.2.3.3.1.6 HiHiAckRequired
Indica se o alarme do tipo HiHi requer reconhecimento.

5.2.3.3.1.7 HiHiAllowShelving
Indica se o alarme do tipo HiHi pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

Objetos de Servidor 264


5.2.3.3.1.8 HiHiEvent
Define se a subcondição HiHi do Alarme deve ser tratada como um evento. Se a propriedade Event, comum às
Fontes de Alarme, está configurada para Verdadeiro, esta propriedade não pode ser modificada e o valor permanece
sempre em Verdadeiro. Esta propriedade não pode ser alterada com o objeto ativo.

5.2.3.3.1.9 HiHiLimit
Indica o nível em que o alarme HiHi é ativado.

5.2.3.3.1.10 HiHiMessageText
Ajusta a mensagem de texto do limite do alarme de tipo HiHi.

5.2.3.3.1.11 HiHiSeverity
Indica o nível de importância do alarme de tipo HiHi. As opções disponíveis para esta propriedade são -2: Crítica, 0:
Alta, 1: Média ou 2: Baixa.

5.2.3.3.1.12 HiHiShelveMaxCount
Define quantas vezes o alarme de tipo HiHi pode ser arquivado. O valor padrão desta propriedade é 0 (zero), ou
seja, sem limites para arquivamento.

5.2.3.3.1.13 HiHiShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme do tipo HiHi. O valor padrão desta
propriedade é 60 (uma hora).

5.2.3.3.1.14 HiLimit
Indica o nível em que o alarme Hi é ativado.

5.2.3.3.1.15 HiMessageText
Ajusta a mensagem de texto do limite do alarme de tipo Hi.

5.2.3.3.1.16 HiSeverity
Indica o nível de importância do alarme de tipo Hi. As opções disponíveis para esta propriedade são -2: Crítica, 0:
Alta, 1: Média ou 2: Baixa.

5.2.3.3.1.17 HiShelveMaxCount
Define quantas vezes o alarme de tipo Hi pode ser arquivado. O valor padrão desta propriedade é 0 (zero), ou seja,
sem limites para arquivamento.

5.2.3.3.1.18 HiShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme do tipo Hi. O valor padrão desta propriedade
é 60 (uma hora).

5.2.3.3.1.19 LevelDeadBand
Banda morta para os limites do nível do alarme.

5.2.3.3.1.20 LevelReturnMessageText
Ajusta a mensagem de retorno do nível do alarme.

5.2.3.3.1.21 Lo
Habilita ou desabilita a verificação de alarmes do tipo Lo.

5.2.3.3.1.22 LoAckRequired
Indica se o alarme do tipo Lo requer reconhecimento.

265 Objetos de Servidor


5.2.3.3.1.23 LoAllowShelving
Indica se o alarme do tipo Lo pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.3.1.24 LoEvent
Define se a subcondição Lo do Alarme deve ser tratada como um evento. Se a propriedade Event, comum às
Fontes de Alarme, está configurada para Verdadeiro, esta propriedade não pode ser modificada e o valor permanece
sempre em Verdadeiro. Esta propriedade não pode ser alterada com o objeto ativo.

5.2.3.3.1.25 LoLimit
Indica o nível em que o alarme Lo é ativado.

5.2.3.3.1.26 LoLo
Habilita ou desabilita a verificação de alarmes do tipo LoLo.

5.2.3.3.1.27 LoLoAckRequired
Indica se o alarme do tipo LoLo requer reconhecimento.

5.2.3.3.1.28 LoLoAllowShelving
Indica se o alarme do tipo LoLo pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.3.1.29 LoLoEvent
Define se a subcondição LoLo do Alarme deve ser tratada como um evento. Se a propriedade Event, comum às
Fontes de Alarme, está configurada para Verdadeiro, esta propriedade não pode ser modificada e o valor permanece
sempre em Verdadeiro. Esta propriedade não pode ser alterada com o objeto ativo.

5.2.3.3.1.30 LoLoLimit
Indica o nível em que o alarme LoLo é ativado.

5.2.3.3.1.31 LoLoMessageText
Ajusta a mensagem de texto do limite do alarme de tipo LoLo.

5.2.3.3.1.32 LoLoSeverity
Indica o nível de importância do alarme de tipo LoLo. As opções disponíveis para esta propriedade são -2: Crítica, 0:
Alta, 1: Média ou 2: Baixa.

5.2.3.3.1.33 LoLoShelveMaxCount
Define quantas vezes o alarme de tipo LoLo pode ser arquivado. O valor padrão desta propriedade é 0 (zero), ou
seja, sem limites para arquivamento.

5.2.3.3.1.34 LoLoShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme do tipo LoLo. O valor padrão desta
propriedade é 60 (uma hora).

5.2.3.3.1.35 LoMessageText
Ajusta a mensagem de texto do limite do alarme de tipo Lo.

5.2.3.3.1.36 LoSeverity
Indica o nível de importância do alarme de tipo Lo. As opções disponíveis para esta propriedade são -2: Crítica, 0:
Alta, 1: Média ou 2: Baixa.

5.2.3.3.1.37 LoShelveMaxCount
Define quantas vezes o alarme de tipo Lo pode ser arquivado. O valor padrão desta propriedade é 0 (zero), ou seja,
sem limites para arquivamento.

Objetos de Servidor 266


5.2.3.3.1.38 LoShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme do tipo Lo. O valor padrão desta
propriedade é 60 (uma hora).

5.2.3.4 Fonte de Alarme Banda Morta


Esta seção contém informações sobre propriedades do objeto Fonte de Alarme Banda Morta (DeadBandAlarm). Este
objeto não possui eventos nem métodos associados.

5.2.3.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte de Alarme Banda Morta (DeadBandAlarm).

5.2.3.4.1.1 DeadBand
Habilita ou desabilita a verificação de alarme de banda morta.

5.2.3.4.1.2 DeadBandAckRequired
Necessidade de reconhecimento para o alarme de banda morta.

5.2.3.4.1.3 DeadBandAllowShelving
Indica se o alarme de banda morta pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.4.1.4 DeadBandLimit
Limite para o alarme de banda morta.

5.2.3.4.1.5 DeadBandMessageText
Texto da mensagem de alarme de banda morta.

5.2.3.4.1.6 DeadBandReturnMessageText
Mensagem de retorno de alarme de banda morta.

5.2.3.4.1.7 DeadBandSetpoint
Limite de banda morta do alarme. Cada vez que o valor do Tag associado ultrapassa o valor desta propriedade,
para mais ou para menos do valor de DeadBandLimit, o alarme ocorre.

5.2.3.4.1.8 DeadBandSeverity
Importância do alarme de banda morta. As opções disponíveis para esta propriedade são -2: Crítica, 0: Alta, 1:
Média ou 2: Baixa.

5.2.3.4.1.9 DeadBandShelveMaxCount
Define quantas vezes o alarme de banda morta pode ser arquivado. O valor padrão desta propriedade é 0 (zero),
ou seja, sem limites para arquivamento.

5.2.3.4.1.10 DeadBandShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme de banda morta. O valor padrão desta
propriedade é 60 (uma hora).

5.2.3.5 Fonte de Alarme Digital


Esta seção contém informações sobre propriedades do objeto Fonte de Alarme Digital (DigitalAlarm). Este objeto não
possui eventos nem métodos associados.

5.2.3.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte de Alarme Digital (DigitalAlarm).

267 Objetos de Servidor


5.2.3.5.1.1 Digital
Habilita ou desabilita a verificação de alarme digital.

5.2.3.5.1.2 DigitalAckRequired
Necessidade de reconhecimento para o alarme digital.

5.2.3.5.1.3 DigitalAllowShelving
Indica se o alarme digital pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.5.1.4 DigitalLimit
Limite para o alarme digital.

5.2.3.5.1.5 DigitalMessageText
Texto da mensagem de alarme digital.

5.2.3.5.1.6 DigitalReturnMessageText
Mensagem de retorno do alarme digital.

5.2.3.5.1.7 DigitalSeverity
Severidade do alarme digital. As opções disponíveis para esta propriedade são -2: Crítica, 0: Alta, 1: Média ou 2:
Baixa.

5.2.3.5.1.8 DigitalShelveMaxCount
Define quantas vezes o alarme digital pode ser arquivado. O valor padrão desta propriedade é 0 (zero), ou seja,
sem limites para arquivamento.

5.2.3.5.1.9 DigitalShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme digital. O valor padrão desta propriedade é
60 (uma hora).

5.2.3.6 Fonte de Alarme Discreto


Esta seção contém informações sobre propriedades do objeto Fonte de Alarme Discreto (DiscreteAlarm). Este objeto
não possui eventos nem métodos associados.

NOTA
Quando o valor da propriedade Event, comum a todas as Fontes de Alarme, está configurado para Verdadeiro, a
propriedade Kind dos objetos da coleção de Subcondições da Fonte de Alarme Discreto não pode ser modificada,
ou seja, todas as subcondições do alarme se comportam como eventos.

5.2.3.6.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte de Alarme Discreto (DiscreteAlarm).

5.2.3.6.1.1 DiscreteReturnMessageText
Retorna ou modifica a mensagem de retorno da Fonte de Alarme Discreto. Se algum dos objetos da coleção de
Subcondições têm a propriedade Kind configurada para 2 (dois, Retorno), a propriedade Message deste objeto é
utilizada ao invés do valor definido nesta propriedade.

5.2.3.6.1.2 SubConditions
Retorna um objeto que é uma coleção das Subcondições da Fonte de Alarme Discreto. Consulte o tópico Coleção
de Subcondições para mais informações sobre a coleção de objetos retornados por esta propriedade. Esta
propriedade é somente de leitura.

Objetos de Servidor 268


5.2.3.6.2 Coleção de Subcondições
Esta seção contém informações sobre métodos e propriedades da Coleção de Subcondições
(DiscreteAlarmSubconditions) retornada pela propriedade SubConditions de uma Fonte de Alarme Discreto.

5.2.3.6.2.1 Métodos
Esta seção contém informações sobre Coleção de Subcondições (DiscreteAlarmSubconditions) de uma Fonte de
Alarme Discreto.
AddSubCondition
AddSubCondition([Name], [Caption], [Message], [Kind], [AckRequired], [Severity], [Value])
Adiciona um objeto Subcondição à coleção de Subcondições. Este método possui os parâmetros opcionais descritos
na tabela a seguir.
Parâmetros do método AddSubCondition
PARÂMETRO DESCRIÇÃO
Name O nome do objeto. Corresponde à propriedade Name
do objeto Subcondição. Se omitido, a Subcondição é
criada com o nome "Subcondicao". Se o valor passado
neste parâmetro já existe na coleção, é automaticamente
incrementado. Consulte a propriedade geral Name para
mais informações sobre os caracteres permitidos nos
nomes de objetos

Caption A descrição do objeto. Corresponde à propriedade


Caption do objeto Subcondição. Se omitido, a descrição
da Subcondição criada é uma String vazia

Message O texto da mensagem da Subcondição. Corresponde à


propriedade Message do objeto Subcondição. Se
omitido, a mensagem da Subcondição criada é uma
String vazia

Kind O tipo de comportamento desta Subcondição. Os valores


possíveis para este parâmetro são 0: Alarme, 1: Evento
ou 2: Retorno. Corresponde à propriedade Kind do
objeto Subcondição. Se omitido, o comportamento da
Subcondição criada é 0 (zero, Alarme)

AckRequired Indica se esta Subcondição exige reconhecimento.


Corresponde à propriedade AckRequired do objeto
Subcondição. Se omitido, a Subcondição criada exige
reconhecimento

Severity O tipo de severidade desta Subcondição. Os valores


possíveis para este parâmetro são -2: Crítica, 0: Alta, 1:
Média ou 2: Baixa. Corresponde à propriedade Severity
do objeto Subcondição. Se omitido, a severidade da
Subcondição criada é 1 (um, Média)

Value Parâmetro que contém um valor que é avaliado para


determinar se o alarme ocorre ou não. Corresponde à
propriedade Value, comum às Fontes de Alarme. Se
omitido, o valor da Subcondição criada é Null

Item
Item(Index)
Retorna uma referência para um objeto Subcondição, indicado por Index. Este parâmetro pode ser o índice na
coleção, iniciando em 1 (um), ou o nome do objeto, definido na propriedade Name.

269 Objetos de Servidor


RemoveSubCondition
RemoveSubCondition(Index)
Remove o objeto Subcondição, indicado pelo parâmetro Index. Este parâmetro pode ser o índice na coleção, iniciando
em 1 (um), ou o nome do objeto, definido na propriedade Name.

5.2.3.6.2.2 Propriedades
Esta seção contém informações sobre Coleção de Subcondições (DiscreteAlarmSubconditions) de uma Fonte de
Alarme Discreto.
Count
Retorna o número de objetos filhos, ou itens, de uma coleção de Subcondições. Esta propriedade trabalha em
conjunto com o método Item. Se a coleção não possui objetos filhos, o valor retornado é 0 (zero). Esta propriedade é
somente de leitura.

5.2.3.6.2.3 Subcondições
Esta seção contém informações sobre propriedades de objetos do tipo Subcondição (DiscreteAlarmSubcondition)
contidos na coleção retornada pela propriedade SubConditions da Fonte de Alarme Discreto. Este objeto não possui
eventos nem métodos associados.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Subcondição (DiscreteAlarmSubcondition).
AckRequired
Indica se este objeto Subcondição requer reconhecimento.
AllowShelving
Indica se esta Subcondição pode ser arquivada. O valor padrão desta propriedade é Verdadeiro.
Caption
Descrição da Subcondição.
Enabled
Habilita ou desabilita a Subcondição.
Kind
Indica o comportamento da Subcondição. Os valores possíveis para esta propriedade são 0: Alarme (padrão), 1:
Evento ou 2: Retorno. Se a propriedade Event, comum às Fontes de Alarme, está configurada para Verdadeiro, esta
propriedade não pode ser modificada e o valor permanece sempre em 1 (um, Evento). Esta propriedade não pode
ser alterada com o objeto ativo.
Limit
Define o valor da Fonte de Alarme para gerar a Subcondição.
Message
A mensagem do evento quando a Subcondição está ativa. Se a propriedade Kind está configurada como 2 (dois,
Retorno), esta propriedade é considerada como a mensagem de retorno do alarme.
Name
Nome do objeto Subcondição. Este valor não diferencia maiúsculas e minúsculas. Consulte a propriedade geral
Name para mais informações sobre os caracteres permitidos no nome deste objeto.
Severity
O tipo de severidade desta Subcondição. Os valores possíveis para esta propriedade são -2: Crítica, 0: Alta, 1: Média
ou 2: Baixa.
ShelveMaxCount
Define quantas vezes esta Subcondição pode ser arquivada. O valor padrão desta propriedade é 0 (zero), ou seja,
sem limites para arquivamento.
ShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento desta Subcondição. O valor padrão desta propriedade é 60
(uma hora).

Objetos de Servidor 270


5.2.3.7 Fonte de Alarme Taxa de Variação
Esta seção contém informações sobre propriedades do objeto Fonte de Alarme Taxa de Variação (ROCAlarm). Este
objeto não possui eventos nem métodos associados.

5.2.3.7.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fonte de Alarme Taxa de Variação (ROCAlarm).

5.2.3.7.1.1 ROC
Habilita ou desabilita a verificação de alarme de taxa de variação.

5.2.3.7.1.2 ROCAckRequired
Necessidade de reconhecimento para o alarme de taxa de variação.

5.2.3.7.1.3 ROCAllowShelving
Indica se o alarme de taxa de variação pode ser arquivado. O valor padrão desta propriedade é Verdadeiro.

5.2.3.7.1.4 ROCLimit
Limite para o alarme de taxa de variação. Para que o alarme ocorra, basta que o valor do Tag associado ultrapasse
este valor em um segundo.

5.2.3.7.1.5 ROCMessageText
Texto da mensagem do alarme de taxa de variação.

5.2.3.7.1.6 ROCReturnMessageText
Mensagem de retorno do alarme de taxa de variação.

5.2.3.7.1.7 ROCSeverity
Importância do alarme de taxa de variação. As opções disponíveis para esta propriedade são -2: Crítica, 0: Alta, 1:
Média ou 2: Baixa.

5.2.3.7.1.8 ROCShelveMaxCount
Define quantas vezes o alarme de taxa de variação pode ser arquivado. O valor padrão desta propriedade é 0
(zero), ou seja, sem limites para arquivamento.

5.2.3.7.1.9 ROCShelveMaxDuration
Define a duração máxima, em minutos, do arquivamento deste alarme de taxa de variação. O valor padrão desta
propriedade é 60 (uma hora).

5.2.4 Servidor de Alarmes


Esta seção contém informações sobre métodos e propriedades do objeto Servidor de Alarmes (AlarmServer). Este
objeto não possui eventos associados.

5.2.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Servidor de Alarmes (AlarmServer).

5.2.4.1.1 AckAllAlarms
AckAllAlarms([ActorID])
Executa o reconhecimento de todos os alarmes do servidor, independente da Área. Este método retorna um Booleano
que indica o sucesso ou não da operação. O parâmetro ActorID informa o nome do usuário responsável pelo
reconhecimento dos alarmes. Este parâmetro é opcional e, se omitido, assume o logon do usuário do E3 Viewer,
"Anonymous" se não há usuário logado ou "System" se a chamada do método originou-se no servidor. Exemplo:
Sub Botao1_Click()
' Ao clicar neste botão reconhece todos os alarmes
Application.GetObject("ServidorAlarmes1")._
271 Objetos de Servidor
AckAllAlarms(Application.User)
End Sub

5.2.4.1.2 AckArea
AckArea(Area, [ActorID])
Executa o reconhecimento dos alarmes em uma determinada Área. Este método retorna um Booleano que indica o
sucesso ou não da operação. O parâmetro Area especifica o nome da Área ou Áreas cujos alarmes são reconhecidos,
através da comparação entre os trechos iniciais dos nomes. Por exemplo, AckArea("ANA") reconhece alarmes das
Áreas "ANALOGICOS", "ANA.AREA2", etc. Se o valor deste parâmetro é uma String vazia, este método tem o mesmo
comportamento do método AckAllAlarms. O parâmetro ActorID informa o nome do usuário responsável pelo
reconhecimento dos alarmes. Este parâmetro é opcional e, se omitido, assume o logon do usuário do E3 Viewer,
"Anonymous" se não há usuário logado ou "System" se a chamada do método originou-se no servidor. Exemplo:
Sub Botao1_Click()
'Ao clicar neste botão reconhece os alarmes da Area1
Application.GetObject("ServidorAlarmes1").AckArea "Area1", _
Application.User
End Sub

5.2.4.1.3 LogTrackingEvent
LogTrackingEvent([Message], [ActorID], [Area], [Severity], [EventTime], [Source],
[EventCategory], [EventType], [UserFields], [AlarmSourceName], [FullAlarmSourceName])
Simula um evento ou alarme e o envia direto para o banco de dados do Servidor de Alarmes, sem passar pelo
E3Alarm. Por isto, este evento não pode ser visto no E3Alarm, nem tampouco o alarme pode ser reconhecido.
Cada parâmetro deste método permite especificar o valor do campo de mesmo nome no evento. Os campos do
evento são preenchidos de acordo com os parâmetros deste método, descritos na tabela a seguir.
Parâmetros do método LogTrackingEvent
NOME DESCRIÇÃO
Message Parâmetro texto que especifica o conteúdo do campo
Mensagem do evento. Se omitido, assume uma String
vazia

ActorID Parâmetro texto que especifica o conteúdo do campo


Operador do evento. Se omitido, assume o logon do
usuário do E3 Viewer, "Anonymous" se não há usuário
logado ou "System" se a chamada deste método
originou-se no servidor

Area Parâmetro texto que especifica o conteúdo do campo


Área do evento. Se omitido, assume uma String vazia

Severity Parâmetro numérico que determina a severidade do


evento. Se omitido, assume o valor 0 (zero), ou seja,
severidade alta

EventTime Especifica a estampa de tempo do evento. Se omitido,


assume o valor da estampa de tempo do momento da
chamada deste método

Source Parâmetro texto que especifica o conteúdo do campo


Fonte do evento. Se omitido, assume uma String vazia

EventCategory Parâmetro texto que especifica a categoria do evento. Se


omitido, assume uma String vazia

EventType Parâmetro texto que especifica o tipo do evento. Se


omitido, assume o valor "Tracking"

UserFields Parâmetro do tipo Vetor, em que cada posição assume


o valor do campo especificado pelo usuário. Se omitido,
usa os valores definidos na Coleção de Campos de
Usuário de Alarmes do Servidor de Alarmes

AlarmSourceName Parâmetro texto que especifica o nome da Fonte de


Alarme. Se omitido, assume uma String vazia

Objetos de Servidor 272


NOME DESCRIÇÃO
FullAlarmSourceName Parâmetro texto que especifica o caminho completo da
Fonte de Alarme, incluindo a Área, a Configuração de
Alarme e as possíveis Pastas onde o alarme está
inserido. Se omitido, assume uma String vazia

Os demais campos do evento não podem ser especificados e sempre assumem os valores a seguir:
· Valor (CurrentValue): 0.0
· Qualidade (Quality): ""
· Condição Ativa (ConditionActive): 0 (Falso)
· Nome da Condição (ConditionName): ""
· Nome da Subcondição (SubConditionName): ""
· Reconhecido (Acked): 1 (Verdadeiro)
· Precisa Ack (AckRequired): 0 (Falso)
· Habilitado (Enabled): 1 (Verdadeiro)
· EventTimeUTC: *Sempre igual a EventTime (como em eventos de alarme)
· Máscara (ChangeMask): 0 (zero)
· Cookie: 0 (zero)

NOTA
Este método falha se a opção Armazenar alarmes em banco de dados está desmarcada, ou quando falha o
armazenamento no banco de dados.

Exemplo:
Sub CommandButton1_Click()
' No parâmetro UserFields, para cada elemento do array,
' é mostrado o valor atribuído a ele.
Application.GetObject("ServidorAlarmes1").LogTrackingEvent_
"Clicou no botão", Application.User, "Operação", 2, , _
"Botão1", , , array(1, 2, "a", "b")
End Sub

5.2.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Servidor de Alarmes (AlarmServer).

5.2.4.2.1 ActiveAlarms
Determina o número total de alarmes ativos em uma aplicação. Esta propriedade é somente de leitura.

5.2.4.2.2 ActiveCritAlarms
Indica o número de alarmes ativos com severidade Crítica em uma aplicação. Esta propriedade é somente de
leitura.

5.2.4.2.3 ActiveCritNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Crítica em uma aplicação. Esta propriedade é
somente de leitura.

5.2.4.2.4 ActiveHighAlarms
Indica o número de alarmes ativos com severidade Alta em uma aplicação. Esta propriedade é somente de leitura.

5.2.4.2.5 ActiveHighNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Alta em uma aplicação. Esta propriedade é somente
de leitura.

273 Objetos de Servidor


5.2.4.2.6 ActiveLowAlarms
Indica o número de alarmes ativos com severidade Baixa em uma aplicação. Esta propriedade é somente de leitura.

5.2.4.2.7 ActiveLowNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Baixa em uma aplicação. Esta propriedade é
somente de leitura.

5.2.4.2.8 ActiveMedAlarms
Indica o número de alarmes ativos com severidade Média em uma aplicação. Esta propriedade é somente de leitura.

5.2.4.2.9 ActiveMedNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Média em uma aplicação. Esta propriedade é
somente de leitura.

5.2.4.2.10 ActiveNACKAlarms
Indica o número total de alarmes que estão sem reconhecimento em uma aplicação, ativos ou não. Esta propriedade
é somente de leitura.

5.2.4.2.11 BackupDiscardInterval
Indica o intervalo máximo de tempo, em minutos, horas, dias ou meses, dos dados de alarmes na tabela de backup
até serem descartados, independente do tempo que os dados permanecem na tabela principal. Por exemplo, para
manter os dados por 24 meses na tabela principal e mais seis meses na tabela de backup, o valor desta propriedade
deve ser de 30 meses. Esta propriedade trabalha em conjunto com a propriedade BackupDiscardTimeUnit. O valor
padrão desta propriedade é 12 (doze unidades de tempo indicadas em BackupDiscardTimeUnit).

NOTA
O tempo total indicado pela combinação das propriedades BackupDiscardInterval e BackupDiscardTimeUnit deve
ser maior que o tempo indicado pelas propriedades DiscardInterval e DiscardTimeUnit.

5.2.4.2.12 BackupDiscardTimeUnit
Esta propriedade indica a unidade de tempo em que os dados de alarmes de backup permanecem armazenados
até serem descartados. As opções disponíveis são 0: dtHour (horas), 1: dtDay (dias), 2: dtMonth (meses, padrão) ou 3:
dtMinute (minutos). Esta propriedade trabalha em conjunto com a propriedade BackupDiscardInterval.

5.2.4.2.13 DataSource
Define o objeto Banco de Dados que é utilizado para gravação dos dados dos alarmes. O valor padrão desta
propriedade é uma String vazia, ou seja, não há nenhum Banco de Dados para armazenar os dados.

5.2.4.2.14 DiscardInterval
Esta propriedade trabalha em conjunto com a propriedade DiscardTimeUnit e indica o intervalo de tempo durante
o qual os dados dos alarmes permanecem armazenados na tabela do banco de dados, até que sejam descartados. O
valor padrão desta propriedade é 1 (uma unidade de tempo indicada na propriedade DiscardTimeUnit). Se esta
propriedade é configurada com um valor menor ou igual ao valor da propriedade BackupDiscardInterval, o E3
automaticamente ajusta o valor de BackupDiscardInterval como o dobro do valor de DiscardInterval.

5.2.4.2.15 DiscardTimeUnit
Esta propriedade trabalha em conjunto com a propriedade DiscardInterval e indica a unidade de tempo em que
os dados de alarmes permanecem armazenados até que sejam descartados. As opções disponíveis são 0: dtHour
(horas), 1: dtDay (dias), 2: dtMonth (meses, padrão) ou 3: dtMinute (minutos).

5.2.4.2.16 EnableBackupTable
Cria ou não uma tabela de backup onde os dados de alarmes descartados permanecem por segurança. O valor
padrão desta propriedade é Verdadeiro, ou seja, a tabela é criada.

Objetos de Servidor 274


5.2.4.2.17 EnableDiscard
Indica se os dados dos alarmes são descartados ou não após um certo tempo. O valor padrão desta propriedade
é Falso, ou seja, os dados são armazenados indefinidamente na tabela.

5.2.4.2.18 ExcludeSuppressedAlarmsOnCounters
Quando configurada para Verdadeiro, desconsidera os alarmes suprimidos nos contadores gerais de alarmes. O
valor padrão desta propriedade é Falso.

5.2.4.2.19 InactiveCritNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Crítica em uma aplicação. Esta
propriedade é somente de leitura.

5.2.4.2.20 InactiveHighNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Alta em uma aplicação. Esta propriedade é
somente de leitura.

5.2.4.2.21 InactiveLowNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Baixa em uma aplicação. Esta propriedade
é somente de leitura.

5.2.4.2.22 InactiveMedNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Média em uma aplicação. Esta
propriedade é somente de leitura.

5.2.4.2.23 InactiveNACKAlarms
Determina o número total de alarmes inativos e não reconhecidos em uma aplicação. Esta propriedade é somente
de leitura.

5.2.4.2.24 Logging
Cria ou não um registro com informações dos alarmes no banco de dados especificado pela propriedade
DataSource. O valor padrão desta propriedade é Falso, ou seja, não cria este registro.

5.2.4.2.25 TableName
Define um nome para a tabela de alarmes. O valor padrão desta propriedade é "Alarms".

5.2.4.2.26 VerificationInterval
Esta propriedade trabalha em conjunto com a propriedade VerificationUnit para controlar o intervalo de tempo
que o E3 verifica a antiguidade dos dados de alarmes, para depois descartá-los. O valor padrão desta propriedade é
1 (uma unidade de tempo indicada na propriedade VerificationUnit).

5.2.4.2.27 VerificationUnit
Esta propriedade trabalha em conjunto com a propriedade VerificationInterval e indica a unidade de tempo em
que é realizada a verificação para descarte dos dados de alarmes. As opções disponíveis são 0: dtHour (horas), 1:
dtDay (dias), 2: dtMonth (meses, padrão) ou 3: dtMinute (minutos).

5.3 Banco de Dados


Esta seção contém informações sobre métodos e propriedades do objeto Banco de Dados (DBServer). Este objeto
não possui eventos associados.

5.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Banco de Dados (DBServer).

275 Objetos de Servidor


5.3.1.1 AccessSetDBPassword
AccessSetDBPassword(DBPwd)
Configura a senha de um banco de dados do tipo Access. O parâmetro DBPwd determina a senha a ser utilizada neste
banco de dados.

5.3.1.2 SetDBParameters
SetDBParameters(ServerName, UserName, Password, [DBName])
String de conexão com o banco de dados nas propriedades do objeto Banco de Dados. O parâmetro ServerName
determina o nome do servidor. O parâmetro UserName determina o nome do usuário. O parâmetro Password
determina a senha do login para se conectar ao banco de dados. O parâmetro DBName é o nome do banco de
dados utilizado no SQL Server. Para os demais bancos de dados, este parâmetro não é utilizado e pode ser omitido.

5.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Banco de Dados (DBServer).

5.3.2.1 ConnectionActive
Indica se o E3 possui uma conexão ativa com o banco de dados. O E3 normalmente utiliza duas conexões com este
banco de dados, uma para escritas e outra para leituras. A propriedade ConnectionActive está em Verdadeiro se
pelo menos uma destas duas conexões estiver conectada e funcionando. Esta propriedade não deve ser utilizada para
detectar falhas de conexão, já que ela pode estar em Falso em diversas situações, como por exemplo:
· Quando o banco de dados não está em uso (nenhuma operação de escrita ou leitura foi executada)
· Quando o banco de dados recém foi reconfigurado (quando uma propriedade de conexão do banco de dados é
alterada em tempo de execução as conexões são fechadas, e só são reconectadas na próxima operação de
escrita ou leitura)
· Quando a conexão com o banco de dados caiu (por exemplo, a rede não está disponível ou o banco de dados
foi fechado)
· Quando o objeto DBServer está desativado (apesar de que, mesmo com o objeto DBServer desativado, a
conexão pode ser reconectada se o aplicativo solicitar alguma leitura ou escrita imediata no banco de dados)

Esta propriedade é somente de leitura.

NOTA
Se o aplicativo gera operações de banco de dados de forma consistente, isto é, se está sempre gerando novas
escritas ou leituras, a propriedade ConnectionActive reporta corretamente o estado da conexão com o banco de
dados, já que ficam eliminadas as demais situações em que esta propriedade poderia estar em Falso.

5.3.2.2 CustomConnectionString
Configura ou retorna uma String personalizada de conexão a um banco de dados. A configuração desta
propriedade só tem efeito quando a propriedade UseCustomConnectionString está configurada para Verdadeiro. O
valor padrão desta propriedade é uma String vazia.

5.3.2.3 EnableSynchronization
Indica ao E3, se habilitada (Verdadeiro), que ele também deve executar a gravação dos dados em uma segunda
base de dados simultaneamente, para permitir uma maior segurança. Se a propriedade estiver habilitada e houver um
servidor Standby, o E3 executa a sincronização entre os bancos de dados dos dois servidores. O valor padrão desta
propriedade é Falso, ou seja, a sincronização está desabilitada.

5.3.2.4 MsSQLNetworkLibrary
Configura ou retorna o tipo de biblioteca de rede de um banco de dados do tipo SQL Server. Os valores possíveis
para esta propriedade estão descritos na propriedade NetLibrary.

Objetos de Servidor 276


5.3.2.5 MsSQLProvider
Configura ou retorna o provedor de dados OLE DB para acesso a um servidor SQL Server. Os valores possíveis
para esta propriedade são 1: SQLOLEDB ou 2: MSOLEDBSQL (padrão).

NOTA
A opção de provedor de dados SQLOLEDB foi descontinuada pela Microsoft e não deve ser utilizada. Entretanto,
aplicações criadas em versões anteriores à versão 6.0 continuam funcionando normalmente. No caso de uma
atualização destas aplicações para a versão 6.0, o E3 adiciona automaticamente à String de conexão o parâmetro de
compatibilidade "DataTypeCompatibility=80".

5.3.2.6 NetLibrary
Configura o tipo de biblioteca de rede do Banco de Dados. As opções disponíveis estão descritas na tabela a
seguir.
Opções disponíveis para a propriedade NetLibrary
OPÇÃO DESCRIÇÃO
0 - Default Biblioteca do tipo padrão

1 - NamedPipes Biblioteca do tipo Named Pipes

2 - TcpIp Biblioteca do tipo Winsock TCP/IP

3 - SpxIpx Biblioteca do tipo SPX/IPX

4 - BanyanVines Biblioteca do tipo Banyan Vines

5 - MultiProtocol Biblioteca do tipo Multi-protocolo (RPC)

NOTA
A propriedade NetLibrary somente está disponível em Bancos de Dados do tipo SQL Server.

5.3.2.7 nRetries
Esta propriedade especifica o número de vezes que o E3 tenta executar uma operação de banco de dados, além da
primeira tentativa. O valor padrão desta propriedade é 5 (cinco). Se o valor desta propriedade for igual a 0 (zero), é
executada apenas uma tentativa por operação. Caso haja uma perda de conexão com o banco de dados durante
qualquer uma das tentativas, a operação é abortada e as tentativas restantes são desconsideradas.

5.3.2.8 OracleEnableTimestamp
Habilita o uso do tipo de dados TIMESTAMP da Oracle, com precisão de milissegundos e disponível a partir da
versão 9.0. Se esta propriedade está configurada para Falso, o banco de dados usa o tipo de dados DATE, com
precisão de segundos.

NOTA
Configurar esta propriedade em Falso não tem efeito se a propriedade OracleUseADODrivers está configurada
para Verdadeiro.

5.3.2.9 OracleUseADODrivers
Permite usar as interfaces ADO (ActiveX Data Objects) do Oracle para que o objeto Consulta do E3 reconheça o tipo
de dados TIMESTAMP, possibilitando ler registros de tabelas do Oracle que possuam precisão de milissegundos.
Caso esta propriedade seja configurada em Falso, o banco de dados usa o tipo de dados DATE, com precisão de
segundos.

NOTA
Configurar esta propriedade em Verdadeiro não tem efeito se a propriedade OracleEnableTimestamp está
configurada para Falso.

277 Objetos de Servidor


5.3.2.10 ReconnectDelay
A propriedade ReconnectDelay determina o tempo de espera, em milissegundos, para que a aplicação execute uma
tentativa de restabelecer uma conexão perdida com o banco de dados. O valor padrão desta propriedade é 2000
(dois segundos).

5.3.2.11 SourceDatabase
Caso o Banco de Dados seja do tipo Access, este é o nome do arquivo .mdb. Caso o Banco de Dados seja do tipo
SQL Server, este é o nome do servidor SQL concatenado com o banco de dados escolhido, no formato
Servidor/Banco de Dados. Caso o Banco de Dados seja do tipo Oracle, este é o nome da conexão criada. Esta
propriedade é somente de leitura.

5.3.2.12 SourceType
Indica o banco de dados utilizado pelo objeto. As opções disponíveis são as seguintes:
· 0 - stAccess: Banco de dados Access (padrão)
· 1 - stOracle: Banco de dados Oracle
· 2 - stSqlServer: Banco de dados SQL Server

5.3.2.13 TimeOutCommand
Contém o tempo de espera para qualquer operação do banco de dados, antes que a aplicação gere um erro por
time-out. O valor padrão é 180 (três minutos).

5.3.2.14 TimeOutConnection
Contém o tempo de espera para realizar a conexão com o banco de dados, antes que a aplicação gere um erro por
time-out. O valor padrão é 15 segundos.

5.3.2.15 TotalFailedWrites
Indica a quantidade de operações dos arquivos .e3o que falharam e foram descartadas desde que a conexão com o
banco de dados foi ativada. Pode ser zerada automaticamente em diversas situações, como por exemplo:
· Ao desativar o objeto DBServer
· Se o processo E3DBEngine for fechado por algum motivo
· Se os parâmetros de configuração da conexão do objeto DBServer forem alterados

5.3.2.16 UseCustomConnectionString
Habilita ou desabilita o uso de uma String de conexão personalizada, configurada na propriedade
CustomConnectionString, ao conectar a um banco de dados.

5.3.2.17 UserName
Login utilizado para se conectar ao banco de dados. Esta propriedade é somente de leitura.

5.3.2.18 UseTransaction
Define se o Servidor de Banco de Dados utiliza as transações do banco de dados ou não. Se a propriedade estiver
em Verdadeiro, cada bloco de operações (200 operações) de banco de dados (operações do Histórico, Storage,
Formulas e Alarmes) são executadas de uma vez só, ou seja, em uma única transação.

5.4 Coleção de Campos de Usuário de Alarmes


Esta seção contém informações sobre métodos e propriedades comuns à coleção de Campos de Usuário de Alarmes
de objetos de Servidor do E3 (AlarmUserFieldsCollection), retornada pela propriedade UserFields de Áreas de
Alarme e Fontes de Alarme.

5.4.1 Métodos Comuns


Esta seção contém informações sobre os métodos comuns à coleção de Campos de Usuário de Alarmes de objetos
de Servidor do E3 (AlarmUserFieldsCollection).

Objetos de Servidor 278


5.4.1.1 Item
Item(Index)
Retorna um objeto Campo de Usuário de Alarmes indicado pelo parâmetro Index, que pode ser o valor da
propriedade Index (inteiro) ou o valor da propriedade Name (texto) do objeto.

5.4.2 Propriedades Comuns


Esta seção contém informações sobre as propriedades comuns à coleção de Campos de Usuário de Alarmes de
objetos de Servidor do E3 (AlarmUserFieldsCollection).

5.4.2.1 Count
Retorna o número de objetos filhos (itens) de uma coleção de Campos de Usuário de Alarmes. Se a Coleção não
contém objetos filhos, esta propriedade retorna o valor 0 (zero). Esta propriedade é somente de leitura.

5.4.3 Campo de Usuário de Alarmes


Esta seção contém informações sobre as propriedades dos objetos do tipo Campo de Usuário de Alarmes
(AlarmUserField) contidos na Coleção de Campos de Usuário de Alarmes retornada pela propriedade UserFields de
Áreas de Alarme, Fontes de Alarme e de Objetos de Servidor com comportamento de Área de Alarme. Este objeto
não possui eventos nem métodos associados.

5.4.3.1 Propriedades
Esta seção contém informações sobre as propriedades dos objetos do tipo Campo de Usuário de Alarmes
(AlarmUserField) contidos na coleção de Campos de Usuário de Alarmes.

5.4.3.1.1 Index
Retorna o índice deste objeto na Coleção de Campos de Usuário de Alarmes. Este valor pode ser utilizado como
parâmetro para o método Item da Coleção. Esta propriedade é somente de leitura.

5.4.3.1.2 Link
Retorna ou modifica a Associação configurada para este Campo de Usuário de Alarmes. Para alterar em tempo de
execução a Associação configurada nesta propriedade, deve-se desativar o objeto. Por exemplo:
Dim sAlarm
Set sAlarm = _
Application.GetObject("ConfigAlarms.Area.DigitalAlarm1")
sAlarm.Deactivate()
sAlarm.UserFields.Item("BatchName").Link = _
"Driver.TagBatchName.Value"
sAlarm.Activate()

5.4.3.1.3 Name
Retorna o nome deste objeto na Coleção de Campos de Usuário de Alarmes. Este valor pode ser utilizado como
parâmetro para o método Item da Coleção. Esta propriedade é somente de leitura.

5.4.3.1.4 Value
Retorna ou configura o valor atual do Campo de Usuário de Alarmes. Esta propriedade tem um comportamento
diferenciado dependendo se o objeto está ativo ou inativo. Com o objeto ativo, o valor retornado na leitura desta
propriedade obedece à seguinte lista de prioridades:
1. Se há um valor forçado (propriedade ValueSource igual a evsForcedValue), retorna este valor
2. Se há uma Associação configurada (propriedade ValueSource igual a evsLink), retorna o valor atual da
Associação
3. Busca o valor deste Campo de Usuário na Área hierarquicamente superior (percorre a hierarquia de Áreas em
sentido ascendente)
4. Se não há nenhuma Área hierarquicamente superior que tenha um valor forçado ou uma Associação configurada
para este Campo de Usuário, recupera o valor padrão do Campo de Usuário configurado no Servidor de Alarmes

Se o objeto estiver inativo, a leitura desta propriedade retorna o valor forçado, caso exista (propriedade ValueSource
igual a evsForcedValue). Se não há um valor forçado, a leitura da propriedade falha.
279 Objetos de Servidor
O comportamento das escritas nesta propriedade é o mesmo, tanto com o objeto ativo como inativo. A escrita falha
caso haja uma Associação configurada (propriedade ValueSource igual a evsLink). Caso contrário, o novo valor é
aceito e a propriedade ValueSource é automaticamente configurada para evsForcedValue.

5.4.3.1.5 ValueSource
Especifica a fonte da propriedade Value deste Campo de Usuário de Alarmes. Os valores possíveis para esta
propriedade são os seguintes:
· 0 - evsInherited: A propriedade Value é herdada do Servidor de Alarmes ou da Área superior (padrão)
· 1 - evsLink: A propriedade Value é fornecida pela propriedade Link
· 2 - evsForcedValue: A propriedade Value é fornecida pelo usuário

Esta propriedade aceita escritas tanto com o objeto ativo como inativo. Em ambos os casos, não é possível escrever o
valor evsLink. Para trocar a propriedade ValueSource para o valor evsLink, deve-se escrever diretamente na
propriedade Link (desativando o objeto se estiver em tempo de execução).

NOTA
Ao exportar um objeto Campo de Usuário de Alarmes, a propriedade ValueSource deve ser colocada após as
propriedades Link e Value na ordem das colunas.

5.5 Drivers
Esta seção contém informações sobre eventos, métodos e propriedades dos objetos Driver de Comunicação, Tag de
Comunicação, Bloco de Comunicação, Elemento de Bloco de Comunicação, Driver de Comunicação OPC, Tag de
Comunicação OPC, Bloco de Comunicação OPC, Elemento de Bloco de Comunicação OPC, Driver de Comunicação
OPC UA., Assinatura OPC UA, Tag de Comunicação OPC UA, Bloco de Comunicação OPC UA e Elemento de Bloco
de Comunicação OPC UA.

5.5.1 Driver de Comunicação


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Driver de Comunicação (IODriver).

5.5.1.1 Eventos
Esta seção contém informações sobre os eventos do objeto Driver de Comunicação (IODriver).

5.5.1.1.1 AfterStart
AfterStart()
Ocorre depois que o Driver de Comunicação iniciou a comunicação. É comum criar um script para este evento
utilizando o método Write para executar configurações em equipamentos. Exemplo:
Sub Driver1_AfterStart()
' Após iniciada a comunicação, escreve valores
' no equipamento ou dispositivo
Write 0, 2, 55, 2, 33.4
Write 0, 3, 55, 20, "Metal"
End Sub

5.5.1.1.2 AfterStop
AfterStop()
Ocorre depois que o Driver de Comunicação finalizou a comunicação. Utilize este evento para executar alguma ação
necessária após terminada a comunicação.

5.5.1.1.3 BeforeStart
BeforeStart()
Ocorre quando o Driver de Comunicação está prestes a iniciar a comunicação. Utilize este evento para executar
alguma ação necessária antes de iniciar a comunicação, como por exemplo a configuração de parâmetros. Exemplo:
Sub Driver1_BeforeStart()
' Executa a inicialização dos parâmetros do Driver
' antes de iniciar a comunicação
P1 = 0
P2 = 20
Objetos de Servidor 280
P3 = 80
P4 = 0
End Sub

5.5.1.1.4 BeforeStop
BeforeStop()
Ocorre quando o Driver de Comunicação está prestes a finalizar a comunicação. Utilize este evento para executar
alguma ação necessária antes que a comunicação seja terminada, como por exemplo escrever ou ler valores de um
equipamento antes que a comunicação não esteja mais disponível.

5.5.1.1.5 OnCommError
OnCommError(EvtType, Size, Element, N1, N2, N3, N4)
Ocorre quando algum erro de escrita ou leitura é detectado pelo Driver de Comunicação. Utilize este evento para
saber quando ocorreu uma falha de escrita ou leitura. As variáveis de evento recebem informações sobre o erro
ocorrido. Com estes valores, é possível rastrear quais Tags de Comunicação estão apresentando problemas de
comunicação.
Variáveis do evento OnCommError
NOME DESCRIÇÃO
EvtType Informa qual o tipo de operação o Driver de Comunicação
estava efetuando quando ocorreu o erro, conforme as
opções a seguir:
· 0: Erro de leitura de um só Elemento de Bloco de
Comunicação (Size = 1). Param1 é N1, Param2 é N2,
Param3 é N3 e Param4 é N4
· 1: Erro de escrita de um só Elemento de Bloco de
Comunicação (Size = 1). Param1 é N1, Param2 é N2,
Param3 é N3 e Param4 é N4
· 2: Erro de leitura de um Bloco de Comunicação. Size é
determinado pelo número de Elementos de Bloco de
Comunicação. Param1 é N1, Param2 é N2, Param3 é
N3 e Param4 é N4
· 3: Erro de escrita de um Bloco de Comunicação. Size é
determinado pelo número de Elementos de Bloco de
Comunicação. Param1 é N1, Param2 é N2, Param3 é
N3 e Param4 é N4

Size Quantidade de valores escritos ou lidos

Element Índice do Elemento de Bloco de Comunicação que estava


sendo lido ou escrito, dentro do Bloco de Comunicação

N1 Parâmetro 1 (um) da operação de leitura ou escrita que


gerou o erro

N2 Parâmetro 2 (dois) da operação de leitura ou escrita que


gerou o erro

N3 Parâmetro 3 (três) da operação de leitura ou escrita que


gerou o erro

N4 Parâmetro 4 (quatro) da operação de leitura ou escrita


que gerou o erro

Exemplo:
Sub Driver1_OnCommError(Type, Size, Element, N1, N2, N3, N4)
Application.GetObject("Dados.TagInterno1").Value = _
Application.GetObject("Dados.TagInterno1").Value + 1
Application.GetObject("Dados.EvtType").Value = EvtType
Application.GetObject("Dados.Size").Value = Size
Application.GetObject("Dados.Element").Value = Element
Application.GetObject("Dados.N1").Value = N1
Application.GetObject("Dados.N2").Value = N2

281 Objetos de Servidor


Application.GetObject("Dados.N3").Value = N3
Application.GetObject("Dados.N4").Value = N4
End Sub

5.5.1.1.6 OnCommErrorEx
OnCommErrorEx(ErrorInfo)
Ocorre logo após a execução do método OnCommError.
Informações do parâmetro ErrorInfo
NOME DESCRIÇÃO
ErrorInfo.EvtType Indica o tipo de operação que causou o erro. Os valores
possíveis são 0: Leitura de Tag de Comunicação, 1:
Escrita em Tag de Comunicação, 2: Leitura de Bloco de
Comunicação ou 3: Escrita em Bloco de Comunicação

ErrorInfo.Size Tamanho do Bloco de Comunicação que ocasionou o


erro. Se é um Tag de Comunicação, Size é igual a 1 (um)

ErrorInfo.Element Índice do Elemento de Bloco de Comunicação que


causou o erro

ErrorInfo.Nx Parâmetros Nx ou Bx, em que x pode ser 1 (um), 2 (dois),


3 (três) ou 4 (quatro), da operação que causou o erro

ErrorInfo.ParamDevice Parâmetro ParamDevice (String) da operação que


causou o erro

ErrorInfo.ParamItem Parâmetro ParamItem (String) da operação que causou


o erro

5.5.1.1.7 OnTagRead
OnTagRead(Tag)
Ocorre na leitura de um Tag de Comunicação, sempre que um novo valor ou um erro é retornado pelo Driver de
Comunicação, ou seja, se o valor ou a qualidade do Tag de Comunicação não mudarem, este evento não é disparado.
Para que este evento funcione, a propriedade EnableDriverEvent deve obrigatoriamente estar habilitada. Além disto,
a propriedade PercentDeadband também pode exercer influência sobre a ocorrência do evento, caso a propriedade
EnableDeadband esteja habilitada. Exemplo:
Sub Tags_OnTagRead(Tag)
Set Obj = Application.GetObject("Dados1.TagName")
Obj.Value = Tag.Name
Set Obj = Application.GetObject("Dados1.TagRead")
Obj.Value = True
Set Obj = Application.GetObject("Dados1.TagType")
Obj.Value = TypeName(Tag)
End Sub

5.5.1.1.8 OnTagWrite
OnTagWrite(Tag, Succeeded, User)
Ocorre quando uma escrita é disparada em qualquer Tag de Comunicação do Driver de Comunicação.
Variáveis do evento OnTagWrite
NOME DESCRIÇÃO
Tag Uma referência para o objeto do Tag de Comunicação
que está sofrendo a escrita. Por exemplo, pode-se
acessar a propriedade do Tag de Comunicação com a
sintaxe Tag.DocString

Succeeded Indica o sucesso ou falha da escrita

User Parâmetro que recebe o usuário que realizou a escrita. O


valor padrão deste parâmetro é "System". Se não houver
nenhum usuário logado no E3 Viewer que gerou o
evento, este parâmetro contém o valor "Anonymous"

Objetos de Servidor 282


5.5.1.2 Métodos
Esta seção contém informações sobre os métodos do objeto Driver de Comunicação (IODriver).

5.5.1.2.1 Write
Write(N1, N2, N3, N4, Value, [WriteSyncMode])
Executa a escrita de um dado em um equipamento. Este método retorna um Booleano que indica o sucesso ou não da
operação. Os parâmetros N1 a N4 correspondem aos parâmetros N do Driver de Comunicação. O parâmetro Value
define o valor a ser escrito no Driver de Comunicação. O parâmetro WriteSyncMode permite utilizar um modo de
escrita diferente do utilizado pelo Driver de Comunicação. As opções disponíveis para este parâmetro são 0: Usa o
modo de escrita configurado no Driver de Comunicação, 1: Executa uma escrita síncrona ou 2: Executa uma escrita
assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Para mais detalhes sobre estes parâmetros, consulte a documentação do Driver.

5.5.1.2.2 WriteEx
WriteEx(N1, N2, N3, N4, Value, [Timestamp], [Quality], [WriteStatus], [WriteSyncMode])
Executa a escrita de um dado em um equipamento. Este método retorna um Booleano que indica o sucesso ou não da
operação. Os parâmetros N1 a N4 correspondem aos parâmetros N do Driver de Comunicação. O parâmetro Value
define o valor a ser escrito no Driver de Comunicação. Para mais detalhes sobre estes parâmetros, consulte a
documentação do Driver. Os parâmetros Timestamp, Quality e WriteStatus são opcionais. Se omitidos, o
comportamento do método é o mesmo do método Write. O parâmetro Timestamp especifica a data e hora a ser
escrita no Tag de Comunicação, se suportada pelo equipamento. Se omitido, assume a data e hora do momento da
operação de escrita. O parâmetro Quality indica a qualidade, de 0 (zero) a 255. Se omitido, assume a qualidade Boa
(192). O parâmetro WriteStatus recebe um valor retornado pelo Driver de Comunicação, que indica o status da escrita,
se suportado, de acordo com a documentação própria. O parâmetro WriteSyncMode permite utilizar o modo de
escrita diferente do utilizado no Driver de Comunicação. As opções disponíveis para este parâmetro são 0: Usa o
modo de escrita configurado no Driver de Comunicação, 1: Executa uma escrita síncrona ou 2: Executa uma escrita
assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Exemplo:
Dim status
If Driver1.WriteEx(0, 0, 0, 0, 100, , , status) Then
MsgBox "Escrita bem-sucedida, status = " & status
Else
MsgBox "Escrita falhou, status = " & status
End If

5.5.1.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Driver de Comunicação (IODriver).

5.5.1.3.1 AsyncBatchFlushTimeMs
Esta propriedade define o tempo máximo que uma operação assíncrona pode esperar no E3Run antes de ser
enviada para o I/O Server. Os valores possíveis para esta propriedade variam entre 0 (zero) e 10000 (10 segundos).
Valores menores que 50 utilizam o valor de 50 milissegundos. O valor padrão desta propriedade é -1 (menos um), ou
seja, o tempo de espera é definido na opção Tempo Máximo de Espera (milissegundos) do grupo Agrupamento
de Operações Assíncronas da aba Propriedades da configuração do Domínio.

5.5.1.3.2 AsyncBatchSize
Esta propriedade define o número máximo de operações por Driver de Comunicação armazenadas na memória do
E3Run antes de enviar para o I/O Server. Os valores possíveis para esta propriedade variam entre 1 (um) e 100000. O
valor 0 (zero) desabilita o agrupamento de operações para este Driver de Comunicação. O valor padrão desta
propriedade é -1 (menos um), ou seja, o agrupamento é definido na opção Número Máximo de Operações por
Grupo do grupo Agrupamento de Operações Assíncronas da aba Propriedades da configuração do Domínio.

5.5.1.3.3 DisableIOServerPool
Força este Driver de Comunicação a não participar do Pool de processos do I/O Server, ou seja, este Driver de
Comunicação executa em um I/O Server exclusivo. O valor padrão desta propriedade é Falso.

283 Objetos de Servidor


NOTA
Para mais informações, consulte o tópico Pool de Processos IOServer no Manual do Usuário do E3.

5.5.1.3.4 DriverLocation
Define qual é o Driver utilizado por este Driver de Comunicação para efetuar a comunicação com um equipamento.
Esta propriedade aceita uma String com o caminho completo do Driver, caso não esteja no mesmo diretório do
Domínio, ou o caminho relativo se estiver no mesmo diretório do Domínio. Caso não haja um Domínio aberto no E3
Studio, o caminho relativo é considerado a partir da pasta onde se encontra o projeto ou biblioteca contendo este
Driver de Comunicação. Após isto, a propriedade DriverName muda para a descrição do Driver. Esta propriedade
não pode ser modificada após iniciada a comunicação. O valor padrão desta propriedade é uma String vazia.

NOTA
Aconselha-se utilizar sempre a opção Procurar DLL, no menu contextual do Driver de Comunicação para configurar
corretamente esta propriedade.

5.5.1.3.5 DriverName
A propriedade DriverName contém uma String que descreve o Driver associado a este Driver de Comunicação.
Para isto, deve-se antes configurar a propriedade DriverLocation. Esta propriedade é somente de leitura.

5.5.1.3.6 EnableReadGrouping
Permite otimizações de leitura ou agrupamento automático de Tags de Comunicação. Esta propriedade não pode
ser alterada com este objeto ativo. O valor padrão desta propriedade é Verdadeiro. A otimização de leitura só
acontece se este Driver de Comunicação suportar este recurso.

5.5.1.3.7 P1
Utilize a propriedade P1 para configurar um Driver de Comunicação. Consulte a documentação do Driver para a
correta configuração. Esta propriedade não pode ser modificada após iniciada a comunicação. O valor padrão desta
propriedade é 0 (zero). Exemplo:
Sub Driver1_BeforeStart()
' Driver1 é um objeto do tipo Driver de Comunicação
DriverLocation = "c:\driver\plc.dll"
P1 = 2
P2 = 1
P3 = 9600
End Sub

5.5.1.3.8 P2
Utilize a propriedade P2 para configurar um Driver de Comunicação. Consulte a documentação do Driver para a
correta configuração. Esta propriedade não pode ser modificada após iniciada a comunicação. O valor padrão desta
propriedade é 0 (zero). Exemplo:
Sub Driver1_BeforeStart()
' Driver1 é um objeto do tipo Driver de Comunicação
DriverLocation = "c:\driver\plc.dll"
P1 = 2
P2 = 1
P3 = 9600
End Sub

5.5.1.3.9 P3
Utilize a propriedade P3 para configurar um Driver de Comunicação. Consulte a documentação do Driver para a
correta configuração. Esta propriedade não pode ser modificada após iniciada a comunicação. O valor padrão desta
propriedade é 0 (zero). Exemplo:
Sub Driver1_BeforeStart()
' Driver1 é um objeto do tipo Driver de Comunicação
DriverLocation = "c:\driver\plc.dll"
P1 = 2
P2 = 1
P3 = 9600
End Sub

Objetos de Servidor 284


5.5.1.3.10 P4
Utilize a propriedade P4 para configurar um Driver de Comunicação. Consulte a documentação do Driver para a
correta configuração. Esta propriedade não pode ser modificada após iniciada a comunicação. O valor padrão desta
propriedade é 0 (zero). Exemplo:
Sub Driver1_BeforeStart()
' Driver1 é um objeto do tipo Driver de Comunicação
DriverLocation = "c:\driver\plc.dll"
P1 = 2
P2 = 1
P3 = 9600
P4 = 500
End Sub

5.5.1.3.11 ParamDevice
Define o endereço do equipamento acessado por este Driver de Comunicação. Esta propriedade é herdada pelos
Tags de Comunicação filhos deste objeto, que podem sobrescrever este valor, se necessário.

5.5.1.3.12 ReadRetries
Indica o número de re-tentativas de leitura deste Driver de Comunicação em caso de erro. Se esta propriedade é
configurada para 2 (dois), por exemplo, indica que este Driver de Comunicação tenta duas vezes mais uma
comunicação falhada, sem contar a tentativa original.

5.5.1.3.13 ShareMaximum
A propriedade ShareMaximum define o número máximo de Drivers de Comunicação que são agrupados em um I/O
Server compartilhado. Esta propriedade só é utilizada se a propriedade ShareServer está habilitada. Exemplo:
' Este Driver não é compartilhado
ShareServer = False
ShareMaximum = <qualquer valor>
' Todos os drivers são agrupados no mesmo I/O Server
' Não define um limite
ShareServer = True
ShareMaximum = 0
' Agrupa cada 5 Drivers em um I/O Server
ShareServer = True
ShareMaximum = 5

5.5.1.3.14 ShareServer
Se a propriedade ShareServer está configurada para Verdadeiro, isto significa que este Driver de Comunicação
compartilha a execução entre os demais Drivers de Comunicação que possuam a mesma String em DriverLocation.
Isto implica que somente o primeiro Driver de Comunicação configurado executa a inicialização da comunicação.
Todos os demais Drivers de Comunicação compartilhados ignoram todos os parâmetros de configuração, de P1 a P4,
e também outras configurações. Do contrário, se a propriedade está configurada para Falso, este Driver de
Comunicação não compartilha qualquer tipo de comunicação com outros Drivers de Comunicação. Esta propriedade
não pode ser modificada após iniciada a comunicação. O valor padrão desta propriedade é Falso.

5.5.1.3.15 WriteFeedbackMode
Esta propriedade permite controlar a confirmação, ou feedback, das escritas em Tags de Comunicação. É aplicável
somente a Tags de Comunicação que possam ser lidos, ou seja, possuam a propriedade AllowRead em Verdadeiro.
Através desta propriedade, é possível tornar mais imediata a leitura de Tags de Comunicação que recebem escritas.
Esta propriedade possui as opções de configuração descritas na tabela a seguir.
Opções disponíveis para a propriedade WriteFeedbackMode
OPÇÃO DESCRIÇÃO
0 - wfWaitNextRead A leitura do Tag de Comunicação é realizada
normalmente na próxima varredura

1 - wfImmediateReadAfterWrite Após cada escrita, uma leitura de confirmação é


realizada o mais cedo possível (valor padrão)

285 Objetos de Servidor


OPÇÃO DESCRIÇÃO
2 - wfTrustWriteSuccess Se este Driver de Comunicação indicar sucesso na escrita,
o valor escrito é assumido diretamente pelo Tag de
Comunicação, sem lê-lo do equipamento

Aplicações anteriores à existência desta propriedade assumem o valor 0 - wfWaitNextRead quando carregadas.
Exemplo:
Sub CommandButton1_Click()
Dim modo
modo = Application.GetObject("Driver1").WriteFeedbackMode
MsgBox modo
Select case modo
Case 0
MsgBox "A leitura do Tag é realizada na próxima varredura."
Case 1
MsgBox "Após cada escrita, uma leitura de confirmação _
é realizada o mais cedo possível."
Case 2
MsgBox "Se este Driver indicar sucesso na escrita, _
o valor escrito é assumido diretamente pelo Tag, _
sem lê-lo do equipamento."
End Select
End Sub

NOTA
Quando é usado o modo 2 - wfTrustWriteSuccess, a estampa de tempo e a qualidade podem estar erradas, já que
em uma escrita bem sucedida, o valor é assumido pelo Tag de Comunicação sem buscar a estampa de tempo e a
qualidade no equipamento. Além disto, o próprio valor assumido pode ter um pequeno desvio devido a qualquer
tipo de arredondamento que possa ocorrer no Driver de Comunicação ou no equipamento. Deve ser levado em
conta ainda que alguns Drivers de Comunicação ou protocolos podem indicar sucesso mesmo quando a escrita
falha. Por tudo isto, os outros modos, 1 - wfImmediateReadAfterWrite ou 0 - wfWaitNextRead, devem ser
preferidos sempre que possível.

5.5.1.3.16 WriteNullAsEmpty
Esta propriedade permite que um Driver de Comunicação converta um valor recebido como Null para Empty em
casos onde o Driver de Comunicação não aceita valores nulos. Tanto a qualidade quanto a estampa de tempo do
valor são propagados sem alteração, exceto no caso em que o valor recebido como Null tenha uma qualidade boa.
Nesta situações, o valor é convertido para Empty e a qualidade é alterada para 0 (zero, qualidade ruim). O valor
padrão desta propriedade é Falso.

5.5.1.3.17 WriteRetries
Indica o número de re-tentativas de escrita deste Driver de Comunicação em caso de erro. Se esta propriedade é
igual a 2 (dois), indica que este Driver de Comunicação tenta duas vezes mais uma comunicação falhada, sem contar a
tentativa original.

5.5.1.3.18 WriteSyncMode
Determina como as escritas são enviadas para o I/O Server, no modo síncrono ou assíncrono. Esta propriedade
possui as opções de configuração descritas na tabela a seguir.
Opções disponíveis para a propriedade WriteSyncMode
OPÇÃO DESCRIÇÃO
0 - wsmDefault Modo síncrono (valor padrão)

1 - wsmSync Modo síncrono. Sempre que um valor é escrito em


algum Tag de Comunicação, o E3Run envia a escrita para
o I/O Server e aguarda o retorno da escrita

Objetos de Servidor 286


OPÇÃO DESCRIÇÃO
2 - wsmAsyncUnconfirmed Modo assíncrono sem confirmação. Todas as escritas
são enviadas para o I/O Server sem aguardar o retorno,
e assume-se sempre que a escrita funcionou. Quando em
modo assíncrono, os métodos de escrita dos Tags de
Comunicação, Write e WriteEx, sempre retornam
Verdadeiro imediatamente, e o status da escrita, nos
métodos que retornam este status, é sempre vazio ou
Empty. O evento OnTagWrite deste Driver de
Comunicação é executado assim que a escrita é enviada
para o I/O Server, e o parâmetro Succeeded permanece
sempre em Verdadeiro

As escritas assíncronas são executadas pelo I/O Server assim que este Driver de Comunicação estiver disponível,
quando a leitura atual terminar. Se várias escritas assíncronas são enviadas para o I/O Server, este Driver de
Comunicação só retoma as leituras depois que todas as escritas assíncronas são executadas.

5.5.1.4 Bloco de Comunicação


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Bloco de Comunicação (IOBlock).

5.5.1.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto Bloco de Comunicação (IOBlock).

5.5.1.4.1.1 OnRead
OnRead()
Ocorre quando uma leitura do Bloco de Comunicação é efetuada pelo Driver de Comunicação. Utilize o evento
OnRead para efetuar alguma operação logo após algum dado ser modificado no objeto Bloco de Comunicação,
como por exemplo as propriedades Quality, TimeStamp ou ainda a propriedade Value de algum Elemento de Bloco
de Comunicação. Exemplo:
Sub IOBloco1_OnRead()
' Ao ler o bloco, atribui ao tag InternalTag1
' o valor do elemento de bloco elm1
Set obj = Application.GetObject("DataServer1.InternalTag1")
Set elm = Application.GetObject("Driver1.IOBloco1.elm1")
obj.Value = elm.Value
End Sub

5.5.1.4.2 Métodos
Esta seção contém informações sobre os métodos do objeto Bloco de Comunicação (IOBlock).

5.5.1.4.2.1 Write
Write([WriteSyncMode])
Executa a escrita do valor corrente do Bloco de Comunicação em um equipamento. Normalmente, este comando de
script só é usado quando a propriedade AllowWrite deste objeto é igual a Falso. O parâmetro WriteSyncMode
permite utilizar o modo de escrita diferente do utilizado no Driver de Comunicação. As opções disponíveis para este
parâmetro são 0: Usa o modo de escrita configurado no Driver de Comunicação, 1: Executa uma escrita síncrona ou 2:
Executa uma escrita assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Para mais detalhes, consulte a documentação do Driver. Este método retorna um Booleano que indica o
sucesso ou não da operação.

5.5.1.4.2.2 WriteEx
WriteEx([Value], [Timestamp], [Quality], [WriteStatus], [WriteSyncMode])
Executa a escrita de um valor em um equipamento. Todos os parâmetros são opcionais e, se omitidos, o
comportamento do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou
não da operação. O parâmetro Value define o valor a ser escrito no Driver de Comunicação. O tipo de dados
depende do Driver de Comunicação e, se omitido, assume o valor corrente do Tag de Comunicação. O parâmetro

287 Objetos de Servidor


Timestamp especifica a data e hora a ser escrita no Tag de Comunicação, se suportada pelo equipamento. Se omitido,
assume a data e hora do momento da operação de escrita. O parâmetro Quality indica a qualidade, de 0 (zero) a 255.
Se omitido, assume a qualidade Boa (192). O parâmetro WriteStatus recebe um valor retornado pelo Driver de
Comunicação, que indica o status da escrita, se suportado, de acordo com a documentação própria. O parâmetro
WriteSyncMode permite utilizar o modo de escrita diferente do utilizado no Driver de Comunicação. As opções
disponíveis para este parâmetro são 0: Usa o modo de escrita configurado no Driver de Comunicação, 1: Executa uma
escrita síncrona ou 2: Executa uma escrita assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Exemplo:
Sub Tag1_OnRead()
' O método WriteEx pode ser usado para transferir
' valores de variáveis de um driver para outro.
Application.GetObject("Driver2.Tag")._
WriteEx Value, TimeStamp, Quality
End Sub

5.5.1.4.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Bloco de Comunicação (IOBlock).

5.5.1.4.3.1 AdviseType
Controla o modo Advise. As opções disponíveis para esta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag de Comunicação é mantido atualizado se a
propriedade AllowRead é igual a Verdadeiro

1 - AdviseWhenLinked O Tag de Comunicação só é atualizado se AllowRead é


igual a Verdadeiro e o Tag de Comunicação está
associado a algum objeto ativo, como por exemplo um
Display de uma Tela aberta ou um Alarme habilitado,
entre outros. A associação do Tag de Comunicação para
este propósito pode ser executada nas propriedades
Value, RawValue, Quality e de Bit00 até Bit31 de
Elementos de Bloco de Comunicação, e Quality e
TimeStamp de Blocos de Comunicação (valor padrão)

5.5.1.4.3.2 AllowRead
Define se este Bloco de Comunicação deve ou não ser lido pelo Driver de Comunicação. Caso a propriedade
AllowRead esteja habilitada, então o Driver automaticamente atualiza os Elementos de Bloco de Comunicação
inseridos neste Bloco de Comunicação, em intervalos de tempo definidos pela propriedade Scan. Caso contrário, este
Bloco de Comunicação não é lido ou atualizado. O valor padrão desta propriedade é Verdadeiro. Exemplo:
Sub Botao1_Click()
' Faz com que seja parada a leitura do bloco
Set obj = Application.GetObject("Driver1.bloco1")
obj.AllowRead = False
End Sub

5.5.1.4.3.3 AllowWrite
Define se este Bloco de Comunicação deve ou não ser escrito quando a propriedade Value dos Elementos de Bloco
de Comunicação é modificada. Se esta propriedade está configurada para Verdadeiro, as modificações são enviadas
para o equipamento associado ao Driver de Comunicação. Caso contrário as modificações são ignoradas. Os
Elementos de Bloco de Comunicação não aceitam valores caso esta propriedade esteja configurada para Falso, a não
ser que a propriedade AllowRead também esteja configurada para Falso. Exemplo:
Sub Botao1_Click()
' Faz com que seja desabilitada a escrita do bloco
Set obj = Application.GetObject("Driver1.bloco1")
obj.AllowWrite = False
End Sub

Objetos de Servidor 288


5.5.1.4.3.4 B1
Especifica a qual conjunto de dados no equipamento este Bloco de Comunicação está associado. Consulte a
documentação do Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a
comunicação. Exemplo:
Sub Bloco1_BeforeStart()
B1 = 2
B2 = 1
B3 = 9600
End Sub

5.5.1.4.3.5 B2
Especifica a qual conjunto de dados no equipamento este Bloco de Comunicação está associado. Consulte a
documentação do Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a
comunicação. Exemplo:
Sub Bloco1_BeforeStart()
B1 = 2
B2 = 1
B3 = 9600
End Sub

5.5.1.4.3.6 B3
Especifica a qual conjunto de dados no equipamento este Bloco de Comunicação está associado. Consulte a
documentação do Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a
comunicação. Exemplo:
Sub Bloco1_BeforeStart()
B1 = 2
B2 = 1
B3 = 9600
End Sub

5.5.1.4.3.7 B4
Especifica a qual conjunto de dados no equipamento este Bloco de Comunicação está associado. Consulte a
documentação do Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a
comunicação. Exemplo:
Sub Bloco1_BeforeStart()
B1 = 2
B2 = 1
B3 = 9600
B4 = 524
End Sub

5.5.1.4.3.8 EnableDeadBand
A propriedade EnableDeadBand habilita ou desabilita a propriedade PercentDeadBand dos Elementos de Bloco
de Comunicação. Se esta propriedade está configurada para Verdadeiro, o valor do Bloco de Comunicação é
atualizado somente se este mudar e o novo valor exceder o limite definido pela propriedade PercentDeadBand de
qualquer um dos Elementos de Bloco de Comunicação. Caso contrário, o Bloco de Comunicação é sempre atualizado
e o limite de banda morta não é verificado. Sempre que possível, é recomendado manter a banda morta habilitada,
pois melhora a performance da aquisição e do processamento de dados. Normalmente, a banda morta é desabilitada
apenas para os Tags de Comunicação que retornem valores representando eventos que precisam ser tratados no
evento OnRead do Tag de Comunicação. O valor padrão desta propriedade é Verdadeiro.

NOTAS
· Caso haja mais de um Elemento de Bloco de Comunicação mapeado para o mesmo índice, a configuração de
banda morta utilizada é aquela que resulte no menor valor absoluto de banda morta.
· Se algum índice do Bloco de Comunicação possuir um Elemento de Bloco de Comunicação não mapeado, a banda
morta neste índice é igual a 0 (zero), ou seja, qualquer variação no valor do Elemento de Bloco de Comunicação
viola a banda morta.
· Se a propriedade EnableDeadBand está habilitada, o último valor enviado ao Bloco de Comunicação é
comparado com o valor lido no momento, Elemento por Elemento. Se qualquer um dos Elementos de Bloco de
Comunicação violar a banda morta, o Bloco de Comunicação inteiro é atualizado.

289 Objetos de Servidor


5.5.1.4.3.9 EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação que contém o Bloco de Comunicação. Se a propriedade EnableDriverEvent do Tag de Comunicação
está configurada para Verdadeiro, é habilitada a geração do evento OnTagRead por este Tag de Comunicação. Caso
contrário, não ocorre. O Tag de Comunicação, Bloco de Comunicação e Elemento de Bloco de Comunicação podem
gerar este evento. O evento ocorre no Driver de Comunicação e não no Bloco de Comunicação.

5.5.1.4.3.10 ParamDevice
Define o endereço do equipamento acessado pelo Bloco de Comunicação. Esta propriedade é herdada do Driver
de Comunicação, mas o valor pode ser sobrescrito, se necessário.

5.5.1.4.3.11 ParamItem
Identifica o dado que este Bloco de Comunicação acessa em um equipamento.

5.5.1.4.3.12 Quality
A propriedade Quality informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação atribui um novo valor para o Bloco de Comunicação, também é configurada a qualidade daquele dado.
Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, Qualidade Ruim).

NOTA
Para mais informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

5.5.1.4.3.13 Scan
Especifica qual tempo de varredura é utilizado pelo servidor para atualizar o Bloco de Comunicação. Esta
propriedade é representada em milissegundos, pode ser modificada após iniciada a comunicação e é utilizada apenas
quando a propriedade AllowRead está habilitada. Ao configurar esta propriedade nos diversos Blocos de
Comunicação presentes na aplicação, recomenda-se aumentar o valor da propriedade Scan para aqueles Blocos de
Comunicação que não variam muito no equipamento, possibilitando assim que outros Blocos de Comunicação de
maior prioridade sejam lidos com maior frequência, aumentando assim a performance geral do sistema. O valor
padrão desta propriedade é 1000, ou um segundo. O valor do scan deve ser maior que 0 (zero). Exemplo:
Sub Bloco de comunicacao1_BeforeStart()
Scan = 152
End Sub

5.5.1.4.3.14 Size
Define o tamanho do conjunto de valores deste Bloco de Comunicação. Consulte a documentação do Driver utilizado
para conhecer qual o limite para esta propriedade, de acordo com os parâmetros B1 até B4. Criando os Elementos de
Bloco de Comunicação, possibilita-se o acesso aos valores lidos e também permite a escrita de valores para o
equipamento. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Bloco de comunicacao1_BeforeStart()
Size = 10
End Sub

5.5.1.4.3.15 TimeStamp
A propriedade TimeStamp é atualizada sempre que ocorrer alguma mudança de valor ou de estado nas
propriedades Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à
qualidade do Bloco de Comunicação. Esta propriedade é somente de leitura. O valor padrão desta propriedade é
"00:00:00".

5.5.1.4.4 Elemento de Bloco de Comunicação


Esta seção contém informações sobre métodos e propriedades do objeto Elemento de Bloco de Comunicação
(IOBlockElement). Este objeto não possui eventos associados.

5.5.1.4.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Elemento de Bloco de Comunicação (IOBlockElement).

Objetos de Servidor 290


Write
Write([WriteSyncMode])
Executa a escrita do valor corrente do Elemento de Bloco de Comunicação no equipamento. Normalmente, este
comando de script só é usado quando a propriedade AllowWrite deste objeto é igual a Falso. O parâmetro
WriteSyncMode permite utilizar o modo de escrita diferente do utilizado no Driver de Comunicação. As opções
disponíveis para este parâmetro são 0: Usa o modo de escrita configurado no Driver de Comunicação, 1: Executa uma
escrita síncrona ou 2: Executa uma escrita assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Para mais detalhes, consulte a documentação do Driver. Este método retorna um Booleano que indica o
sucesso ou não da operação.
WriteEx
WriteEx([Value], [Timestamp], [Quality], [WriteStatus], [WriteSyncMode])
Executa a escrita de um valor no equipamento. Todos os seus parâmetros são opcionais e, se omitidos, o
comportamento do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou
não da operação. O parâmetro Value define o valor a ser escrito no Driver de Comunicação. O tipo de dados
depende do Driver de Comunicação e, se omitido, assume o valor corrente do Tag de Comunicação. O parâmetro
Timestamp especifica a data e hora a ser escrita no Tag de Comunicação, se suportada pelo equipamento. Se omitido,
assume a data e hora do momento da operação de escrita. O parâmetro Quality indica a qualidade, de 0 (zero) a 255.
Se omitido, assume a qualidade Boa (192). O parâmetro WriteStatus recebe um valor retornado pelo Driver de
Comunicação, que indica o status da escrita, se suportado pelo Driver de Comunicação, de acordo com a
documentação própria. O parâmetro WriteSyncMode permite utilizar o modo de escrita diferente do utilizado no Driver
de Comunicação. As opções disponíveis para este parâmetro são 0: Usa o modo de escrita configurado no Driver de
Comunicação, 1: Executa uma escrita síncrona ou 2: Executa uma escrita assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Exemplo:
Sub Tag1_OnRead()
' O método WriteEx pode ser usado para transferir
' valores de variáveis de um driver para outro.
Application.GetObject("Driver2.Tag")._
WriteEx Value, TimeStamp, Quality
End Sub

5.5.1.4.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Elemento de Bloco de Comunicação
(IOBlockElement).
Bit00 até Bit31
As propriedades de bit Bit00 até Bit31 representam juntas os 32 bits do valor presente na propriedade Value do
Elemento de Bloco de Comunicação, em que Bit00 é o bit menos significativo e Bit31 o bit mais significativo. Modificar
cada um destes bits implica na igual modificação da propriedade Value do Elemento de Bloco de Comunicação, e
vice-versa, mas isto somente ocorre quando a propriedade UseBitFields está configurada para Verdadeiro. O valor
padrão destas propriedades é Falso.
DeviceHigh
A propriedade DeviceHigh define o valor máximo atingido pelo Elemento de Bloco de Comunicação no
equipamento. Esta propriedade é utilizada no cálculo do valor da propriedade PercentDeadBand, e também para
executar o ajuste de escala do valor proveniente do equipamento antes de ser atribuído à propriedade Value. Da
mesma forma, no momento da escrita é realizada a operação inversa antes de enviar o valor para o Driver de
Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada para Verdadeiro. O
valor padrão desta propriedade é 1000.

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste na escala, ou seja,
representam os bits dos valores lidos pelo equipamento antes da conversão.

DeviceLow
A propriedade DeviceLow define qual o valor mínimo atingido por este Elemento de Bloco de Comunicação no
equipamento. Esta propriedade é utilizada no cálculo do valor da propriedade PercentDeadBand, e também para
realizar o ajuste de escala do valor proveniente do equipamento antes de ser atribuído à propriedade Value. Da

291 Objetos de Servidor


mesma forma, no momento da escrita, é realizada a operação inversa antes de enviar o valor para o Driver de
Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada para Verdadeiro. O
valor padrão desta propriedade é 0 (zero).

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste na escala, ou seja,
representam os bits dos valores lidos pelo equipamento antes da conversão.

EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação que contém o Bloco de Comunicação. Se a propriedade EnableDriverEvent do Tag de Comunicação
está configurada para Verdadeiro, é habilitada a geração do evento OnTagRead por este Tag de Comunicação. Caso
contrário, não ocorre. O Tag de Comunicação, Bloco de Comunicação e Elemento de Bloco de Comunicação podem
gerar este evento. O evento ocorre no Driver de Comunicação e não no Bloco de Comunicação.
EnableScaling
A propriedade EnableScaling habilita ou desabilita a escala de valor para o valor enviado e recebido do
equipamento. Se esta propriedade está configurada para Verdadeiro, todo valor proveniente do equipamento sofre
ajuste de escala conforme as propriedades DeviceHigh, DeviceLow, EUHigh e EULow antes de ser atribuído à
propriedade Value. Caso contrário, nenhum ajuste de escala é efetuado em nenhum dos dois sentidos, escrita e
leitura. O valor padrão desta propriedade é Falso. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala de um elemento temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EU
Esta propriedade é utilizada para identificar qual unidade de engenharia o valor representa, como por exemplo
graus, metros ou KW/h. O valor padrão desta propriedade é vazio. Exemplo:
Sub ElementodeBloco1_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EUHigh
Define qual valor máximo deve ser atribuído à propriedade Value, ajustando a escala ao valor do equipamento
antes desta atribuição. Da mesma forma, no momento da escrita é realizada a operação inversa antes de enviar o
valor para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada
para Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala de um elemento temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

Objetos de Servidor 292


EULow
Define qual valor mínimo deve ser atribuído à propriedade Value, ajustando a escala ao valor do equipamento
antes desta atribuição. Da mesma forma, no momento da escrita, é realizada a operação inversa antes de enviar o
valor para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada
para Verdadeiro. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala de um elemento temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
Index
Especifica a posição que o Elemento de Bloco de Comunicação ocupa entre os Elementos configurados pela
propriedade Size do Bloco de Comunicação no qual está inserido. Esta propriedade aceita valores entre 0 (zero) e um
número menor do que o valor definido em Size. Por exemplo, configurando um Bloco de Comunicação para ter Size
igual a 20, o número máximo válido para a propriedade Index é 19 e o mínimo é 0 (zero). Esta propriedade pode ser
alterada após iniciada a comunicação. O valor padrão desta propriedade é 0 (zero), porém ao mapear os Elementos
de Bloco de Comunicação de um Bloco de Comunicação o E3 Studio automaticamente ajusta o parâmetro Index para
um valor de acordo com o especificado. Exemplo:
Sub Elemento_OnStartRunning()
Index = 15
End Sub
PercentDeadBand
A propriedade PercentDeadBand determina a variação mínima do valor ou banda morta de um Elemento de Bloco
de Comunicação, para que o valor no E3 seja atualizado. Este valor é especificado como um percentual da diferença
entre as propriedades DeviceHigh e DeviceLow. Esta propriedade só é utilizada caso a propriedade
EnableDeadBand do Bloco de Comunicação esteja configurada para Verdadeiro. Se a propriedade PercentDeadBand
é igual a 0 (zero), o Elemento de Bloco de Comunicação não tem banda morta, e qualquer variação no seu valor é
repassada para o E3. Caso contrário, só é enviado para o E3 um novo valor cuja diferença, em relação ao valor atual
no E3, seja maior que a banda morta. O valor padrão desta propriedade é 0 (zero).
Quality
A propriedade Quality informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação atribui um novo valor para o Elemento de Bloco de Comunicação, também é configurada a qualidade
daquele dado. Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, Qualidade Ruim).

NOTA
Para mais informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

RawValue
Acessa o valor original do Elemento de Bloco de Comunicação anterior à escala, ou seja, independente da
configuração da propriedade EnableScaling. Portanto, se esta propriedade é igual a Falso, as propriedades Value e
RawValue apresentam o mesmo comportamento.
UseBitFields
Se esta propriedade está configurada para Verdadeiro, toda vez que o valor da propriedade Value é modificada,
atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de Value toda vez que
alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o equipamento se a
propriedade AllowWrite do Bloco de Comunicação está configurada para Verdadeiro. Caso contrário, os bits não
sofrem nem acarretam qualquer mudança. Esta propriedade pode ser atualizada após ter sido iniciada a
comunicação. O valor padrão desta propriedade é Falso.
Value
Atualizada sempre que uma nova leitura válida de um valor do equipamento é realizada, utilizando-se a
configuração B1 até B4 do Bloco de Comunicação onde este Elemento de Bloco de Comunicação está inserido, e
considerando-se a posição na tabela lida através da propriedade Index. O tipo de dados desta variável, um número

293 Objetos de Servidor


inteiro, ponto flutuante ou texto, depende do Driver de Comunicação ao qual o Elemento de Bloco de Comunicação
está associado e da configuração.
Esta propriedade somente é atualizada desta forma se a propriedade AllowRead do objeto Bloco de Comunicação
ao qual o Elemento de Bloco de Comunicação pertence está configurada para Verdadeiro, e quando não houver erros
de comunicação. Neste caso, somente as propriedades Quality e TimeStamp são atualizadas, de acordo com o
tempo de varredura definido em Scan. Outra forma de utilizar esta propriedade é para escrever valores no
equipamento. Para isto, atribua um novo valor à propriedade Value ou a algum dos bits Bit00 até Bit31. Neste caso,
a propriedade AllowWrite do objeto Bloco de Comunicação deve estar configurada para Verdadeiro.
Esta também é a propriedade padrão do objeto Elemento de Bloco de Comunicação. Sendo assim, uma referência
por valor a um Elemento de Bloco de Comunicação não necessita obrigatoriamente explicitar a propriedade Value
para acessar o valor. Caso esta propriedade não esteja sendo atualizada, verifique se a propriedade Index está
corretamente configurada. O valor padrão desta propriedade é vazio ou sem valor. Exemplo:
Sub Botao1_Click()
' Acessa um elemento e mostra o valor atual
' elm1 é um objeto tipo Bloco de comunicação
Set obj = Application.GetObject("Driverde_
Comunicacao1.Block1.elm1")
MsgBox "Valor atual de elm1: " & obj.Value
' Isto também pode ser feito de outra forma,
' sem mostrar a propriedade Value, que é padrão
MsgBox "Valor atual de elm1: " & obj
End Sub

5.5.1.5 Pasta
Esta seção contém informações sobre as propriedades do objeto Pasta do Driver de Comunicação (IOFolder). Este
objeto não possui eventos nem métodos associados.

5.5.1.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Pasta do Driver de Comunicação (IOFolder).

5.5.1.5.1.1 ParamDevice
Define o endereço do equipamento acessado pela Pasta. Esta propriedade é herdada do Driver de Comunicação e
o valor pode ser sobrescrito, se necessário.

5.5.1.6 Tag de Comunicação


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Tag de Comunicação (IOTag).

5.5.1.6.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tag de Comunicação (IOTag).

5.5.1.6.1.1 OnRead
OnRead()
Ocorre quando é efetuada uma leitura do Tag de Comunicação pelo Driver de Comunicação. Utilize o evento OnRead
para efetuar alguma operação logo após algum dado ser modificado no Tag de Comunicação, como por exemplo as
propriedades Value, Quality ou TimeStamp. Este evento é gerado por uma leitura em background. Exemplo:
Sub CommTag1_OnRead()
' Ao ler o tag, atribui o seu valor ao tag InternalTag1
Set obj = Application.GetObject("DataServer1.InternalTag1")
obj = Value ' Valor de CommTag1
End Sub

5.5.1.6.2 Métodos
Esta seção contém informações sobre os métodos do objeto Tag de Comunicação (IOTag).

5.5.1.6.2.1 Write
Write([WriteSyncMode])
Executa a escrita do valor corrente do Tag de Comunicação no equipamento. Normalmente, este comando de script
só é usado quando a propriedade AllowWrite deste objeto é igual a Falso. O parâmetro WriteSyncMode permite

Objetos de Servidor 294


utilizar o modo de escrita diferente do utilizado no Driver de Comunicação. As opções disponíveis para este
parâmetro são 0: Usa o modo de escrita configurado no Driver de Comunicação, 1: Executa uma escrita síncrona ou 2:
Executa uma escrita assíncrona, sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Para mais detalhes, consulte a documentação do Driver. Este método retorna um Booleano que indica o
sucesso ou não da operação.

5.5.1.6.2.2 WriteEx
WriteEx([Value], [Timestamp], [Quality], [WriteStatus], [WriteSyncMode])
Executa a escrita de um valor no equipamento. Todos os seus parâmetros são opcionais e, se omitidos, o
comportamento do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou
não da operação.
O parâmetro Value define o valor a ser escrito no Driver de Comunicação. O tipo de dados depende do Driver de
Comunicação e, se omitido, assume o valor corrente do Tag de Comunicação. Timestamp especifica a data e hora a
ser escrita no Tag de Comunicação, se suportada pelo equipamento. Se omitido, assume a data e hora do momento
da operação de escrita. Quality indica a qualidade, de 0 (zero) a 255. Se omitido, assume a qualidade Boa (192). O
parâmetro WriteStatus recebe um valor retornado pelo Driver de Comunicação, que indica o status da escrita, se
suportado, de acordo com a documentação própria. O parâmetro WriteSyncMode permite utilizar o modo de escrita
diferente do utilizado no Driver de Comunicação. As opções disponíveis para este parâmetro são 0: Usa o modo de
escrita configurado no Driver de Comunicação, 1: Executa uma escrita síncrona ou 2: Executa uma escrita assíncrona,
sem confirmação.
Se o parâmetro WriteSyncMode é omitido, também é utilizado o modo de escrita configurado no Driver de
Comunicação. Exemplo:
Sub Tag1_OnRead()
' O método WriteEx pode ser usado para transferir
' valores de variáveis de um driver para outro.
Application.GetObject("Driver2.Tag")._
WriteEx Value, TimeStamp, Quality
End Sub

5.5.1.6.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag de Comunicação (IOTag).

5.5.1.6.3.1 AdviseType
Controla o modo Advise. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag de Comunicação é mantido atualizado se a
propriedade AllowRead é igual a Verdadeiro

1 - AdviseWhenLinked O Tag de Comunicação só é atualizado se AllowRead é


igual a Verdadeiro e o Tag de Comunicação está
associado a algum objeto ativo, por exemplo um Display
de uma Tela aberta ou um Alarme habilitado, entre
outros. A associação do Tag de Comunicação para este
propósito pode ser realizada nas propriedades Value,
RawValue, TimeStamp, Quality e Bit00 até Bit31 do
Tag de Comunicação (padrão)

Exemplo:
Sub CommandButton3_Click()
MsgBox Application._
Application.GetObject("Driver1.Tag1").AdviseType
End Sub

5.5.1.6.3.2 AllowRead
Configure esta propriedade para definir se este Tag de Comunicação deve ou não ser lido pelo Driver de
Comunicação. Se esta propriedade está configurada para Verdadeiro, o Driver de Comunicação automaticamente
atualiza as propriedades Value, Bits (de Bit00 até Bit31) e RawValue deste objeto em intervalos de tempo definidos
295 Objetos de Servidor
pela propriedade Scan. Caso contrário, este Tag de Comunicação não é lido. O valor padrão desta propriedade é
Verdadeiro. Exemplo:
Sub Botao1_Click()
' Faz com que seja parada a leitura do tag
Set obj = Application.GetObject("Driver1.tag")
obj.AllowRead = False
End Sub

5.5.1.6.3.3 AllowWrite
Configure esta propriedade para definir se este Tag de Comunicação deve ou não ser escrito automaticamente
quando as propriedades Value, qualquer uma das propriedades de Bits, de Bit00 até Bit31, ou RawValue são
modificadas. Se esta propriedade está configurada para Verdadeiro, as modificações são enviadas para o
equipamento associado ao Driver de Comunicação. Caso contrário, as modificações são ignoradas. O valor padrão
desta propriedade é Verdadeiro. Exemplo:
Sub Botao1_Click()
' Faz com que seja desabilitada a escrita do tag
Set obj = Application.GetObject("Driver1.tag")
obj.AllowWrite = False
End Sub

5.5.1.6.3.4 Bit00 até Bit31


As propriedades de bit Bit00 até Bit31 representam juntas os 32 bits do valor presente na propriedade Value do
objeto Tag de Comunicação, em que Bit00 é o bit menos significativo e Bit31 o bit mais significativo. Modificar cada
um destes bits implica na igual modificação da propriedade Value do Tag de Comunicação, e vice-versa, mas isto
somente ocorre quando a propriedade UseBitFields está configurada para Verdadeiro. O valor padrão destas
propriedades é Falso.

5.5.1.6.3.5 DeviceHigh
A propriedade DeviceHigh define qual o valor máximo atingido pelo Tag de Comunicação no equipamento. Esta
propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento antes de ser atribuído
à propriedade Value. Da mesma forma, no momento da escrita é realizada a operação inversa antes de enviar o valor
para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada para
Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.1.6.3.6 DeviceLow
A propriedade DeviceLow define o valor mínimo atingido por este Tag de Comunicação no equipamento. Esta
propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento antes de ser atribuído
à propriedade Value. Da mesma forma, no momento da escrita é realizada a operação inversa antes de enviar o valor
para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está configurada para
Verdadeiro. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0

Objetos de Servidor 296


EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.1.6.3.7 EnableDeadBand
A propriedade EnableDeadBand habilita ou desabilita a propriedade PercentDeadBand. Se esta propriedade está
configurada para Verdadeiro, o valor do Tag de Comunicação é atualizado somente se este mudar e o novo valor
exceder o limite definido pela propriedade PercentDeadBand. Caso contrário, o Tag de Comunicação é sempre
atualizado e o limite de banda morta não é verificado. Sempre mantenha a banda morta habilitada, pois melhora a
performance da aquisição de dados e processamento. Deve-se desabilitar a banda morta somente em casos onde o
Driver de Comunicação está retornando eventos de Tags Digitais ou Analógicos, e seja necessário processar estes
eventos via script no evento OnRead do Tag de Comunicação. O valor padrão desta propriedade é Verdadeiro.

5.5.1.6.3.8 EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação que contém este Tag de Comunicação. Se a propriedade EnableDriverEvent do Tag de Comunicação
está configurada para Verdadeiro, é habilitada a geração do evento OnTagRead por este Tag de Comunicação. Caso
contrário, não ocorre. O Tag de Comunicação, Bloco de Comunicação e Elemento de Bloco de Comunicação podem
gerar este evento. O evento ocorre no Driver de Comunicação e não no Tag de Comunicação.

5.5.1.6.3.9 EnableScaling
A propriedade EnableScaling habilita ou desabilita a escala de valor para o valor enviado e recebido do
equipamento. Se esta propriedade está configurada para Verdadeiro, todo valor proveniente do equipamento sofre
ajuste de escala nas propriedades DeviceHigh, DeviceLow, EUHigh e EULow, antes de ser atribuído à propriedade
Value. Caso contrário, nenhum ajuste de escala é efetuado em nenhum dos dois sentidos, escrita e leitura. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

5.5.1.6.3.10 EU
Esta propriedade é utilizada para identificar a unidade de engenharia que o valor representa, como por exemplo
graus, metros ou KW/h. O valor padrão desta propriedade é vazio. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

5.5.1.6.3.11 EUHigh
Define qual o valor máximo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento antes desta atribuição. Da mesma forma, no momento da escrita é realizada a operação inversa antes
de enviar o valor para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está
configurada para Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
297 Objetos de Servidor
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.1.6.3.12 EULow
Define qual o valor mínimo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento antes desta atribuição. Da mesma forma, no momento da escrita, é realizada a operação inversa antes
de enviar o valor para o Driver de Comunicação. Esta conversão só ocorre quando a propriedade EnableScaling está
configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EULow = 100
End Sub

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.1.6.3.13 N1
Especifica a variável do equipamento a que este Tag de Comunicação está associado. Consulte a documentação do
Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a comunicação. O valor
padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
N1 = 10
End Sub

5.5.1.6.3.14 N2
Especifica a variável do equipamento a que este Tag de Comunicação está associado. Consulte a documentação do
Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a comunicação. O valor
padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
N2 = 3
End Sub

5.5.1.6.3.15 N3
Especifica a variável do equipamento a que este Tag de Comunicação está associado. Consulte a documentação do
Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a comunicação. O valor
padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
N1 = 10
N3 = 5
N4 = 20
End Sub

Objetos de Servidor 298


5.5.1.6.3.16 N4
Especifica a variável do equipamento a que este Tag de Comunicação está associado. Consulte a documentação do
Driver para a correta configuração. Esta propriedade pode ser modificada após iniciada a comunicação. O valor
padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
N1 = 10
N4 = 20
End Sub

5.5.1.6.3.17 ParamDevice
Define o endereço do equipamento acessado por este Tag de Comunicação. Esta propriedade é herdada do Driver
de Comunicação, mas o valor pode ser sobrescrito, se necessário.

5.5.1.6.3.18 ParamItem
Identifica o dado que este Tag de Comunicação acessa em um equipamento.

5.5.1.6.3.19 PercentDeadBand
A propriedade PercentDeadBand determina a variação mínima do valor ou banda morta de um Tag de
Comunicação, para que o valor no E3 seja atualizado. Este valor é especificado como um percentual da diferença
entre as propriedades DeviceHigh e DeviceLow. Esta propriedade só é utilizada caso a propriedade
EnableDeadBand do mesmo Tag de Comunicação esteja configurada para Verdadeiro. Se a propriedade
PercentDeadband é igual a 0 (zero), o Tag de Comunicação não tem banda morta, e qualquer variação no valor é
repassada para o E3. Caso contrário, só é enviado para o E3 um novo valor cuja diferença, em relação ao valor atual
no E3, seja maior que a banda morta. O valor padrão desta propriedade é 0 (zero).

5.5.1.6.3.20 Quality
A propriedade Quality informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação atribui um novo valor para o Tag de Comunicação, também é configurada a qualidade daquele dado.
Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, Qualidade Ruim).

NOTA
Para mais informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

5.5.1.6.3.21 RawValue
Acessa o valor original do Tag de Comunicação anterior à escala, ou seja, independente da configuração da
propriedade EnableScaling. Portanto, se esta propriedade é igual a Falso, as propriedades Value e RawValue
apresentam o mesmo comportamento.

5.5.1.6.3.22 Scan
Utilize a propriedade Scan para especificar o tempo de varredura que é utilizado pelo servidor para atualizar a
propriedade Value. Esta propriedade é representada em milissegundos, pode ser modificada após iniciada a
comunicação e é utilizada apenas quando a propriedade AllowRead está configurada para Verdadeiro. Ao configurar
esta propriedade nos diversos Tags de Comunicação presentes em uma aplicação, recomenda-se aumentar o valor
da propriedade Scan para aqueles Tags de Comunicação que não variam muito no equipamento, possibilitando assim
que outros Tags de Comunicação de maior prioridade sejam lidos com maior frequência, aumentando assim a
performance geral do sistema. O valor padrão desta propriedade é 1000, ou um segundo. O valor do scan deve ser
maior que 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
Scan = 1500
End Sub

5.5.1.6.3.23 TimeStamp
A propriedade TimeStamp é atualizada sempre que ocorrer alguma mudança de valor ou estado nas
propriedades Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à
qualidade do Tag de Comunicação. Esta é uma propriedade somente para leitura. O valor padrão desta propriedade
é "00:00:00".

299 Objetos de Servidor


5.5.1.6.3.24 UseBitFields
Caso a propriedade UseBitFields esteja configurada para Verdadeiro, toda vez que o valor da propriedade Value
é modificado, atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de Value
toda vez que alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o equipamento,
se a propriedade AllowWrite está configurada para Verdadeiro. Caso contrário, os bits não sofrem nem acarretam
qualquer mudança. Esta propriedade pode ser atualizada após ter sido iniciada a comunicação.

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.1.6.3.25 Value
Atualizada sempre que uma nova leitura válida de um valor do equipamento é executada, utilizando-se a
configuração dos parâmetros de N1 até N4. O tipo de dados desta variável, um número inteiro, ponto flutuante ou
texto, depende do Driver de Comunicação ao qual o Tag de Comunicação está associado e da configuração.
Esta propriedade somente é atualizada desta forma se a propriedade AllowRead está configurada para Verdadeiro, e
quando não houver erros de comunicação. Neste caso, somente as propriedades Quality e TimeStamp são
atualizadas, de acordo com o tempo de varredura definido em Scan. Outra forma de utilizar esta propriedade é para
escrever valores no equipamento. Para isto, atribua um novo valor à propriedade Value ou a algum dos bits Bit00 até
Bit31. Neste caso, a propriedade AllowWrite deve estar configurada para Verdadeiro.
Esta também é a propriedade padrão do objeto Tag de Comunicação. Sendo assim, uma referência por valor a um
Tag de Comunicação não necessita obrigatoriamente explicitar a propriedade Value para acessar o valor. O valor
padrão desta propriedade é vazio. Exemplo:
Sub Botao1_Click()
' Acessa um tag e mostra o valor atual
' tag1 é um objeto tipo Tag de Comunicação
Set obj = Application.GetObject("Driver de Comunicação1._
tag1")
MsgBox "Valor atual de tag1: " & obj.Value
' Isto também pode ser feito de outra forma,
' sem mostrar a propriedade Value, que é o padrão
MsgBox "Valor atual de tag1: " & obj
End Sub

NOTA
Os valores dos bits, as propriedades de Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam
os bits do valor lido do equipamento antes da conversão.

5.5.2 Driver de Comunicação OPC


Esta seção contém informações sobre eventos e propriedades do objeto Driver de Comunicação OPC (OPCDriver).
Este objeto não possui métodos associados.

5.5.2.1 Eventos
Esta seção contém informações sobre os eventos do objeto Driver de Comunicação OPC (OPCDriver).

5.5.2.1.1 OnTagRead
OnTagRead(Tag)
Ocorre na leitura de um Tag, sempre que um novo valor ou erro é retornado pelo servidor OPC, ou seja, se o valor ou
a qualidade do Tag não mudarem, o evento não é disparado. Para que este evento ocorra, a propriedade
EnableDriverEvent do Tag deve obrigatoriamente estar habilitada.

5.5.2.1.2 OnTagWrite
OnTagWrite(Tag, Succeeded, User)
Ocorre quando uma escrita é disparada em qualquer Tag do Driver de Comunicação OPC. Para que o evento ocorra,
a propriedade EnableDriverEvent do Tag deve obrigatoriamente estar habilitada. Se a escrita é assíncrona, o evento
OnTagWrite é gerado apenas quando o servidor enviar a resposta indicando o efetivo sucesso ou não da escrita.

Objetos de Servidor 300


Parâmetros do evento OnTagWrite
NOME DESCRIÇÃO
Tag Uma referência para o objeto Tag que está sofrendo a
escrita. Por exemplo, pode-se acessar a propriedade do
Tag usando a sintaxe Tag.DocString

Succeeded Um valor Booleano que indica sucesso ou falha na escrita

User Parâmetro que recebe o usuário que executou a escrita.


O valor padrão deste parâmetro é "System". Se não
houver nenhum usuário logado no E3 Viewer que gerou
o evento, este parâmetro contém o valor "Anonymous".
Se a escrita é assíncrona ou se ocorreu uma falha
reportada de forma assíncrona, este parâmetro sempre
contém o valor "System"

5.5.2.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Driver de Comunicação OPC (OPCDriver).

5.5.2.2.1 CallTimeout
Especifica o tempo limite para a resposta de qualquer chamada ou acesso a um servidor OPC, como por exemplo
escritas, criação de Grupos OPC, criação, remoção e browsing de Tags, mudança no modo Advise dos Tags, etc. Caso
este tempo seja excedido, o E3 considera o servidor como travado ou indisponível e inicia o processo de reconexão.
O valor desta propriedade não pode ser negativo. Configurar esta propriedade com o valor 0 (zero) desabilita este
tempo limite, fazendo com que acessos ao servidor OPC possam demorar um tempo indefinido, eventualmente
travando todo o aplicativo caso este acesso seja síncrono. O valor padrão desta propriedade é 10000 (10 segundos).
Aplicações criadas em versões anteriores, ao serem carregadas na versão atual, assumem o valor 0 (zero) por
questões de compatibilidade. Este valor deve ser ajustado com cuidado, para que não tranque a aplicação e nem
force uma desconexão sem necessidade, caso o servidor OPC realmente demore para responder determinadas
requisições.

5.5.2.2.2 Compatibility
Permite controlar o uso das interfaces padrão OPC pelo Cliente OPC do E3. As opções disponíveis são as
seguintes:
· 0 - AnyVersion: Funcionamento normal, padrão e recomendado, o Driver de Comunicação OPC comunica com
servidores DA 2.0x e 1.0a, dando preferência ao uso de interfaces 2.0x
· 1 - Version10A: Permite forçar a comunicação no padrão DA 1.0a para servidores que suportam DA 2.0x e 1.0a
· 2 - Version20: Permite forçar a comunicação apenas no padrão OPC DA 2.0

Esta propriedade não pode ser modificada quando a comunicação do cliente OPC estiver habilitada, tanto no E3
Studio quanto em tempo de execução.

NOTA
Apenas em último caso o Driver de Comunicação OPC deve ser configurado com um valor diferente de 0 -
AnyVersion. Esta propriedade é de uso avançado, e se aplica restritamente para contornar alguma situação de
possível incompatibilidade com algum servidor OPC específico.

5.5.2.2.3 ConnectionTimeout
Especifica o tempo máximo para estabelecer uma conexão com um servidor OPC, incluindo todos os passos da
conexão, mesmo os passos antes do acesso ao servidor em si, como acesso ao serviço OPCENUM ou ao Registro do
Windows. O valor desta propriedade não pode ser negativo. Configurar esta propriedade com o valor 0 (zero)
desabilita este tempo, fazendo com que o limite seja o efetivo tempo de retorno de erro pelos serviços necessários
para acessar o servidor OPC. O valor padrão é 10000 (10 segundos). Aplicações criadas em versões anteriores, ao
serem carregadas na versão atual, assumem o valor 0 (zero) por questões de compatibilidade.

301 Objetos de Servidor


5.5.2.2.4 ReconnectPeriod
Controla o período da conexão com o Servidor OPC. Se a conexão é perdida, o Driver de Comunicação OPC para e
reinicia até que esta ação retorne sucesso. O período é configurado em milissegundos e quando o valor é
configurado para 0 (zero), a reconexão é desabilitada. Pelo fato do Driver de Comunicação OPC ser parado e iniciado,
os eventos BeforeStart e AfterStop são gerados. Quando a conexão é perdida, todos os Tags relacionados são
desconectados do seu estado atual (bad/quality/null value). Exemplo:
Sub DriverOPC1_AfterStart()
Application.GetObject("DriverOPC1.GrupoOPC1")._
ReconnectPeriod = 0
End Sub

5.5.2.2.5 ServerId
Determina o servidor ao qual o Driver de Comunicação OPC deve se conectar. Apesar de o valor padrão da
propriedade ser vazio, se este valor estiver vazio o Driver de Comunicação OPC não vai se conectar. Esta propriedade
só pode ser modificada quando o Driver de Comunicação OPC não está conectado. Exemplo:
Sub CommandButton1_Click()
Set Opc = Application.GetObject("DriverOPC1")
Opc.Deactivate
Opc.ServerId = "ElipseSCADA.OPCSvr.1"
Opc.ServerMachine = "\\server2"
Opc.Activate
End Sub

5.5.2.2.6 ServerMachine
Esta propriedade determina o endereço da estação onde está executando o servidor OPC. Para aplicações que
estão executando localmente, esta propriedade pode permanecer em branco (padrão). Caso contrário, é necessário
especificar o caminho, como por exemplo "\\NomeServidor". Esta propriedade só pode ser modificada quando o
Driver de Comunicação OPC estiver desconectado. Exemplo:
Sub CommandButton1_Click()
Set Opc = Application.GetObject("DriverOPC1")
Opc.Deactivate
Opc.ServerId = "ElipseSCADA.OPCSvr.1"
Opc.ServerMachine = "\\server2"
Opc.Activate
End Sub

5.5.2.2.7 ServerName
Esta propriedade retorna o nome ou a descrição do servidor OPC. Esta propriedade é diferente da propriedade
ServerID, que é um código. Esta propriedade é somente de leitura. Exemplo:
Sub Driver OPC1_AfterStart()
MsgBox _
Application.GetObject("DriverOPC1.GrupoOPC1").ServerName
End Sub

5.5.2.2.8 ServerStatus
Determina o estado da conexão com o servidor OPC. Esta propriedade é somente de leitura. As opções
disponíveis estão descritas na tabela a seguir.
Opções disponíveis para ServerStatus
OPÇÃO DESCRIÇÃO
-1 - ServerStatus_Unknown O Driver de Comunicação OPC está conectado ao
servidor OPC mas o estado não é informado ou o cliente
OPC possui a propriedade ReconnectPeriod configurada
em zero (padrão)

0 - ServerStatus_NotConnected O Driver de Comunicação OPC não está conectado ao


servidor OPC. Isto acontece quando, por exemplo, o
Driver de Comunicação OPC não está ativo, ou a conexão
não foi estabelecida por algum problema qualquer

Os valores a seguir são informados apenas quando a propriedade ReconnectPeriod é diferente de 0 (zero). Esta
passagem de período especificando o estado é buscada no servidor. Caso o estado não seja informado
Objetos de Servidor 302
corretamente, a propriedade pode manter o valor igual a -1 (menos um), ou a desconexão pode ser detectada neste
caso, levando a propriedade ServerStatus para 0 (zero). Os valores são baseados nos cinco estados padrão
definidos para servidores OPC.
Opções disponíveis para ReconnectPeriod diferente de zero
OPÇÃO DESCRIÇÃO
1 - ServerStatus_Running O servidor está executando normalmente

2 - ServerStatus_Failed O servidor não está executando. Um erro não


especificado ocorreu no servidor

3 - ServerStatus_NoConfig O servidor está executando, porém sem informações de


configuração

4 - ServerStatus_Suspended O servidor foi suspenso temporariamente

5 - ServerStatus_Test O servidor está em modo de teste

Exemplo:
Sub CommandButton1_Click()
Dim status
status = Application.GetObject("DriverOPC1").ServerStatus
MsgBox "O status do driver é " & status
Select Case status
Case -1
MsgBox "O DriverOPC está conectado ao servidor OPC_
mas seu estado não foi informado."
Case 0
MsgBox "O DriverOPC não está conectado ao servidor OPC"
Case 1
MsgBox "O servidor está rodando normalmente"
Case 2
MsgBox "O servidor não está rodando"
Case 3
MsgBox "O servidor está rodando mas sem_
informações de configuração"
Case 4
MsgBox "O servidor foi suspenso temporariamente"
Case 5
MsgBox "O servidor está em Modo de Testes"
End Select
End Sub

NOTA
Para obter o comportamento equivalente a uma propriedade Booleana, o recomendado é usar ServerStatus
diferente de 0 (zero). Isto basicamente diferencia apenas entre haver a conexão ou não, desconsiderando estados
mais específicos do servidor. Além disto, a expressão independe do uso da propriedade ReconnectPeriod diferente
de 0 (zero).

5.5.2.2.9 WriteFeedbackMode
Esta propriedade permite controlar a confirmação ou feedback das escritas em Tags. As opções de configuração
desta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade WriteFeedbackMode
OPÇÃO DESCRIÇÃO
0 - wfWaitNextRead Após a escrita, aguarda normalmente a próxima leitura,
que é o padrão para aplicações criadas antes da
implementação desta propriedade

1 - wfImmediateReadAfterWrite Força uma leitura assíncrona de dispositivo logo após


cada escrita, que é o padrão para aplicações criadas a
partir da implementação desta propriedade

2 - wfTrustWriteSuccess O valor escrito é assumido pelo Tag imediatamente, caso


a escrita tenha funcionado

303 Objetos de Servidor


NOTAS
· A propriedade WriteFeedbackMode do Driver de Comunicação OPC não pode ser alterada com o objeto ativo.
· Na opção 2 - wfTrustWriteSuccess, no caso de escritas assíncronas, o valor é assumido no Tag após o
agendamento da escrita, se a operação é bem sucedida. Porém, se a escrita falhar posteriormente, o valor no Tag
pode estar errado. No caso da escrita síncrona, o valor é assumido logo após o término da escrita, se houver
sucesso.
· Veja também a propriedade WriteFeedbackMode do objeto Driver de Comunicação, cujo comportamento é
semelhante.

5.5.2.3 Grupo OPC


Esta seção contém informações sobre métodos e propriedades do objeto Grupo OPC (OPCGroup). Este objeto não
possui eventos associados.

5.5.2.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Grupo OPC (OPCGroup).

5.5.2.3.1.1 Refresh
Refresh(Source)
Força o servidor a reenviar os valores de todos os Tags do Grupo OPC que estejam com a leitura habilitada, tenham
eles mudado de valor ou não. O parâmetro Source determina o argumento da fonte de dados do Driver de
Comunicação OPC. Se o valor informado é igual a 1 (RefreshFromCache), os valores enviados são os valores do cache
do servidor. Do contrário, se o valor informado é igual a 2 (RefreshFromDevice), os valores enviados são atualizados
no cache do servidor antes de serem enviados. Para que este método funcione, a propriedade Enable do Grupo OPC,
bem como a leitura de pelo menos um Tag do Grupo OPC, deve estar habilitada. Para maiores informações sobre o
mecanismo de habilitação de leitura, o modo Advise, consulte as propriedades AllowRead e AdviseType do Tag.

5.5.2.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Grupo OPC (OPCGroup).

5.5.2.3.2.1 BlockMode
Esta propriedade determina o comportamento de ativação ou desativação do Grupo OPC. Quando esta
propriedade estiver configurada para Verdadeiro, a comunicação dos Tags do Grupo OPC é iniciada em conjunto. Isto
em geral ocasiona uma melhor performance, um menor tempo de ativação, por minimizar o número de chamadas ao
servidor OPC. Quando a propriedade estiver configurada para Falso, o comportamento é de ativar a comunicação de
cada Tag do Grupo OPC individualmente, de acordo com a sequência normal de ativação dos objetos. Com isto, por
exemplo, o primeiro Tag do Grupo OPC, na ordem vista no Organizer, comunica antes do último Tag. Apesar de mais
lento, pode ser uma vantagem usar este modo de ativação do Bloco de Comunicação OPC quando se deseja executar
alguma operação, como por exemplo uma escrita no Tag, em um script do evento OnStartRunning do Tag. A
desativação ocorre de maneira análoga. Quando o valor da propriedade é Verdadeiro, a desativação da comunicação
dos Tags do Grupo OPC ocorre em conjunto, ao término da desativação de todo o Grupo OPC. Caso a propriedade
esteja configurada para Falso, a desativação da comunicação ocorre individualmente para cada Tag, de acordo com a
sequência normal de desativação de objetos.

5.5.2.3.2.2 DeadBand
Esta propriedade permite ajustar o nível mínimo de variação de um Tag OPC, para que este seja atualizado. Essa
propriedade só se aplica aos Tags do Grupo OPC considerados do tipo analógico pelo servidor OPC ao qual o Driver
de Comunicação OPC está conectado. O intervalo válido para esta propriedade é entre 0 (zero) e 100%. Um valor 0
(zero) para esta propriedade significa que qualquer variação do valor de um Tag do Grupo OPC implica na
atualização do Grupo OPC. Este valor percentual é aplicado para cada Tag em relação aos limites de engenharia, que
estão definidos no servidor OPC. Para que um Tag seja atualizado, a seguinte expressão deve ser verdadeira, que é
avaliada no servidor OPC:
Abs(Valor_guardado_anteriormente – Valor_corrente) > (DeadBand / 100) * Abs(Limite_Superior –
Limite_Inferior)

O valor padrão desta propriedade é 0 (zero).

Objetos de Servidor 304


5.5.2.3.2.3 Enable
Esta propriedade habilita a atualização dos Tags dentro de um Grupo OPC. Se esta propriedade estiver configurada
para Falso, nenhum Tag dentro do Grupo OPC é atualizado. Caso contrário, os Tags que tenham a propriedade
AllowRead configurada para Verdadeiro e que estejam em modo Advise são mantidos atualizados de acordo com o
tempo de atualização, a propriedade Scan, e a banda morta, a propriedade DeadBand, do Grupo OPC. Para mais
informações, consulte a propriedade AdviseType. Estando esta propriedade configurada para Falso, não é possível
utilizar o método Refresh do Grupo OPC.

5.5.2.3.2.4 RealScan
Tempo de varredura efetivamente utilizado pelo servidor OPC. Esta propriedade é somente de leitura.

5.5.2.3.2.5 Scan
Especifica o tempo de varredura de atualização dos Tags do Grupo OPC que é utilizado pelo servidor. Esta
propriedade é representada em milissegundos e pode ser modificada após iniciada a comunicação, sendo utilizada
apenas quando a propriedade Enable estiver configurada para Verdadeiro.
Ao configurar esta propriedade nos diversos Tags presentes na aplicação, recomenda-se aumentar o valor desta
propriedade para aqueles Grupos OPC de Tags que não variam muito no equipamento ou dispositivo, possibilitando
assim que outros Grupos OPC de Tags de maior prioridade sejam lidos com maior frequência, aumentando assim a
performance e a resposta da aplicação. O valor padrão desta propriedade é 1000.

5.5.2.3.3 Bloco de Comunicação OPC


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Bloco de Comunicação OPC
(OPCTagBlock).

5.5.2.3.3.1 Eventos
Esta seção contém informações sobre os eventos do objeto Bloco de Comunicação OPC (OPCTagBlock).
OnRead
OnRead()
Ocorre quando um valor do Bloco de Comunicação OPC é recebido do Servidor OPC. Utilize o evento OnRead ao
efetuar alguma operação logo após algum dado ter sido modificado no objeto Bloco de Comunicação OPC, nas
propriedades Bit00 até Bit31, Quality, RawValue, TimeStamp e Value de algum Elemento do Bloco de Comunicação
OPC.

5.5.2.3.3.2 Métodos
Esta seção contém informações sobre os métodos do objeto Bloco de Comunicação OPC (OPCTagBlock).
Write
Write()
Executa a escrita do valor corrente do Bloco de Comunicação OPC no equipamento. Para mais detalhes, consulte a
documentação do Driver. Este método retorna um Booleano que indica o sucesso ou não da operação.
WriteEx
WriteEx([Value], [SyncWrite])
Executa a escrita de um valor no equipamento. Todos os seus parâmetros são opcionais. Se omitidos, o
comportamento do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou
não da operação. O parâmetro Value define o valor a ser escrito no Driver de Comunicação OPC. O tipo de dados
depende do Driver. Se omitido, assume o valor corrente do Bloco de Comunicação OPC. O parâmetro SyncWrite é um
Booleano que especifica se a operação descrita deve ser síncrona (Verdadeiro) ou assíncrona (Falso). Se omitido, usa
o valor especificado na propriedade SyncWrite do Bloco de Comunicação OPC.

305 Objetos de Servidor


NOTA
Assim como no método Write, a escrita é realizada independente de o valor ser diferente do valor atual do Bloco de
Comunicação OPC, bem como independente da propriedade AllowWrite do Bloco de Comunicação OPC estar
configurada para Verdadeiro ou Falso. Além disto, se a escrita funciona mas o Bloco de Comunicação OPC não está
em scan, seja porque a propriedade AllowRead está configurada para Falso ou porque usa a opção
AdviseWhenLinked quando não está sendo associado, o valor escrito é assumido imediatamente com qualidade
boa e estampa de tempo do momento da escrita.

5.5.2.3.3.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Bloco de Comunicação OPC (OPCTagBlock).
AdviseType
Controla o modo Advise. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag é mantido atualizado se a propriedade AllowRead
do Bloco de Comunicação OPC está configurada para
Verdadeiro e a propriedade Enable do Grupo OPC
também está configurada para Verdadeiro

1 - AdviseWhenLinked O Tag só é atualizado se a propriedade AllowRead do


Bloco de Comunicação OPC e a propriedade Enable do
Grupo OPC estejam configuradas para Verdadeiro, e o
Tag estiver associado a algum objeto ativo, como por
exemplo um Display de uma Tela aberta ou um Alarme
habilitado, entre outros. A associação do Tag para este
propósito pode ser realizada nas seguintes
propriedades: Value, RawValue, Quality e Bit00 até
Bit31 de Elementos de Bloco de Comunicação OPC, e
Quality e TimeStamp de Blocos de Comunicação OPC
(padrão)

Exemplo:
Sub CommandButton3_Click()
MsgBox Application._
GetObject("DriverOPC.GrupoOPC.SCRIPT1").AdviseType
End Sub
AllowRead
Configure esta propriedade para definir se este Bloco de Comunicação OPC deve ou não ser lido pelo Driver de
Comunicação OPC. Se esta propriedade estiver configurada para Verdadeiro, então o Driver automaticamente atualiza
as propriedades Value e Bits, de Bit00 até Bit31, dos Elementos do Bloco de Comunicação OPC em intervalos de
tempo. Caso contrário, este Bloco de Comunicação OPC não é lido se esta propriedade estiver configurada para
Falso. O valor padrão desta propriedade é Verdadeiro. Exemplo:
Sub Botao1_Click()
' Faz com que seja parada a leitura do Tag
Set obj = Application.GetObject("Driver1.tag")
obj.AllowRead = False
End Sub
AllowWrite
Configure esta propriedade para definir se este Tag deve ou não ser escrito automaticamente quando a
propriedade Value ou qualquer propriedade Bit, de Bit00 até Bit31, é modificada. Se a propriedade estiver em
Verdadeiro, as modificações são enviadas para o equipamento ou dispositivo associado ao Driver de Comunicação
OPC, senão as modificações são ignoradas. Estando esta propriedade configurada para Verdadeiro, então o Driver
automaticamente atualiza as propriedades Value e Bits, de Bit00 até Bit31, deste objeto, em intervalos de tempo.
Caso contrário, este Bloco de Comunicação OPC não é lido. O valor padrão desta propriedade é Verdadeiro.
Exemplo:
Sub Botao1_Click()
Set obj = Application.GetObject("Driver1.tag")
obj.AllowWrite = False
End Sub

Objetos de Servidor 306


DataType
Determina o tipo de dados associado ao Bloco de Comunicação OPC. Esta propriedade é somente de leitura. Os
valores possíveis para esta propriedade estão descritos na tabela a seguir.
Opções disponíveis para a propriedade DataType
OPÇÃO DESCRIÇÃO
0 - _Undefined Valor unidimensional não definido (vazio, padrão)

1 - _Null Valor nulo

2 - _Integer Valor unidimensional inteiro de 16 bits sinalizado

3 - _Long Valor unidimensional inteiro de 32 bits sinalizado

4 - _Single Valor unidimensional de ponto flutuante de 32 bits

5 - _Double Valor unidimensional de ponto flutuante de 64 bits

6 - _Currency Valor unidimensional monetário com quatro casas


decimais

7 - _Date Valor de data e hora

8 - _String Valor literal (texto)

9 - _Object Valor unidimensional de referência a um objeto

10 - _Error Valor unidimensional de código de erro

11 - _Boolean Valor unidimensional Booleano (Verdadeiro ou Falso)

12 - _Variant Dados de qualquer tipo usados para objetos e outros


valores para os quais o tipo de dados é desconhecido

13 - _UnkObject Valor unidimensional de referência a um objeto

14 - _Decimal Valor unidimensional de ponto flutuante de 96 bits

36 - _Record Valor unidimensional de gravação

16 - _Char Valor unidimensional inteiro de oito bits

17 - _Byte Utilizado para criação de DLLs e para OLE, ocupa um


byte de memória

18 - _Word Valor unidimensional inteiro de 16 bits

19 - _Dword Valor unidimensional inteiro de 32 bits

20 - _LongLong Valor unidimensional inteiro de 64 bits sinalizado

21 - _DDWord Valor unidimensional inteiro de 64 bits

22 - _Integer_ Números sem decimais, cujo intervalo de ocorrência


deve estar entre -32.768 e 32.767, ocupa dois bytes

23 - _Uinteger Número inteiro sem sinal (equivalente a um DWord), que


vai de 0 (zero) a 4294967295 (232 - 1)

8194 - _ArrInteger Array unidimensional de valores inteiros

8195 - _ArrLong Array unidimensional de valores inteiros de 32 bits


sinalizados

8196 - _ArrSingle Array unidimensional de valores de ponto flutuante de 32


bits

8197 - _ArrDouble Array unidimensional de valores de ponto flutuante de 64


bits

8198 - _ArrCurrency Array unidimensional de valores monetários com quatro


casas decimais

8199 - _ArrDate Array unidimensional de valores de data e hora

307 Objetos de Servidor


OPÇÃO DESCRIÇÃO
8200 - _ArrString Array unidimensional de valores literais (texto)

8201 - _ArrObject Array unidimensional de valores de referência a um


objeto

8202 - _ArrError Array unidimensional de valores de código de erro

8203 - _ArrBoolean Array unidimensional de valores Booleanos (Verdadeiro


ou Falso)

8204 - _ArrVariant Array de dados de qualquer tipo usados para objetos e


outros valores para os quais o tipo de dados é
desconhecido

8205 - _ArrUnkObject Array unidimensional de valores de referência a um


objeto

8206 - _ArrDecimal Array unidimensional de valores de ponto flutuante de 96


bits

8228 - _ArrRecord Array unidimensional de valores record

8208 - _ArrChar Array unidimensional de valores char

8209 - _ArrByte Array unidimensional de bytes, que são valores utilizados


para criação de DLLs e para OLE, ocupa um byte de
memória

8210 - _ArrWord Array unidimensional de valores inteiros de 32 bits

8211 - _ArrDWord Array unidimensional de valores inteiros de 32 bits

8212 - _ArrLongLong Array unidimensional de valores inteiros de 16 bits

8213 - _ArrDDWord Array unidimensional de valores inteiros de 32 bits


sinalizados

8214 - _ArrInteger_ Array unidimensional de valores inteiros de 16 bits


sinalizados

8215 - _ArrUInteger Array unidimensional de números inteiros sem sinal


(equivalente a um DWord), que vai de 0 (zero) a
4294967295 (232 -1)

EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação OPC que contém o Bloco de Comunicação OPC. Se a propriedade EnableDriverEvent do Bloco de
Comunicação OPC estiver configurada para Verdadeiro, a cada leitura vinda do servidor OPC, seja com erro ou não, é
gerado o evento OnTagRead no objeto Driver de Comunicação OPC que contém este Bloco de Comunicação OPC.
Caso contrário, o evento não ocorre. Também quando a propriedade EnableDriverEvent estiver configurada para
Verdadeiro, a cada escrita que seja enviada para o servidor OPC é gerado o evento OnTagWrite no objeto Driver de
Comunicação OPC que contém o Bloco de Comunicação OPC. Se a escrita é assíncrona, o evento OnTagWrite é
gerado apenas quando o servidor enviar a resposta indicando o efetivo sucesso ou não da escrita. Neste caso, o
evento é gerado apenas se a propriedade EnableDriverEvent estiver configurada para Verdadeiro neste momento, e
não no momento do envio da escrita. O valor padrão desta propriedade é Falso.
ItemID
Esta propriedade determina o caminho que identifica o Bloco de Comunicação OPC no servidor ao qual o Driver de
Comunicação OPC se conecta. A definição deste caminho é flexível e depende do servidor específico. Normalmente, os
servidores especificam um espaço de ID com itens hierárquicos, do tipo ItemPai.ItemFilho.Tag1. A propriedade
ItemID funciona como uma chave única para os dados, considerando o onde ou o quê permite ao servidor OPC se
conectar à fonte dos dados. Apesar de o valor padrão ser vazio, é necessário especificar algum valor para que o
Bloco de Comunicação OPC seja válido.
Quality
Esta propriedade informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação OPC atribui um novo valor para o Bloco de Comunicação OPC, ele também configura a qualidade
daquele dado. Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, qualidade ruim).

Objetos de Servidor 308


NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

Size
Define o tamanho do conjunto de valores do Bloco de Comunicação OPC. Consulte a documentação do Driver
utilizado para conhecer qual o limite para esta propriedade, de acordo com os parâmetros B1 até B4. Criando os
Elementos para o Bloco de Comunicação OPC, possibilita-se acessar os valores lidos e também permite a escrita de
valores para o equipamento ou dispositivo. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub BlocoOPC1_OnStartRunning()
Size = 12
End Sub
SyncWrite
Esta propriedade determina o tipo de escrita usada por um Bloco de Comunicação OPC. Se a propriedade estiver
configurada para Verdadeiro, a escrita é síncrona, isto é, o Driver de Comunicação OPC espera o resultado da escrita
do servidor. Caso contrário, a escrita é assíncrona, isto é, o valor do Tag de Comunicação OPC é enviado e o
processamento do Driver de Comunicação OPC continua imediatamente. O valor padrão desta propriedade é Falso.

NOTA
No modo assíncrono, com esta propriedade desabilitada, a performance da comunicação tende a ser melhor,
porém no modo síncrono, com esta propriedade habilitada, o sucesso da operação de escrita é verificado e
informado.

TimeStamp
Esta propriedade é atualizada sempre que ocorrer alguma mudança de valor ou de estado nas propriedades
Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à qualidade do Bloco
de Comunicação OPC. Esta é uma propriedade somente para leitura. O valor padrão desta propriedade é "00:00:00".

5.5.2.3.3.4 Elemento de Bloco de Comunicação OPC


Esta seção contém informações sobre eventos e propriedades do objeto Elemento de Bloco de Comunicação OPC
(OPCElementBlock). Este objeto não possui métodos associados.
Eventos
Esta seção contém informações sobre os eventos do objeto Elemento de Bloco de Comunicação OPC
(OPCElementBlock).
OnRead
OnRead()
Ocorre quando um valor do Elemento de Bloco de Comunicação OPC é recebido pelo servidor OPC. Utilize o evento
OnRead para efetuar alguma operação logo após algum dado ter sido modificado no objeto Elemento de Bloco de
Comunicação OPC, nas propriedades Bit00 até Bit31, Quality, RawValue ou Value.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Elemento de Bloco de Comunicação OPC
(OPCElementBlock).
Bit00 até Bit31
Estas propriedades representam juntas os 32 bits do valor presente na propriedade Value do objeto Elemento de
Bloco de Comunicação OPC, sendo Bit00 o bit menos significativo e Bit31 o bit mais significativo. Modificar cada um
destes bits implica na igual modificação da propriedade Value do Elemento de Bloco de Comunicação OPC e vice-
versa, mas isto somente ocorre quando a propriedade UseBitFields estiver configurada para Verdadeiro. O valor
padrão destas propriedades é Falso.
DeviceHigh
Esta propriedade define o valor máximo atingido por um Elemento de Bloco de Comunicação OPC no equipamento
ou no dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento
ou dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da

309 Objetos de Servidor


' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
DeviceLow
Esta propriedade define o valor mínimo atingido por um Elemento de Bloco de Comunicação OPC no equipamento
ou no dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento
ou dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da
' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EnableScaling
Esta propriedade habilita ou desabilita a escala de valor para o valor enviado e recebido do equipamento ou
dispositivo. Se esta propriedade estiver configurada para Verdadeiro, todo valor proveniente do equipamento ou
dispositivo sofre ajuste de escala conforme as propriedades DeviceHigh, DeviceLow, EUHigh e EULow antes de ser
atribuído à propriedade Value. Isto também ocorre quando uma escrita é necessária, quando o valor presente em
Value sofre ajuste de escala, sem com isto alterar a propriedade Value, e posteriormente é enviado para o
equipamento ou dispositivo. Caso a propriedade EnableScaling esteja configurada para Falso, nenhum ajuste de
escala é efetuado em nenhum dos dois sentidos, escrita e leitura. O valor padrão desta propriedade é Falso. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da
' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EU
Identifica a unidade de engenharia representada por este valor, como por exemplo graus, metros ou KW/h. O valor
padrão desta propriedade é vazio. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da
' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

Objetos de Servidor 310


EUHigh
Define qual o valor máximo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da
' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EULow = 100
EULow = 0
End Sub
EULow
Define qual o valor mínimo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Elemento_OnStartRunning()
' Faz o ajuste de escala da
' temperatura de um Elemento
' que varia de 0 a 255 no servidor OPC,
' mas que significa na prática
' de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
Index
Utilize esta propriedade para especificar a posição que um Elemento de Bloco de Comunicação OPC ocupa entre os
Elementos configurados pela propriedade Size do objeto Bloco de Comunicação OPC no qual ele está inserido. Esta
propriedade aceita valores de 0 (zero) até um número menor do que o valor definido em Size. Por exemplo,
configurando um Bloco de Comunicação OPC para ter a propriedade Size igual a 20, o número máximo válido para a
propriedade Index é 19 e o mínimo é 0 (zero). Esta propriedade pode ser alterada após iniciada a comunicação. O
valor padrão da propriedade é 0 (zero), porém ao mapear os Elementos de um Bloco de Comunicação OPC o E3
Studio automaticamente configura a propriedade Index para um valor de acordo com o especificado. Exemplo:
Sub Elemento1_OnRead()
MsgBox Index
End Sub
Quality
Esta propriedade representa o estado de qualidade do valor contido na propriedade Value. Esta propriedade é
somente de leitura.

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

RawValue
Acessa o valor original do Elemento de Bloco de Comunicação OPC anterior à escala, ou seja, independente da
configuração da propriedade EnableScaling. Então, se esta propriedade estiver configurada para Falso, as
propriedades Value e RawValue apresentam o mesmo comportamento.
UseBitFields
Caso esta propriedade esteja configurada para Verdadeiro, toda vez que o valor da propriedade Value é
modificado, ela atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de
Value toda vez que alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o

311 Objetos de Servidor


equipamento ou dispositivo se a propriedade AllowWrite do Bloco de Comunicação OPC estiver configurada para
Verdadeiro. Caso contrário, se esta propriedade estiver configurada para Falso, os bits não sofrem nem acarretam
qualquer mudança. Esta propriedade pode ser atualizada após ter sido iniciada a comunicação. O valor padrão desta
propriedade é Falso.
Value
Atualizada sempre que um novo valor é lido no servidor OPC, de acordo com a especificação da propriedade
ItemID do Bloco de Comunicação OPC onde este objeto está inserido, e considerando a propriedade Index, que
especifica a posição do Elemento no vetor do Bloco de Comunicação OPC. O tipo de dados desta propriedade, tais
como número inteiro, ponto flutuante ou texto, depende do Driver ao qual está associada e da configuração.
Esta propriedade somente é atualizada desta forma se a propriedade AllowRead do objeto Bloco de Comunicação
OPC ao qual o Elemento de Bloco de Comunicação OPC pertence estiver configurada para Verdadeiro, e de acordo
com o tempo de varredura definido na propriedade Scan do Grupo OPC que contêm o Bloco de Comunicação OPC.
Se a propriedade AllowWrite do objeto Bloco de Comunicação OPC estiver configurada para Verdadeiro, pode-se
escrever valores no equipamento ou no dispositivo simplesmente atribuindo um novo valor para a propriedade
Value.
Esta também é a propriedade padrão do objeto Elemento de Bloco OPC. Sendo assim, uma referência por valor a um
objeto Elemento de Bloco OPC não necessita obrigatoriamente explicitar a propriedade Value para acessar o valor.
Caso esta propriedade não esteja sendo atualizada, verifique se a propriedade Index está corretamente configurada,
ou seja, o valor deve ser entre zero e o tamanho do Bloco de Comunicação OPC menos um. Exemplo:
Sub Botao1_Click()
' Acessa um elemento e mostra o valor atual
' elm1 é um objeto do tipo Elemento de Bloco OPC
Set obj = Application.GetObject_
("OPCDriver1.Grupo1.BlocoOPC1.elm1")
MsgBox "Valor atual de elm1: " & obj.Value
' Isto também pode ser feito de outra forma,
' sem mostrar a propriedade Value, que é padrão
MsgBox "Valor atual de elm1: " & obj
End Sub

5.5.2.3.4 Tag de Comunicação OPC


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Tag de Comunicação OPC
(OPCTag).

5.5.2.3.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tag de Comunicação OPC (OPCTag).
OnRead
OnRead()
Ocorre quando um valor do Tag de Comunicação OPC é recebido do Servidor OPC. Utilize o evento OnRead quando
for necessário efetuar alguma operação logo após algum dado ter sido modificado no objeto Tag de Comunicação
OPC, nas propriedades Bit00 até Bit31, Quality, RawValue, TimeStamp ou Value.

5.5.2.3.4.2 Métodos
Esta seção contém informações sobre os métodos do objeto Tag de Comunicação OPC (OPCTag).
Write
Write()
Executa a escrita do valor corrente do Tag de Comunicação OPC no equipamento. Para mais detalhes, consulte a
documentação do Driver. Este método retorna um Booleano que indica o sucesso ou não da operação.
WriteEx
WriteEx([Value], [SyncWrite])
Executa a escrita de um valor no equipamento. Todos os seus parâmetros são opcionais. Se omitidos, o
comportamento do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou
não da operação. O parâmetro Value define o valor a ser escrito no Driver. O tipo de dados depende do Driver. Se
omitido, assume o valor corrente do Tag de Comunicação OPC. O parâmetro SyncWrite é um Booleano que especifica
se a operação descrita deve ser síncrona (Verdadeiro) ou assíncrona (Falso). Se omitido, usa o valor especificado na
propriedade SyncWrite do Tag de Comunicação OPC.

Objetos de Servidor 312


NOTA
Assim como no método Write, a escrita é realizada independente de o valor ser diferente do valor atual do Tag de
Comunicação OPC, bem como independente da propriedade AllowWrite do Tag estar configurada para Verdadeiro
ou Falso. Além disto, se a escrita funciona mas o Tag não está em scan, seja porque a propriedade AllowRead está
configurada para Falso ou porque usa a opção AdviseWhenLinked quando não está sendo associado, o valor
escrito é assumido imediatamente com qualidade boa e estampa de tempo do momento da escrita.

5.5.2.3.4.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag de Comunicação OPC (OPCTag).
AdviseType
Controla o modo Advise. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag de Comunicação OPC é mantido atualizado se a
propriedade AllowRead estiver configurada para
Verdadeiro e a propriedade Enable do Grupo OPC
também estiver configurada para Verdadeiro

1 - AdviseWhenLinked O Tag de Comunicação OPC só é atualizado se a


propriedade AllowRead e a propriedade Enable do
Grupo OPC estiverem configuradas para Verdadeiro, e o
Tag estiver associado a algum objeto ativo, como por
exemplo um Display de uma Tela aberta ou um Alarme
habilitado, entre outros. A associação do Tag para este
propósito pode ser realizada nas propriedades Value,
RawValue, TimeStamp, Quality e Bit00 até Bit31 de
Tags de Comunicação OPC (padrão)

Exemplo:
Sub CommandButton3_Click()
MsgBox Application._
GetObject("DriverOPC.GrupoOPC.TagOPC1").AdviseType
End Sub
AllowRead
Define se este Tag de Comunicação OPC deve ou não ser lido pelo Driver de Comunicação OPC. Caso a
propriedade esteja configurada para Verdadeiro, o Driver automaticamente atualiza as propriedades Value, Bits, de
Bit00 até Bit31, e RawValue deste objeto em intervalos de tempo. Caso contrário, este Tag de Comunicação OPC não
é lido. O valor padrão desta propriedade é Verdadeiro. Exemplo:
Sub Botao1_Click()
' Faz com que seja parada a leitura do tag
Set obj = Application.GetObject("Driver1.tag")
obj.AllowRead = False
End Sub
AllowWrite
Define se este Tag de Comunicação OPC deve ou não ser escrito automaticamente quando as propriedades Value,
qualquer uma das propriedades de Bits, de Bit00 até Bit31, ou RawValue são modificadas. Se a propriedade estiver
configurada para Verdadeiro, as modificações são enviadas para o equipamento ou dispositivo associado ao Driver
de Comunicação OPC. Do contrário, as modificações são ignoradas. O valor padrão desta propriedade é Verdadeiro.
Exemplo:
Sub Botao1_Click()
' Faz com que seja desabilitada a escrita do tag
Set obj = Application.GetObject("Driver1.tag")
obj.AllowWrite = False
End Sub
Bit00 até Bit31
Estas propriedades representam juntas os 32 bits do valor presente na propriedade Value do objeto Tag de
Comunicação OPC, sendo Bit00 o bit menos significativo e Bit31 o bit mais significativo. Modificar cada um destes bits

313 Objetos de Servidor


implica na igual modificação da propriedade Value do Tag e vice-versa, mas isto somente ocorre quando a
propriedade UseBitFields estiver configurada para Verdadeiro. O valor padrão destas propriedades é Falso.

NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

DataType
Determina o tipo de dados associado ao Tag de Comunicação OPC. Esta propriedade é somente de leitura. Veja a
tabela Opções disponíveis para a propriedade DataType na propriedade DataType do objeto Bloco de
Comunicação OPC para os valores possíveis desta propriedade.
DeviceHigh
Esta propriedade define o valor máximo atingido por um Tag de Comunicação OPC no equipamento ou no
dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento ou do
dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling estiver configurada para Verdadeiro, senão os valores permanecem os mesmos. O valor padrão desta
propriedade é 1000. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

DeviceLow
Esta propriedade define o valor mínimo atingido por um Tag de Comunicação OPC no equipamento ou no
dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento ou do
dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro, senão as configurações permanecem as mesmas. O valor padrão
desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação OPC que contém o Tag de Comunicação OPC. Se a propriedade EnableDriverEvent do Tag estiver
configurada para Verdadeiro, a cada leitura vinda do servidor OPC, seja com erro ou não, é gerado o evento
OnTagRead no objeto Driver de Comunicação OPC que contém este Tag. Caso contrário, o evento não ocorre.

Objetos de Servidor 314


Também quando a propriedade EnableDriverEvent estiver configurada para Verdadeiro, a cada escrita que seja
enviada para o servidor OPC é gerado o evento OnTagWrite no objeto Driver de Comunicação OPC que contém o
Tag. Se a escrita é assíncrona, o evento OnTagWrite é gerado apenas quando o servidor enviar a resposta indicando
o efetivo sucesso ou não da escrita. Neste caso, o evento é gerado apenas se a propriedade EnableDriverEvent
estiver configurada para Verdadeira neste momento, e não no momento do envio da escrita. O valor padrão desta
propriedade é Falso.
EnableScaling
Se esta propriedade estiver configurada para Verdadeiro, todo valor proveniente do equipamento ou do
dispositivo sofre ajuste de escala conforme as propriedades EUHigh e EULow antes de ser atribuído à propriedade
Value. Caso a propriedade EnableScaling esteja configurada para Falso, nenhum ajuste de escala é efetuado em
nenhum dos dois sentidos, tanto para escrita como para leitura. O valor padrão desta propriedade é Falso. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EU
Identifica a unidade de engenharia representada pelo valor, como por exemplo graus, metros ou KW/h. O valor
padrão desta propriedade é vazio. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub
EUHigh
Define qual o valor máximo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000. Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na
' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

EULow
Define qual o valor mínimo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita, é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Tag_OnStartRunning()
' Faz o ajuste de escala de um tag de temperatura
' que varia de 0 a 255 no PLC, mas significam na

315 Objetos de Servidor


' prática de 0 a 100 graus Celsius
EU = "Graus Celsius"
EnableScaling = True
DeviceHigh = 255
DeviceLow = 0
EUHigh = 100
EULow = 0
End Sub

NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

ItemID
Esta propriedade determina o caminho que identifica o Tag de Comunicação OPC no servidor OPC ao qual o Driver
de Comunicação OPC se conecta. A definição deste caminho é flexível e depende do servidor específico. Normalmente
os servidores especificam um espaço de ID com itens hierárquicos, do tipo ItemPai.ItemFilho.Tag1. Esta propriedade
funciona como uma chave única para os dados, considerando o onde ou o quê permite o servidor OPC se conectar à
fonte dos dados. Apesar de o valor padrão ser vazio, é necessário especificar algum valor para que o Tag de
Comunicação OPC seja válido.
Quality
Esta propriedade informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação OPC atribui um novo valor para o Tag de Comunicação OPC, ele também configura a qualidade daquele
dado. Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, qualidade ruim).

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

RawValue
Acessa o valor original do Tag de Comunicação OPC anterior à escala, ou seja, independente da configuração da
propriedade EnableScaling. Portanto, se esta propriedade estiver configurada para Falso, as propriedades Value e
RawValue apresentam o mesmo comportamento.
SyncWrite
Esta propriedade determina o tipo de escrita usada por um Tag de Comunicação OPC. Se a propriedade estiver
configurada para Verdadeiro, a escrita é síncrona, isto é, o Driver de Comunicação OPC espera o resultado da escrita
do servidor. Caso contrário, a escrita é assíncrona, isto é, o valor do Tag de Comunicação OPC é enviado e o
processamento do Driver de Comunicação OPC continua imediatamente. O valor padrão desta propriedade é Falso.

NOTA
No modo assíncrono, esta propriedade configurada para Falso, a performance da comunicação tende a ser melhor,
porém no modo síncrono, esta propriedade configurada para Verdadeiro, o sucesso da operação de escrita é
verificado e informado.

TimeStamp
Esta propriedade é atualizada sempre que ocorrer alguma mudança de valor ou de estado nas propriedades
Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à qualidade do Tag
de Comunicação OPC. Esta é uma propriedade somente para leitura. O valor padrão desta propriedade é "00:00:00".
UseBitFields
Caso esta propriedade esteja configurada para Verdadeiro, toda vez que o valor da propriedade Value é
modificado ele atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de Value
toda vez que alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o equipamento
ou dispositivo se a propriedade AllowWrite estiver configurada para Verdadeiro. Caso contrário, se esta propriedade
estiver configurada para Falso, os bits não sofrem qualquer mudança. Esta propriedade pode sofrer atualização após
ter sido iniciada a comunicação. O valor padrão desta propriedade é Falso. Exemplo:
Sub TagOPC1_Click()
UseBitFields = True
End Sub

Objetos de Servidor 316


NOTA
Os valores dos bits, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é, representam os
bits do valor lido do equipamento antes da conversão.

Value
Esta propriedade é atualizada quando é executada uma nova leitura válida de um valor do equipamento ou do
dispositivo utilizando sua configuração, porém o tipo de dados desta variável, tais como número inteiro, ponto
flutuante ou texto, depende do Driver de Comunicação OPC ao qual está associado e da configuração. Esta
propriedade somente é atualizada desta forma se a propriedade AllowRead estiver configurada para Verdadeiro e
quando não houver erros de comunicação, e neste caso somente as propriedades Quality e TimeStamp são
atualizadas, mas de acordo com o tempo de varredura definido no Grupo OPC ao qual o Tag de Comunicação OPC
pertence. Outra forma de utilizar esta propriedade é escrever valores no equipamento ou dispositivo. Basta que se
atribua um novo valor para a propriedade Value ou algum dos bits Bit00 até Bit31, desde que a propriedade
AllowWrite esteja configurado para Verdadeiro. Esta propriedade também é a propriedade padrão do objeto Tag
de Comunicação OPC. Sendo assim, uma referência por valor a um objeto Tag de Comunicação OPC não necessita
obrigatoriamente explicitar a propriedade Value para acessar o valor. O valor padrão desta propriedade é vazio.
Exemplo:
Sub Botao1_Click()
' Acessa um tag e mostra o valor atual
' tag1 é um objeto tipo OPCTag
Set obj = Application._
GetObject("Driverde_ Comunicacao1.tag1")
MsgBox "Valor atual de tag1: " & obj.Value
' Sem mostrar a propriedade Value, que é padrão
MsgBox "Valor atual de tag1: " & obj
End Sub

5.5.3 Driver de Comunicação OPC UA


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Driver de Comunicação OPC UA
(UaDriver).

5.5.3.1 Eventos
Esta seção contém informações sobre os eventos do objeto Driver de Comunicação OPC UA (UaDriver).

5.5.3.1.1 OnTagRead
OnTagRead(Tag)
Ocorre na leitura de um Tag, sempre que um novo valor ou erro é retornado pelo servidor OPC UA, ou seja, se o
valor ou a qualidade do Tag não mudarem, o evento não é disparado. Para que este evento ocorra, a propriedade
EnableDriverEvent do Tag deve obrigatoriamente estar habilitada.

5.5.3.1.2 OnTagWrite
OnTagWrite(Tag, Succeeded, User)
Ocorre quando uma escrita é disparada em qualquer Tag do Driver de Comunicação OPC UA. Para que o evento
ocorra, a propriedade EnableDriverEvent do Tag deve obrigatoriamente estar habilitada. Se a escrita é assíncrona, o
evento OnTagWrite é gerado apenas quando o servidor enviar a resposta indicando o efetivo sucesso ou não da
escrita.
Parâmetros do evento OnTagWrite
NOME DESCRIÇÃO
Tag Uma referência para o objeto Tag que sofre a escrita.
Por exemplo, pode-se acessar a propriedade do Tag
usando a sintaxe Tag.DocString

Succeeded Um valor Booleano que indica sucesso ou falha na escrita

317 Objetos de Servidor


NOME DESCRIÇÃO
User Parâmetro que recebe o usuário que executou a escrita.
O valor padrão deste parâmetro é "System". Se não
houver nenhum usuário logado no E3 Viewer que gerou
o evento, este parâmetro contém o valor "Anonymous".
Se a escrita é assíncrona ou se ocorreu uma falha
reportada de forma assíncrona, este parâmetro sempre
contém o valor "System"

5.5.3.2 Métodos
Esta seção contém informações sobre os métodos do objeto Driver de Comunicação OPC UA (UaDriver).

5.5.3.2.1 RefreshUaNodeIds
RefreshUaNodeIds()
Atualiza todos os Blocos e Tags de Comunicação OPC UA do Driver, buscando os Identificadores de Nós OPC UA
(NodeIds) no servidor e atualizando as propriedades UaNodeId dos Blocos de Comunicação OPC UA e dos Tags de
Comunicação OPC UA. Este método retorna um Booleano indicando o sucesso ou não da operação.

5.5.3.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Driver de Comunicação OPC UA (UaDriver).

5.5.3.3.1 EndPointURL
Propriedade de leitura e escrita que especifica o caminho, ou ponto de conexão, do servidor OPC UA ao qual o
cliente se conecta. Esta propriedade não pode ser alterada com a comunicação ativa.

5.5.3.3.2 MaxNodesPerClientCall
Esta propriedade gerencia o tamanho máximo do array de nós passados por padrão nas requisições síncronas a
um servidor OPC UA. O valor padrão desta propriedade é 0 (zero), que desabilita este gerenciamento. O uso desta
propriedade permite que uma requisição seja dividida em requisições menores, evitando erros do tipo
BadTooManyOperations.

5.5.3.3.3 OverrideEndpointURLHost
Esta propriedade força a utilização do ponto de conexão ou endpoint usado para conectar ao servidor OPC UA,
configurado na propriedade EndPointURL, nos casos em que um servidor OPC UA retorne uma lista de pontos de
conexão que podem ou não estar acessíveis ao cliente. O valor padrão desta propriedade é Falso.

5.5.3.3.4 Password
Propriedade de leitura e escrita que especifica a senha do usuário que é usado na conexão com o servidor OPC UA.
Esta propriedade é usada em conjunto com a propriedade UserName, e o valor padrão é uma String vazia.

NOTA
Esta propriedade pode ser alterada com a comunicação ativa, mas esta alteração só tem efeito quando o Cliente
OPC UA é reiniciado.

5.5.3.3.5 SecurityMode
Propriedade de leitura e escrita que especifica o modo de segurança que é usado na conexão com o servidor OPC
UA. Esta propriedade não pode ser alterada com a comunicação ativa. Os valores possíveis para esta propriedade
são os seguintes:
· 1 - usmNone: Não utiliza nenhum modo de segurança na conexão (padrão)
· 2 - usmSign: Utiliza autenticação na conexão
· 3 - usmSignAndEncrypt: Utiliza autenticação e criptografia na conexão

Esta propriedade é usada em conjunto com a propriedade SecurityPolicy para determinar o tipo de segurança da
conexão.

Objetos de Servidor 318


NOTA
Se a propriedade SecurityMode é diferente de usmNone, é necessário que o servidor OPC UA aceite o certificado
da instância do cliente E3. A forma como um certificado é aceito ou reconhecido por um servidor OPC UA depende
do servidor.

5.5.3.3.6 SecurityPolicy
Propriedade de leitura e escrita que especifica a política de segurança ou criptografia usada na conexão com o
servidor OPC UA. Esta propriedade não pode ser alterada com a comunicação ativa. Os valores possíveis para esta
propriedade são os seguintes:
· 1 - uspNone: Não utiliza criptografia na conexão (padrão)
· 2 - uspBasic128Rsa15: Utiliza o algoritmo RSA com chave de 128 bits na conexão
· 3 - uspBasic256: Utiliza o algoritmo AES com chave de 256 bits na conexão
· 4 - uspBasic256Sha256: Utiliza o algoritmo SHA com chave de 256 bits na conexão

Esta propriedade é usada em conjunto com a propriedade SecurityMode para determinar o tipo de segurança da
conexão.

5.5.3.3.7 ServerState
Retorna o estado da conexão ou do servidor OPC UA. Esta propriedade é somente de leitura. Os valores possíveis
para esta propriedade são os seguintes:
· -1 - ussNotConnected: O servidor não está conectado (padrão)
· 0 - ussRunning: O servidor está executando normalmente
· 1 - ussFailed: O servidor não está executando
· 2 - ussNoConfig: O servidor está executando, mas sem informações de configuração
· 3 - ussSuspended: O servidor foi suspenso temporariamente
· 4 - ussShutdown: O servidor foi desligado
· 5 - ussTest: O servidor está em modo de teste
· 6 - ussCommunicationFault: Houve uma falha na comunicação com o servidor
· 7 - ussUnknown: O estado do servidor é desconhecido

5.5.3.3.8 TimeoutCall
Propriedade de leitura e escrita que especifica o tempo limite de uma chamada ao servidor OPC UA, em
milissegundos. Esta propriedade não pode ser alterada com a comunicação ativa, seu valor deve ser maior que 0
(zero) e seu valor padrão é 10000 (10 segundos).

NOTA
No padrão OPC UA, várias chamadas permitem continuar a comunicação, com múltiplas respostas do servidor. Desta
forma, este tempo acaba por ser o tempo limite de resposta do servidor OPC UA.

5.5.3.3.9 TimeoutConnection
Propriedade de leitura e escrita que especifica o tempo limite da conexão, em milissegundos. O valor padrão desta
propriedade é 10000 (10 segundos) e seu valor deve ser maior que 0 (zero). Esta propriedade não pode ser alterada
com a comunicação ativa.

5.5.3.3.10 TimeoutSession
Propriedade de leitura e escrita que especifica o tempo limite para a renovação da sessão de comunicação do
cliente E3 com o servidor OPC UA, em milissegundos. O valor padrão desta propriedade é 600000 (10 minutos) e este
valor deve ser maior que 0 (zero). Esta propriedade não pode ser alterada com a comunicação ativa.

319 Objetos de Servidor


5.5.3.3.11 UserName
Propriedade de leitura e escrita que especifica o nome do usuário usado na conexão com o servidor OPC UA. Esta
propriedade é usada em conjunto com a propriedade Password. O valor padrão desta propriedade é uma String
vazia.

NOTA
Esta propriedade pode ser alterada com a comunicação ativa, mas esta alteração só tem efeito quando o Cliente
OPC UA é reiniciado.

5.5.3.3.12 WriteFeedbackMode
Esta propriedade permite controlar a confirmação ou feedback das escritas em Tags. As opções de configuração
desta propriedade estão descritas na tabela a seguir.
Opções disponíveis para a propriedade WriteFeedbackMode
OPÇÃO DESCRIÇÃO
0 - wfWaitNextRead Após a escrita, aguarda normalmente a próxima leitura

1 - wfImmediateReadAfterWrite Força uma leitura assíncrona de dispositivo logo após


cada escrita (padrão)

2 - wfTrustWriteSuccess O valor escrito é assumido pelo Tag imediatamente, caso


a escrita tenha funcionado

NOTAS
· A propriedade WriteFeedbackMode do Driver de Comunicação OPC UA não pode ser alterada com o objeto
ativo.
· Na opção 2 - wfTrustWriteSuccess, no caso de escritas assíncronas, o valor é assumido no Tag após o
agendamento da escrita, se a operação é bem sucedida. Porém, se a escrita falhar posteriormente, o valor no Tag
pode estar errado. No caso da escrita síncrona, o valor é assumido logo após o término da escrita, se houver
sucesso.

5.5.3.3.13 WriteValueMode
Propriedade de leitura e escrita que controla o comportamento do envio do valor nas operações de escrita. Esta
propriedade deve ser configurada de acordo com o servidor OPC UA utilizado, pois do contrário a escrita falha. Os
valores possíveis para esta propriedade são os seguintes:
· 0 - wvmDefault: Segue o comportamento padrão do Driver de Comunicação OPC UA de escrever apenas o valor
· 1 - wvmValueOnly: Escreve apenas o valor (padrão)
· 2 - wvmValueQualityTimestamp: Envia sempre a qualidade e a estampa de tempo junto com o valor

Esta propriedade não pode ser alterada com a comunicação ativa.

NOTA
Utilizar o valor 2 - wvmValueQualityTimestamp afeta a forma como os valores são enviados para o servidor OPC
UA, independente da forma como a escrita é disparada pelo E3.

5.5.3.4 Assinatura OPC UA


Esta seção contém informações sobre as propriedades do objeto Assinatura OPC UA (UaSubscription). Este objeto
não possui eventos nem métodos associados.

5.5.3.4.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Assinatura OPC UA (UaSubscription).

Objetos de Servidor 320


5.5.3.4.1.1 Enable
Esta propriedade habilita a atualização dos Tags dentro de uma Assinatura OPC UA. Se esta propriedade estiver
configurada para Falso, nenhum Tag dentro da Assinatura OPC UA é atualizado. Caso contrário, os Tags que tenham a
propriedade AllowRead configurada para Verdadeiro e que estejam em modo Advise são mantidos atualizados de
acordo com o tempo de atualização, definido na propriedade Scan. Para mais informações, consulte a propriedade
AdviseType. Se esta propriedade estiver configurada para Falso, não é possível utilizar o método RefreshUaNodeIds
do Driver de Comunicação OPC UA.

5.5.3.4.1.2 RealScan
Tempo de varredura efetivamente utilizado pelo servidor OPC UA. Esta propriedade é somente de leitura.

5.5.3.4.1.3 Scan
Especifica o tempo de varredura de atualização dos Tags da Assinatura OPC UA que é utilizado pelo servidor. Esta
propriedade é representada em milissegundos e pode ser modificada após iniciada a comunicação, sendo utilizada
apenas quando a propriedade Enable estiver configurada para Verdadeiro.
Ao configurar esta propriedade nos diversos Tags presentes na aplicação, recomenda-se aumentar o valor desta
propriedade para aquelas Assinaturas OPC UA de Tags que não variam muito no equipamento ou dispositivo,
possibilitando assim que outras Assinaturas OPC UA de Tags de maior prioridade sejam lidas com maior frequência,
aumentando assim a performance e a resposta da aplicação. O valor padrão desta propriedade é 1000.

5.5.3.4.2 Bloco de Comunicação OPC UA


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Bloco de Comunicação OPC UA
(UaTagBlock).

5.5.3.4.2.1 Eventos
Esta seção contém informações sobre os eventos do objeto Bloco de Comunicação OPC UA (UaTagBlock).
OnRead
OnRead()
Ocorre quando um valor do Bloco de Comunicação OPC UA é recebido do servidor OPC UA. Utilize o evento OnRead
para efetuar alguma operação logo após algum dado ter sido modificado no objeto Bloco de Comunicação OPC UA,
nas propriedades Bit00 até Bit31, Quality, RawValue, TimeStamp e Value de algum Elemento do Bloco de
Comunicação OPC UA.

5.5.3.4.2.2 Métodos
Esta seção contém informações sobre os métodos do objeto Bloco de Comunicação OPC UA (UaTagBlock).
Write
Write()
Executa a escrita do valor corrente do Bloco de Comunicação OPC UA no equipamento. Para mais detalhes, consulte a
documentação do Driver. Este método retorna um Booleano que indica o sucesso ou não da operação.
WriteEx
WriteEx([Value], [NewTimestamp], [NewQuality], [SyncWrite])
Executa a escrita de um valor no equipamento. Todos os parâmetros são opcionais. Se omitidos, o comportamento
do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou não da
operação. O parâmetro Value define o valor a ser escrito no Driver de Comunicação OPC UA. O tipo de dados
depende do Driver. Se omitido, assume o valor corrente do Bloco de Comunicação OPC UA. Se especificado, deve ser
um array com o mesmo número de Elementos do Bloco de Comunicação OPC UA. Os parâmetros NewTimestamp e
NewQuality indicam, respectivamente, a estampa de tempo e a qualidade do valor, caso a propriedade
WriteValueMode esteja configurada para 2 - wvmValueQualityTimestamp. O parâmetro SyncWrite é um Booleano
que especifica se a operação descrita deve ser síncrona (Verdadeiro) ou assíncrona (Falso). Se omitido, usa o valor
especificado na propriedade SyncWrite do Bloco de Comunicação OPC UA.

321 Objetos de Servidor


NOTA
Assim como no método Write, a escrita é realizada independente de o valor ser diferente do valor atual do Bloco de
Comunicação OPC UA, bem como independente da propriedade AllowWrite do Bloco de Comunicação OPC UA
estar configurada como Verdadeiro ou Falso. Além disto, se a escrita funciona mas o Bloco de Comunicação OPC UA
não está em scan, seja porque a propriedade AllowRead está configurada como Falso ou porque usa a opção
AdviseWhenLinked quando não está sendo associado, o valor escrito é assumido imediatamente com qualidade
boa e estampa de tempo do momento da escrita.

5.5.3.4.2.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Bloco de Comunicação OPC UA (UaTagBlock).
AdviseType
Controla o modo Advise. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag é mantido atualizado se a propriedade AllowRead
do Bloco de Comunicação OPC UA está configurada
como Verdadeiro e a propriedade Enable da Assinatura
OPC UA também está configurada como Verdadeiro

1 - AdviseWhenLinked O Tag só é atualizado se a propriedade AllowRead do


Bloco de Comunicação OPC UA e a propriedade Enable
da Assinatura OPC UA estiverem configuradas como
Verdadeiro, e o Tag estiver associado a algum objeto
ativo, como por exemplo um Display de uma Tela aberta
ou um Alarme habilitado, entre outros. A associação do
Tag para este propósito pode ser realizada nas
propriedades Value, RawValue, Quality e Bit00 até
Bit31 de Elementos de Bloco de Comunicação OPC UA, e
Quality e TimeStamp de Blocos de Comunicação OPC
UA (padrão)

AllowRead
Configure esta propriedade para definir se este Bloco de Comunicação OPC UA deve ou não ser lido pelo Driver de
Comunicação OPC UA. Se esta propriedade estiver configurada para Verdadeiro, então o Driver automaticamente
atualiza as propriedades Value e Bits, de Bit00 até Bit31, dos Elementos do Bloco de Comunicação OPC UA em
intervalos de tempo. Caso contrário, este Bloco de Comunicação OPC UA não é lido se esta propriedade estiver
configurada para Falso. O valor padrão desta propriedade é Verdadeiro.
AllowWrite
Configure esta propriedade para definir se este Tag deve ou não ser escrito automaticamente quando a
propriedade Value ou qualquer propriedade Bit, de Bit00 até Bit31, é modificada. Se a propriedade estiver
configurada para Verdadeiro, as modificações são enviadas para o equipamento ou dispositivo associado ao Driver
de Comunicação OPC UA, senão as modificações são ignoradas. Estando esta propriedade configurada para
Verdadeiro, então o Driver automaticamente atualiza as propriedades Value e Bits, de Bit00 até Bit31, deste objeto,
em intervalos de tempo. Caso contrário, este Bloco de Comunicação OPC UA não é lido. O valor padrão desta
propriedade é Verdadeiro.
DataType
Propriedade preenchida quando o E3 se conecta ao servidor OPC UA, que indica o tipo de dados no servidor OPC
UA. Esta propriedade é inicialmente preenchida no processo de busca (browsing), se realizado, e em cada
comunicação ou conexão com o servidor OPC UA. Valores abaixo de 1000 são escalares e valores acima de 1000 são
vetores (arrays). Esta propriedade é somente de leitura. Os valores possíveis para esta propriedade são os seguintes:
· 17: udtNodeId (Identificador de Nó OPC UA, formatado como um vetor de três elementos no E3)
· 18: udtExpandedNodeId (Identificador de Nó OPC UA expandido, formatado como um vetor de três elementos no
E3)
· 22: udtStructure (Indica que é um tipo de dados complexo do OPC UA, mas não específico, formatado como um
vetor onde cada elemento é um membro da estrutura)
· 25: udtDiagnosticInfo

Objetos de Servidor 322


· 1000: udtArrayUnknown (Vetor genérico, de tipos de dados não conhecidos)
· 1001: udtArrayBoolean
· 1002: udtArraySByte
· 1003: udtArrayByte
· 1004: udtArrayInt16
· 1005: udtArrayUInt16
· 1006: udtArrayInt32
· 1007: udtArrayUInt32
· 1008: udtArrayInt64
· 1009: udtArrayUInt64
· 1010: udtArrayFloat
· 1011: udtArrayDouble
· 1012: udtArrayString
· 1013: udtArrayDateTime
· 1014: udtArrayGuid
· 1015: udtArrayByteString
· 1016: udtArrayXmlElement
· 1017: udtArrayNodeId
· 1018: udtArrayExpandedNodeId
· 1019: udtArrayStatusCode
· 1020: udtArrayQualifiedName
· 1021: udtArrayLocalizedText
· 1022: udtArrayStructure
· 1023: udtArrayDataValue
· 1024: udtArrayVariant

NOTAS
· Estruturas definidas por servidores específicos, não compatíveis com o padrão OPC UA, não são lidas pelo E3.
· Os tipos de dados udtArrayQualifiedName, udtArrayLocalizedText, udtStructure, udtArrayStructure,
udtArrayDataValue e udtArrayUnknown não permitem a escrita na versão atual do E3, pois o E3 utiliza uma
formatação simplificada destes tipos de dados.
· Os tipos de dados ServiceCounterDataType (array de duas posições), BuildIndfo (array de seis posições),
Argument (array de seis posições), ApplicationDescription (array de oito posições),
SessionDiagnosticsDataType (array de 44 posições), SessionSecurityDiagnosticsDataType (array de 10
posições), SubscriptionsDiagnosticsDataType (array de 31 posições), ServerDiagnosticsSummaryDataType
(array de 12 posições), ServerStatusDataType (array de seis posições), EuInformation (array de quatro posições),
Range (array de duas posições), TimeZoneDataType (array de duas posições), DiagnosticInfo (array de sete
posições), StatusResult (array de duas posições), ComplexNumberType (array de duas posições),
DoubleComplexNumberType (array de duas posições), XVType (array de duas posições),
RedundanteServerSataType (array de três posições), SamplingIntervalDiagnosticsDataType (array de quatro
posições), EnumValueType (array de três posições), EndpointUrlListDataType (array de duas posições) e
NetworkGroupDataType (array de três posições) são mostrados como udtStructure, mas o E3 trata o tipo de
dados específico.
· Na versão atual, o E3 só permite vetores de uma dimensão, ou seja, não permite matrizes como tipos de dados.

EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação OPC UA que contém o Bloco de Comunicação OPC UA. Se a propriedade EnableDriverEvent do Bloco
de Comunicação OPC UA estiver configurada para Verdadeiro, a cada leitura vinda do servidor OPC UA, seja com erro
ou não, é gerado o evento OnTagRead no objeto Driver de Comunicação OPC UA que contém este Bloco de
Comunicação OPC UA. Caso contrário, o evento não ocorre. Também quando a propriedade EnableDriverEvent
estiver configurada para Verdadeiro, a cada escrita que seja enviada para o servidor OPC UA é gerado o evento
OnTagWrite no objeto Driver de Comunicação OPC UA que contém o Bloco de Comunicação OPC UA. Se a escrita é
assíncrona, o evento OnTagWrite é gerado apenas quando o servidor enviar a resposta indicando o efetivo sucesso

323 Objetos de Servidor


ou não da escrita. Neste caso, o evento é gerado apenas se a propriedade EnableDriverEvent estiver configurada
como Verdadeiro neste momento, e não no momento do envio da escrita. O valor padrão desta propriedade é Falso.
ItemID
Especifica o caminho para realizar a busca, ou browsing, de um Bloco de Comunicação OPC UA em um servidor OPC
UA. Este caminho é usado no método RefreshUaNodeIds do Driver de Comunicação OPC UA para recuperar o
Identificador de Nó OPC UA de um Bloco de Comunicação OPC UA, quando desejado.
Quality
Esta propriedade informa qual a qualidade do valor contido na propriedade Value. Cada vez que o Driver de
Comunicação OPC UA atribui um novo valor para o Bloco de Comunicação OPC UA, ele também configura a qualidade
daquele dado. Esta propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, qualidade ruim).

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

Size
Define o tamanho do conjunto de valores do Bloco de Comunicação OPC UA. Consulte a documentação do driver
utilizado para conhecer qual o limite para esta propriedade, de acordo com os parâmetros B1 até B4. Criando os
Elementos para o Bloco de Comunicação OPC UA, possibilita-se acessar os valores lidos e também permite a escrita
de valores para o equipamento ou dispositivo. O valor padrão desta propriedade é 0 (zero).
SyncWrite
Esta propriedade determina o tipo de escrita usada por um Bloco de Comunicação OPC UA. Se a propriedade
estiver configurada para Verdadeiro, a escrita é síncrona, isto é, o Driver de Comunicação OPC UA espera o resultado
da escrita do servidor. Caso contrário, a escrita é assíncrona, isto é, o valor do Bloco de Comunicação OPC UA é
enviado e o processamento do Driver de Comunicação OPC UA continua imediatamente. O valor padrão desta
propriedade é Falso.

NOTA
No modo assíncrono, com esta propriedade desabilitada, a performance da comunicação tende a ser melhor,
porém no modo síncrono, esta propriedade habilitada, o sucesso da operação de escrita é verificado e informado.

TimeStamp
Esta propriedade é atualizada sempre que ocorrer alguma mudança de valor ou de estado nas propriedades
Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à qualidade do Bloco
de Comunicação OPC UA. Esta é uma propriedade somente de leitura. O valor padrão desta propriedade é "00:00:00".
UaNodeId
Especifica o caminho para realizar a busca, ou browsing, de um Bloco de Comunicação OPC UA em um servidor
OPC UA. Este caminho é usado no método RefreshUaNodeIds do Driver de Comunicação OPC UA para recuperar o
Identificador de Nó OPC UA de um Bloco de Comunicação OPC UA, quando desejado. Esta propriedade deve estar
preenchida para estabelecer a comunicação com um servidor OPC UA.
WriteValueMode
Propriedade de leitura e escrita que controla o comportamento do envio do valor nas operações de escrita. Esta
propriedade deve ser configurada de acordo com o servidor OPC UA utilizado, pois do contrário a escrita falha. Os
valores possíveis para esta propriedade são os seguintes:
· 0 - wvmDefault: Segue o comportamento padrão, isto é, o comportamento configurado no Driver de
Comunicação OPC UA a que este Bloco de Comunicação OPC UA pertence
· 1 - wvmValueOnly: Escreve apenas o valor
· 2 - wvmValueQualityTimestamp: Envia sempre a qualidade e a estampa de tempo junto com o valor

5.5.3.4.2.4 Elemento de Bloco de Comunicação OPC UA


Esta seção contém informações sobre eventos e propriedades do objeto Elemento de Bloco de Comunicação OPC UA
(UaElementBlock). Este objeto não possui métodos associados.
Eventos
Esta seção contém informações sobre os eventos do objeto Elemento de Bloco de Comunicação OPC UA
(UaElementBlock).

Objetos de Servidor 324


OnRead
OnRead()
Ocorre quando um valor do Elemento de Bloco de Comunicação OPC UA é recebido pelo servidor OPC UA. Utilize o
evento OnRead para efetuar alguma operação logo após algum dado ter sido modificado no objeto Elemento de
Bloco de Comunicação OPC UA, nas propriedades Bit00 até Bit31, Quality, RawValue ou Value.
Propriedades
Esta seção contém informações sobre as propriedades do objeto Elemento de Bloco de Comunicação OPC UA
(UaElementBlock).
Bit00 até Bit31
Estas propriedades representam juntas os 32 bits do valor presente na propriedade Value do objeto Elemento de
Bloco de Comunicação OPC UA, sendo Bit00 o bit menos significativo e Bit31 o bit mais significativo. Modificar cada
um destes bits implica na igual modificação da propriedade Value do Elemento de Bloco de Comunicação OPC UA e
vice-versa, mas isto somente ocorre quando a propriedade UseBitFields estiver configurada para Verdadeiro. O valor
padrão destas propriedades é Falso.
DeviceHigh
Esta propriedade define o valor máximo atingido por um Elemento de Bloco de Comunicação OPC UA no
equipamento ou no dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do
equipamento ou dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é
executada a operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000.
DeviceLow
Esta propriedade define o valor mínimo atingido por um Elemento de Bloco de Comunicação OPC UA no
equipamento ou no dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do
equipamento ou dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é
executada a operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero).
EnableScaling
Esta propriedade habilita ou desabilita a escala de valor para o valor enviado e recebido do equipamento ou
dispositivo. Se esta propriedade estiver configurada para Verdadeiro, todo valor proveniente do equipamento ou
dispositivo sofre ajuste de escala conforme as propriedades DeviceHigh, DeviceLow, EUHigh e EULow antes de ser
atribuído à propriedade Value. O mesmo ocorre quando uma escrita é necessária, quando o valor presente em Value
sofre ajuste de escala, sem com isto alterar a propriedade Value, e posteriormente é enviado para o equipamento ou
dispositivo. Caso a propriedade EnableScaling esteja configurada para Falso, nenhum ajuste de escala é efetuado em
nenhum dos dois sentidos, escrita e leitura. O valor padrão desta propriedade é Falso.
EU
Identifica a unidade de engenharia representada por este valor, como por exemplo graus, metros ou KW/h. O valor
padrão desta propriedade é vazio.
EUHigh
Define qual o valor máximo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000.
EULow
Define qual o valor mínimo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero).
Index
Utilize esta propriedade para especificar a posição que um Elemento de Bloco de Comunicação OPC UA ocupa entre
os Elementos configurados pela propriedade Size do objeto Bloco de Comunicação OPC UA no qual ele está inserido.
Esta propriedade aceita valores de 0 (zero) até um número menor do que o valor definido em Size. Por exemplo,
configurando um Bloco de Comunicação OPC UA para ter a propriedade Size igual a 20, o número máximo válido
para a propriedade Index é 19 e o mínimo é 0 (zero). Esta propriedade pode ser alterada após iniciada a
comunicação. O valor padrão da propriedade é 0 (zero), porém ao mapear os Elementos de um Bloco de

325 Objetos de Servidor


Comunicação OPC UA o E3 Studio automaticamente configura a propriedade Index para um valor de acordo com o
especificado.
Quality
Esta propriedade representa o estado de qualidade do valor contido na propriedade Value. Esta propriedade é
somente de leitura.

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

RawValue
Acessa o valor original do Elemento de Bloco de Comunicação OPC UA anterior à escala, ou seja, independente da
configuração da propriedade EnableScaling. Então, se esta propriedade estiver configurada para Falso, as
propriedades Value e RawValue apresentam o mesmo comportamento.
UseBitFields
Caso esta propriedade esteja configurada para Verdadeiro, toda vez que o valor da propriedade Value é
modificado, ela atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de
Value toda vez que alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o
equipamento ou dispositivo se a propriedade AllowWrite do Bloco de Comunicação OPC UA estiver configurada para
Verdadeiro. Caso contrário, se esta propriedade estiver configurada para Falso, os bits não sofrem nem acarretam
qualquer mudança. Esta propriedade pode ser atualizada após ter sido iniciada a comunicação. O valor padrão desta
propriedade é Falso.
Value
Atualizada sempre que um novo valor é lido no servidor OPC UA, de acordo com a especificação da propriedade
ItemID do Bloco de Comunicação OPC UA onde este objeto está inserido, e considerando a propriedade Index, que
especifica a posição do Elemento no vetor do Bloco de Comunicação OPC UA. O tipo de dados desta propriedade,
tais como número inteiro, ponto flutuante ou texto, depende do Driver ao qual está associado e da configuração.
Esta propriedade somente é atualizada desta forma se a propriedade AllowRead do objeto Bloco de Comunicação
OPC UA ao qual o Elemento de Bloco de Comunicação OPC UA pertence estiver configurada para Verdadeiro, e de
acordo com o tempo de varredura definido na propriedade Scan da Assinatura OPC UA que contêm o Bloco de
Comunicação OPC UA. Se a propriedade AllowWrite do objeto Bloco de Comunicação OPC UA estiver configurada
para Verdadeiro, pode-se escrever valores no equipamento ou no dispositivo simplesmente atribuindo um novo valor
para a propriedade Value.
Esta também é a propriedade padrão do objeto Elemento de Bloco OPC UA. Sendo assim, uma referência por valor a
um objeto Elemento de Bloco OPC UA não necessita obrigatoriamente explicitar a propriedade Value para acessar o
valor. Caso esta propriedade não esteja sendo atualizada, verifique se a propriedade Index está corretamente
configurada, ou seja, o valor deve ser entre 0 (zero) e o tamanho do Bloco de Comunicação OPC UA menos um.

5.5.3.4.3 Pasta
O objeto Pasta da Assinatura OPC UA (UaFolder) não possui eventos, métodos ou propriedades específicos
associados, somente métodos e propriedades gerais. Estes podem ser visualizados nas seções Eventos, Métodos e
Propriedades Gerais dos Objetos.

5.5.3.4.4 Tag de Comunicação OPC UA


Esta seção contém informações sobre eventos, métodos e propriedades do objeto Tag de Comunicação OPC UA
(UaTag).

5.5.3.4.4.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tag de Comunicação OPC UA (UaTag).
OnRead
OnRead()
Ocorre quando um valor do Tag de Comunicação OPC UA é recebido do servidor OPC UA. Utilize o evento OnRead
para efetuar alguma operação logo após algum dado ter sido modificado no objeto Tag de Comunicação OPC UA,
nas propriedades Bit00 até Bit31, Quality, RawValue, TimeStamp ou Value.

Objetos de Servidor 326


5.5.3.4.4.2 Métodos
Esta seção contém informações sobre os métodos do objeto Tag de Comunicação OPC UA (UaTag).
Write
Write()
Executa a escrita do valor corrente do Tag de Comunicação OPC UA no equipamento. Para mais detalhes, consulte a
documentação do Driver. Este método retorna um Booleano que indica o sucesso ou não da operação.
WriteEx
WriteEx([Value], [NewTimestamp], [NewQuality], [SyncWrite])
Executa a escrita de um valor no equipamento. Todos os parâmetros são opcionais. Se omitidos, o comportamento
do método é igual ao do método Write. Este método retorna um Booleano que indica o sucesso ou não da
operação. O parâmetro Value define o valor a ser escrito no Driver. O tipo de dados depende do Driver. Se omitido,
assume o valor corrente do Tag de Comunicação OPC UA. Os parâmetros NewTimestamp e NewQuality indicam,
respectivamente, a estampa de tempo e a qualidade do valor, caso a propriedade WriteValueMode esteja
configurada para 2 - wvmValueQualityTimestamp. O parâmetro SyncWrite é um Booleano que especifica se a
operação descrita deve ser síncrona (Verdadeiro) ou assíncrona (Falso). Se omitido, usa o valor especificado na
propriedade SyncWrite do Tag de Comunicação OPC UA.

NOTA
Assim como no método Write, a escrita é realizada independente de o valor ser diferente do valor atual do Tag de
Comunicação OPC UA, bem como independente da propriedade AllowWrite do Tag estar configurada para
Verdadeiro ou Falso. Além disto, se a escrita funciona mas o Tag não está em scan, seja porque a propriedade
AllowRead está configurada para Falso ou porque usa a opção AdviseWhenLinked quando não está sendo
associado, o valor escrito é assumido imediatamente com qualidade boa e estampa de tempo do momento da
escrita.

5.5.3.4.4.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag de Comunicação OPC UA (UaTag).
AdviseType
Controla o modo Advise. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para a propriedade AdviseType
OPÇÃO DESCRIÇÃO
0 - AlwaysInAdvise O Tag de Comunicação OPC UA é mantido atualizado se
a propriedade AllowRead estiver configurada para
Verdadeiro e a propriedade Enable da Assinatura OPC
UA também estiver configurada para Verdadeiro

1 - AdviseWhenLinked O Tag de Comunicação OPC UA só é atualizado se a


propriedade AllowRead e a propriedade Enable da
Assinatura OPC UA estiverem configuradas para
Verdadeiro, e o Tag estiver associado a algum objeto
ativo, como por exemplo um Display de uma Tela aberta
ou um Alarme habilitado, entre outros. A associação do
Tag para este propósito pode ser realizada nas
propriedades Value, RawValue, TimeStamp, Quality e
Bit00 até Bit31 de Tags de Comunicação OPC UA
(padrão)

AllowRead
Define se este Tag de Comunicação OPC UA deve ou não ser lido pela Assinatura OPC UA. Caso a propriedade
esteja configurada para Verdadeiro, a Assinatura OPC UA automaticamente atualiza as propriedades Value, Bits, de
Bit00 até Bit31, e RawValue deste objeto em intervalos de tempo. Caso contrário, este Tag de Comunicação OPC UA
não é lido. Esta propriedade não pode ser alterada com o objeto ativo. O valor padrão desta propriedade é
Verdadeiro.

327 Objetos de Servidor


AllowWrite
Define se este Tag de Comunicação OPC UA deve ou não ser escrito automaticamente quando as propriedades
Value, qualquer uma das propriedades de Bits, de Bit00 até Bit31, ou RawValue são modificadas. Se a propriedade
estiver configurada para Verdadeiro, as modificações são enviadas para o equipamento ou dispositivo associado à
Assinatura OPC UA. Do contrário, as modificações são ignoradas. O valor padrão desta propriedade é Verdadeiro.
Bit00 até Bit31
Estas propriedades representam juntas os 32 bits do valor presente na propriedade Value do objeto Tag de
Comunicação OPC UA, em que Bit00 representa o bit menos significativo e Bit31 representa o bit mais significativo.
Modificar cada um destes bits implica em modificar também a propriedade Value do Tag e vice-versa, mas isto
somente ocorre quando a propriedade UseBitFields está configurada para Verdadeiro. O valor padrão destas
propriedades é Falso.

NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

DataType
Propriedade preenchida quando o E3 se conecta ao servidor OPC UA, que indica o tipo de dados no servidor OPC
UA. Esta propriedade é inicialmente preenchida no processo de busca (browsing), se realizado, e em cada
comunicação ou conexão com o servidor OPC UA. Valores abaixo de 1000 são escalares e valores acima de 1000 são
vetores (arrays). Esta propriedade é somente de leitura. Os valores possíveis para esta propriedade são os seguintes:
· -1: udtUnknown (Valor desconhecido, item desconectado ou tipo de dados não suportado pelo E3)
· 0: udtNull
· 1: udtBoolean
· 2: udtSByte
· 3: udtByte
· 4: udtInt16
· 5: udtUInt16
· 6: udtInt32
· 7: udtUInt32
· 8: udtInt64 (ver Nota a seguir)
· 9: udtUInt64 (ver Nota a seguir)
· 10: udtFloat
· 11: udtDouble
· 12: udtString
· 13: udtDateTime
· 14: udtGuid (Identificador único global de 128 bits, formatado como texto no E3)
· 15: udtByteString (Vetor de bytes ou uma String binária)
· 16: udtXmlElement (Elemento XML, formatado como texto no E3)
· 17: udtNodeId (Identificador de Nó OPC UA, formatado como um vetor de três elementos no E3)
· 18: udtExpandedNodeId (Identificador de Nó OPC UA expandido, formatado como um vetor de três elementos no
E3)
· 19: udtStatusCode (Equivalente à qualidade, indica erros)
· 20: udtQualifiedName (Texto com o Namespace, que no E3 é descartado)
· 21: udtLocalizedText (Texto com o locale, que no E3 é descartado)
· 22: udtStructure (Indica que é um tipo de dados complexo do OPC UA, mas não específico, formatado como um
vetor onde cada elemento é um membro da estrutura)
· 23: udtDataValue (Valor com a qualidade e a estampa de tempo, que no E3 são descartados)
· 24: udtVariant (Valor com tipo de dados variável ou indefinido)
· 25: udtDiagnosticInfo
· 1000: udtArrayUnknown (Vetor genérico, de tipos de dados não conhecidos)
· 1001: udtArrayBoolean

Objetos de Servidor 328


· 1002: udtArraySByte
· 1003: udtArrayByte
· 1004: udtArrayInt16
· 1005: udtArrayUInt16
· 1006: udtArrayInt32
· 1007: udtArrayUInt32
· 1008: udtArrayInt64
· 1009: udtArrayUInt64
· 1010: udtArrayFloat
· 1011: udtArrayDouble
· 1012: udtArrayString
· 1013: udtArrayDateTime
· 1014: udtArrayGuid
· 1015: udtArrayByteString
· 1016: udtArrayXmlElement
· 1017: udtArrayNodeId
· 1018: udtArrayExpandedNodeId
· 1019: udtArrayStatusCode
· 1020: udtArrayQualifiedName
· 1021: udtArrayLocalizedText
· 1022: udtArrayStructure
· 1023: udtArrayDataValue
· 1024: udtArrayVariant

NOTAS
· Apesar de o padrão OPC UA permitir valores de 64 bits, atualmente no E3 as propriedades de Bit00 até Bit31
permitem apenas controlar os primeiros 32 bits menos significativos.
· Estruturas definidas por servidores específicos, não compatíveis com o padrão OPC UA, não são lidas pelo E3.
· Tipos de dados complexos com valores abaixo de 1000 devem ser usados em Blocos de Comunicação OPC UA.
· Os tipos de dados udtQualifiedName, udtArrayQualifiedName, udtLocalizedText, udtArrayLocalizedText,
udtStructure, udtArrayStructure, udtDataValue, udtArrayDataValue, udtUnknown e udtArrayUnknown não
permitem a escrita na versão atual do E3, pois o E3 utiliza uma formatação simplificada destes tipos de dados.
· Os tipos de dados ServiceCounterDataType (array de duas posições), BuildIndfo (array de seis posições),
Argument (array de seis posições), ApplicationDescription (array de oito posições),
SessionDiagnosticsDataType (array de 44 posições), SessionSecurityDiagnosticsDataType (array de 10
posições), SubscriptionsDiagnosticsDataType (array de 31 posições), ServerDiagnosticsSummaryDataType
(array de 12 posições), ServerStatusDataType (array de seis posições), EuInformation (array de quatro posições),
Range (array de duas posições), TimeZoneDataType (array de duas posições), DiagnosticInfo (array de sete
posições), StatusResult (array de duas posições), ComplexNumberType (array de duas posições),
DoubleComplexNumberType (array de duas posições), XVType (array de duas posições),
RedundanteServerSataType (array de três posições), SamplingIntervalDiagnosticsDataType (array de quatro
posições), EnumValueType (array de três posições), EndpointUrlListDataType (array de duas posições) e
NetworkGroupDataType (array de três posições) são mostrados como udtStructure, mas o E3 trata o tipo de
dados específico.
· Na versão atual, o E3 só permite vetores de uma dimensão, ou seja, não permite matrizes como tipos de dados.

DeviceHigh
Esta propriedade define o valor máximo atingido por um Tag de Comunicação OPC UA no equipamento ou no
dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento ou do
dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro, senão os valores permanecem os mesmos. O valor padrão desta
propriedade é 1000.

329 Objetos de Servidor


NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

DeviceLow
Esta propriedade define o valor mínimo atingido por um Tag de Comunicação OPC UA no equipamento ou no
dispositivo. Esta propriedade é utilizada para executar o ajuste de escala do valor proveniente do equipamento ou do
dispositivo antes de ser atribuído à propriedade Value. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro, senão as configurações permanecem as mesmas. O valor padrão
desta propriedade é 0 (zero).

NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

EnableDriverEvent
Esta propriedade é utilizada para controlar a geração do evento OnTagRead, que ocorre no Driver de
Comunicação OPC UA que contém o Tag de Comunicação OPC UA. Se a propriedade EnableDriverEvent do Tag
estiver configurada para Verdadeiro, a cada leitura vinda do servidor OPC UA, seja com erro ou não, é gerado o
evento OnTagRead no objeto Driver de Comunicação OPC UA que contém este Tag. Caso contrário, o evento não
ocorre. Também quando a propriedade EnableDriverEvent estiver configurada para Verdadeiro, a cada escrita que
seja enviada para o servidor OPC UA é gerado o evento OnTagWrite no objeto Driver de Comunicação OPC UA que
contém o Tag. Se a escrita é assíncrona, o evento OnTagWrite é gerado apenas quando o servidor enviar a resposta
indicando o efetivo sucesso ou não da escrita. Neste caso, o evento é gerado apenas se a propriedade
EnableDriverEvent estiver configurada para Verdadeiro neste momento, e não no momento do envio da escrita. O
valor padrão desta propriedade é Falso.
EnableScaling
Se esta propriedade estiver configurada para Verdadeiro, todo valor proveniente do equipamento ou do
dispositivo sofre ajuste de escala conforme as propriedades EUHigh e EULow antes de ser atribuído à propriedade
Value. Caso a propriedade EnableScaling esteja configurada para Falso, nenhum ajuste de escala é efetuado em
nenhum dos dois sentidos, tanto para escrita como para leitura. O valor padrão desta propriedade é Falso.
EU
Identifica a unidade de engenharia representada pelo valor, como por exemplo graus, metros ou KW/h. O valor
padrão desta propriedade é vazio.
EUHigh
Define qual o valor máximo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 1000.

NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

EULow
Define qual o valor mínimo que deve ser atribuído à propriedade Value, ajustando a escala ao valor do
equipamento ou do dispositivo antes desta atribuição. Da mesma forma, no momento da escrita, é executada a
operação inversa antes de enviar o valor para o Driver. Esta conversão só ocorre quando a propriedade
EnableScaling está configurada para Verdadeiro. O valor padrão desta propriedade é 0 (zero).

NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

Objetos de Servidor 330


ItemID
Especifica o caminho para realizar a busca, ou browsing, de um Tag de Comunicação OPC UA em um servidor OPC
UA. Este caminho é usado no método RefreshUaNodeIds do Driver de Comunicação OPC UA para recuperar o
Identificador de Nó OPC UA de um Tag de Comunicação OPC UA, quando desejado.
Quality
Esta propriedade informa qual a qualidade do valor contido na propriedade Value. Cada vez que a Assinatura OPC
UA atribui um novo valor para o Tag de Comunicação OPC UA, também configura a qualidade daquele dado. Esta
propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero, qualidade ruim).

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

RawValue
Acessa o valor original do Tag de Comunicação OPC UA anterior à escala, ou seja, independente da configuração da
propriedade EnableScaling. Portanto, se esta propriedade estiver configurada para Falso, as propriedades Value e
RawValue apresentam o mesmo comportamento.
SyncWrite
Esta propriedade determina o tipo de escrita usada por um Tag de Comunicação OPC UA. Se a propriedade estiver
configurada para Verdadeiro, a escrita é síncrona, isto é, a Assinatura OPC UA espera o resultado da escrita do
servidor. Caso contrário, a escrita é assíncrona, isto é, o valor do Tag de Comunicação OPC UA é enviado e o
processamento da Assinatura OPC UA continua imediatamente. O valor padrão desta propriedade é Falso.

NOTA
No modo assíncrono, com esta propriedade configurada para Falso, a performance da comunicação tende a ser
melhor, porém no modo síncrono, com esta propriedade configurada para Verdadeiro, o sucesso da operação de
escrita é verificado e informado.

TimeStamp
Esta propriedade é atualizada sempre que ocorrer alguma mudança de valor ou de estado nas propriedades
Value ou Quality. Esta propriedade informa qual a data e hora associada tanto ao valor quanto à qualidade do Tag
de Comunicação OPC UA. Esta propriedade é somente de leitura. O valor padrão desta propriedade é "00:00:00".
UaNodeId
Especifica o caminho para realizar a busca, ou browsing, de um Tag de Comunicação OPC UA em um servidor OPC
UA. Este caminho é usado no método RefreshUaNodeIds do Driver de Comunicação OPC UA para recuperar o
Identificador de Nó OPC UA de um Tag de Comunicação OPC UA, quando desejado. Esta propriedade deve estar
preenchida para estabelecer a comunicação com um servidor OPC UA.
UseBitFields
Caso esta propriedade esteja configurada para Verdadeiro, toda vez que o valor da propriedade Value é
modificado ele atualiza os bits referentes às propriedades Bit00 até Bit31. Da mesma forma, atualiza o valor de Value
toda vez que alguma das propriedades Bit00 até Bit31 mudar de valor e posteriormente envia para o equipamento
ou dispositivo se a propriedade AllowWrite estiver configurada para Verdadeiro. Caso contrário, se esta propriedade
estiver configurada para Falso, os bits não sofrem qualquer mudança. Esta propriedade pode sofrer atualização após
ter sido iniciada a comunicação. O valor padrão desta propriedade é Falso.

NOTA
Os valores dos bits, ou seja, as propriedades Bit00 até Bit31, não são afetados pelo ajuste de escala, isto é,
representam os bits do valor lido do equipamento antes da conversão.

Value
Esta propriedade é atualizada quando é executada uma nova leitura válida de um valor do equipamento ou do
dispositivo utilizando sua configuração, porém o tipo de dados desta variável, tais como número inteiro, ponto
flutuante ou texto, depende do Driver de Comunicação OPC UA ao qual está associado e da configuração. Esta
propriedade somente é atualizada desta forma se a propriedade AllowRead está configurada para Verdadeiro e
quando não houver erros de comunicação, neste caso somente as propriedades Quality e TimeStamp são
atualizadas, mas de acordo com o tempo de varredura definido na Assinatura OPC UA ao qual o Tag de Comunicação
OPC UA pertence. Outra forma de utilizar esta propriedade é escrever valores no equipamento ou dispositivo. Basta

331 Objetos de Servidor


que se atribua um novo valor para a propriedade Value ou algum dos bits Bit00 até Bit31, desde que a propriedade
AllowWrite esteja configurada para Verdadeiro. Esta propriedade também é a propriedade padrão do objeto Tag de
Comunicação OPC UA. Sendo assim, uma referência por valor a um objeto Tag de Comunicação OPC UA não necessita
obrigatoriamente explicitar a propriedade Value para acessar o valor. O valor padrão desta propriedade é vazio.
WriteValueMode
Propriedade de leitura e escrita que controla o comportamento do envio do valor nas operações de escrita. Esta
propriedade deve ser configurada de acordo com o servidor OPC UA utilizado, pois do contrário a escrita falha. Os
valores possíveis para esta propriedade são os seguintes:
· 0 - wvmDefault: Segue o comportamento padrão, isto é, o comportamento configurado no Driver de
Comunicação OPC UA a que este Tag de Comunicação OPC UA pertence
· 1 - wvmValueOnly: Escreve apenas o valor
· 2 - wvmValueQualityTimestamp: Envia sempre a qualidade e a estampa de tempo junto com o valor

5.6 Fórmulas
Esta seção contém informações sobre métodos e propriedades do objeto Fórmula (Formula). Este objeto não possui
eventos associados.

5.6.1 Métodos
Esta seção contém informações sobre os métodos do objeto Fórmula (Formula).

5.6.1.1 CreateUnit
CreateUnit(UnitName)
Cria uma Unidade na tabela de Fórmulas. Este método possui o parâmetro UnitName, que determina o nome da
Unidade a ser criada. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.2 CreateValue
CreateValue(ValueName)
Cria um Conjunto de Valores na tabela de Fórmulas. Este método possui o parâmetro ValueName, que determina o
nome do Conjunto de Valores a ser criado. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em
caso de falha.

5.6.1.3 DeleteUnit
DeleteUnit(UnitName)
Apaga uma Unidade na tabela de Fórmulas. Este método possui o parâmetro UnitName, que informa o nome da
Unidade a ser apagada. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.4 DeleteValue
DeleteValue(ValueName)
Apaga um Conjunto de Valores na tabela de Fórmulas. Este método possui o parâmetro ValueName, que informa o
nome do Conjunto de Valores a ser apagado. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso
em caso de falha.

5.6.1.5 FindUnit
FindUnit(UnitName)
Verifica se uma determinada Unidade existe no banco de dados das Fórmulas. Este método possui o parâmetro
UnitName, que determina o nome da Unidade a ser encontrada. O método retorna Verdadeiro se a operação é
realizada com sucesso ou Falso em caso de falha.

5.6.1.6 FindValue
FindValue(ValueName)
Verifica se um determinado Conjunto de Valores existe no banco de dados de Fórmulas. Este método possui o
parâmetro ValueName, que informa o nome do Conjunto de Valores a ser encontrado. Retorna Verdadeiro se a
operação é realizada com sucesso ou Falso em caso de falha.

Objetos de Servidor 332


5.6.1.7 GetUnitData
GetUnitData(UnitName, TemplateName, Val)
Coloca na variável indicada em Val o Tag associado à Unidade UnitName do Template TemplateName. Retorna
Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.8 GetValueData
GetValueData(ValueName, TemplateName, Val)
Coloca na variável Val o valor do Conjunto de Valores ValueName que está associado ao Template TemplateName.
Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.9 LoadFormulaValuesQuiet
LoadFormulaValuesQuiet(UnitName, ValueName)
Carrega um Conjunto de Valores para uma Unidade de destino, sem apresentar nenhuma mensagem. Este método
possui os parâmetros UnitName, que determina o nome da Unidade, e ValueName, que determina o nome do
Conjunto de Valores. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha. Isto não
significa um erro de script, necessariamente.

NOTA
Este método também é acessado através do objeto Viewer.

5.6.1.10 RenameUnit
RenameUnit(UnitName, NewUnitName)
Renomeia uma determinada Unidade existente na tabela de Fórmulas. Este método possui os parâmetros UnitName,
que determina o nome da Unidade a ser encontrada, e NewUnitName, que informa o novo nome da Unidade. Retorna
Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.11 RenameValue
RenameValue(ValueName, NewValueName)
Renomeia um determinado Conjunto de Valores existente na tabela de Fórmulas. Este método possui os parâmetros
ValueName, que informa o nome do Conjunto de Valores, e NewValueName, que informa o novo nome do Conjunto
de Valores. Retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

5.6.1.12 SaveFormulaValues
SaveFormulaValues(UnitName, ValueName, [IgnoreErrors])
Salva os valores atuais dos Tags de uma Unidade de origem em um Conjunto de Valores na tabela de Fórmulas. Este
método possui os parâmetros UnitName, que indica o nome da Unidade de origem, ValueName, que indica o
Conjunto de Valores que é salvo, e IgnoreErrors, um Booleano opcional que permite que se grave ou não todos os
valores, independente de haver erros nas associações da Fórmula. Se este parâmetro é omitido, os valores não são
gravados. Este método não realiza a verificação de limites se o Template tem uma restrição do tipo Absoluta.

5.6.1.13 SetUnitData
SetUnitData(UnitName, TemplateName, Data)
Carrega para a tabela de Fórmulas o Tag identificado para um certo Template, em uma determinada Unidade. Este
método possui os parâmetros UnitName, que informa o nome da Unidade, TemplateName, que informa o nome do
Template do Tag e Data, que informa o nome do Tag a ser atribuído à Unidade. Retorna Verdadeiro se a operação é
realizada com sucesso ou Falso em caso de falha.

5.6.1.14 SetValueData
SetValueData(ValueName, TemplateName, Data)
Altera o valor referente a um Template definido para um determinado Conjunto de Valores. Este método possui os
parâmetros ValueName, que determina o nome do Conjunto de Valores, TemplateName, que determina o nome do

333 Objetos de Servidor


Template, e Data, que determina o valor a ser atribuído ao Conjunto de Valores. Este método realiza a verificação dos
limites e retorna Verdadeiro se a operação é realizada com sucesso ou Falso em caso de falha.

NOTA
Para mais informações sobre o método SetValueData, consulte os artigos Trabalhando com Fórmulas no Elipse E3,
Criando um conjunto de valores durante a execução e Modificando um conjunto de valores em tempo de execução no
Elipse Knowledgebase.

5.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fórmula (Formula).

5.6.2.1 DataSourceSize
Indica o tamanho máximo dos campos de Unidades na tabela do Banco de Dados. O valor padrão desta
propriedade é 200 e seu valor deve ser positivo.

NOTA
· O tipo de dados desta propriedade é um inteiro de 32 bits, mas é dependente do tipo de dados definido pelo
servidor de banco de dados utilizado (Access, SQL Server ou Oracle).
· Alterar esta propriedade para um valor menor do que o previamente configurado pode resultar em truncamento
dos dados já armazenados na tabela do Banco de Dados.

5.6.2.2 DBServer
Indica o nome do banco de dados onde são gravadas as informações da Fórmula, ou seja, as Unidades e os
Conjuntos de Valores. O valor padrão desta propriedade é uma String vazia.

5.6.2.3 ImmediateExecute
Quando habilitada, esta propriedade permite que a Fórmula escreva seus registros diretamente no Banco de Dados
sem precisar passar por suas filas de operações, ou seja, os arquivos .e3i e .e3o. Isto permite que as operações
realizadas no Banco de Dados sejam visualizadas de forma mais rápida.

5.6.2.4 TableName
Indica o nome das tabelas onde são armazenadas as informações das Fórmulas. O valor padrão desta propriedade
é uma String vazia.

5.6.2.5 ValueSize
Indica o tamanho máximo dos campos de Valores na tabela do Banco de Dados. O valor padrão desta propriedade
é 200 e seu valor deve ser positivo.

NOTA
· O tipo de dados desta propriedade é um inteiro de 32 bits, mas é dependente do tipo de dados definido pelo
servidor de banco de dados utilizado (Access, SQL Server ou Oracle).
· Alterar esta propriedade para um valor menor do que o previamente configurado pode resultar em truncamento
dos dados já armazenados na tabela do Banco de Dados.

5.7 Históricos
Esta seção contém informações sobre métodos e propriedades do objeto Histórico (Hist). Este objeto não possui
eventos associados.

5.7.1 Métodos
Esta seção contém informações sobre os métodos do objeto Histórico (Hist).

Objetos de Servidor 334


5.7.1.1 StartAcquisition
StartAcquisition()
Habilita o Histórico a gravar os valores do seus campos periodicamente, a partir da taxa especificada na propriedade
ScanTime. Este método pode ser utilizado a qualquer momento após utilizar o método StopAcquisition. O
comportamento padrão deste método é iniciar a aplicação habilitado, ou seja, este método é sempre executado
internamente ao se iniciar o Histórico. Exemplo:
Sub Botao1_Click()
' Ao clicar neste botão, habilita o Histórico.
Application.GetObject("Hist1").StartAcquisition()
End Sub

5.7.1.2 StopAcquisition
StopAcquisition()
Desabilita a gravação dos registros por período no Histórico, independente do valor especificado na propriedade
ScanTime. A gravação por período permanece desabilitada até que o método StartAcquisition seja utilizado. O
comportamento padrão do objeto Histórico é iniciar a aplicação com a gravação habilitada. Exemplo:
Sub Hist1_OnStartRunning()
' Desabilita o Histórico assim que iniciar.
StopAcquisition()
End Sub

5.7.1.3 WriteRecord
WriteRecord()
Insere um novo registro no banco de dados. Os valores são obtidos a partir dos valores atuais de cada uma das
variáveis especificadas como fontes de dados dos campos do Histórico. Utiliza-se este método em duas situações:
· Para gravar um novo registro antes do tempo previsto para a próxima gravação quando o Histórico está
habilitado por tempo
· Para gravar um novo registro quando o Histórico está desabilitado

Exemplo:
Sub Tag1_OnValueChange()
' Grava um novo registro em um Histórico
' quando um Tag muda de valor.
Application.GetObject("Hist1").WriteRecord()
End Sub

5.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Histórico (Hist).

5.7.2.1 BackupDiscardInterval
Indica o intervalo máximo de tempo, em minutos, horas, dias ou meses, dos dados na tabela de backup do Histórico
até serem descartados, independente do tempo que os dados permanecem na tabela principal. Por exemplo, para
manter os dados por 24 meses na tabela principal e mais seis meses na tabela de backup, o valor desta propriedade
deve ser de 30 meses. Esta propriedade trabalha em conjunto com a propriedade BackupDiscardTimeUnit. O valor
padrão desta propriedade é 12 (doze unidades de tempo indicadas em BackupDiscardTimeUnit).

NOTA
O tempo total indicado pela combinação desta propriedade e da propriedade BackupDiscardTimeUnit deve ser
maior que o tempo indicado pelas propriedades DiscardInterval e DiscardTimeUnit.

5.7.2.2 BackupDiscardTimeUnit
Esta propriedade indica a unidade de tempo em que os dados de backup do Histórico permanecem armazenados
até serem descartados. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)

335 Objetos de Servidor


· 3 - dtMinute: Minutos

Esta propriedade trabalha em conjunto com a propriedade BackupDiscardInterval.

5.7.2.3 CacheSize
Define o tamanho do bloco de registros que deve ser lido pelo Histórico antes de ser enviado para o banco de
dados. Por exemplo, se esta propriedade é igual a 4 (quatro), são enviados blocos contendo quatro registros cada
um para o objeto Banco de Dados associado. Os valores válidos para esta propriedade devem estar no intervalo
entre 1 (um) e 4 (quatro). O valor padrão desta propriedade é 1 (um).

NOTA
O bloco de registros é enviado a cada um segundo, mesmo que não tenha atingido o tamanho configurado nesta
propriedade.

5.7.2.4 CompressedTable
Habilita o uso de banda morta para a gravação de dados. O valor padrão desta propriedade é Falso.

5.7.2.5 DBServer
Indica o objeto Banco de Dados utilizado no Histórico para criação de tabelas e registros de dados. O valor padrão
desta propriedade é uma String vazia.

5.7.2.6 DeadBand
Esta propriedade trabalha em conjunto com a propriedade CompressedTable e indica o valor calculado sobre o
último valor gravado, em percentagem, que define se este novo valor é gravado. Se o valor gravado não é numérico,
sua modificação força todos os valores a serem gravados.

5.7.2.7 DiscardInterval
Esta propriedade trabalha em conjunto com a propriedade DiscardTimeUnit e indica o intervalo de tempo durante
o qual os dados do Histórico permanecem armazenados na tabela do banco de dados, até serem descartados. O
valor padrão desta propriedade é 1 (uma unidade de tempo indicada em DiscardTimeUnit). Se esta propriedade é
configurada com um valor menor ou igual ao valor da propriedade BackupDiscardInterval, o E3 automaticamente
ajusta o valor de BackupDiscardInterval como o dobro do valor desta propriedade.

5.7.2.8 DiscardTimeUnit
Esta propriedade trabalha em conjunto com a propriedade DiscardInterval e indica a unidade de tempo em que
os dados do Histórico permanecem armazenados até serem descartados. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)
· 3 - dtMinute: Minutos

5.7.2.9 EnableBackupTable
Cria uma tabela de backup onde os dados descartados do Histórico permanecem por segurança. Se configurada
para Verdadeiro, a tabela é criada. Caso contrário, não há tabela de backup. O valor padrão desta propriedade é
Falso.

5.7.2.10 EnableDiscard
Indica descarte dos dados do Histórico após um certo tempo. Se configurada para Falso, os dados são
armazenados indefinidamente na tabela. Caso contrário, são descartados após determinado tempo. O valor padrão
desta propriedade é Falso.

5.7.2.11 EnableQualityLogs
Quando em Verdadeiro, ao iniciar o Histórico o E3 gera um registro igual ao primeiro registro coletado, mas com
qualidade ruim (0) e estampa de tempo de um segundo antes.

Objetos de Servidor 336


5.7.2.12 Fields
Esta propriedade retorna um objeto que representa a coleção de Campos criados em um Histórico. Esta
propriedade é somente de leitura. Para mais informações sobre o objeto retornado nesta propriedade, consulte o
tópico Fields.

NOTAS
· Em aplicações criadas antes da versão 5.0 do E3, esta propriedade é uma coleção padrão, que suporta o método
Item para acessar os Campos disponíveis. A partir da versão 5.0, esta propriedade também retorna um objeto
nativo do E3 e, portanto, a forma de acesso aos Campos é diferente para ambas as formas. O exemplo a seguir
demonstra a forma correta de utilização desta propriedade.
· Aplicações salvas na versão 5.0 convertem os objetos Histórico do formato de coleção para objeto nativo e NÃO
podem mais ser abertas em versões anteriores.

Para acessar a coleção de Campos de Histórico tanto como uma coleção quanto como um objeto nativo, use a sintaxe
descrita no exemplo a seguir.
'A aplicação contém um objeto chamado Hist1
'que contém um Campo chamado Campo1.
'Para acessar este Campo a partir de uma coleção,
'use a seguinte sintaxe:
Set campoColecao = Application.GetObject("Hist1").Fields.Item("Campo1")
'Para acessar este mesmo Campo como um objeto nativo,
'use a seguinte sintaxe:
Set campoNativo = Application.GetObject("Hist1.Fields.Campo1")

5.7.2.13 ScanTime
Define a variação de intervalo do tempo, em milissegundos, que o Histórico espera para executar a aquisição e
gravação de um novo registro na tabela. Utilize esta propriedade se houver necessidade de maior ou menor
quantidade de dados gerados por segundo. O valor padrão desta propriedade é 1000.

5.7.2.14 TableName
Define o nome da tabela utilizada no Histórico.

5.7.2.15 UserTable
Quando esta propriedade está configurada para Verdadeiro, identifica que o Histórico é do usuário, ou seja, os
dados da tabela foram importados do banco de dados. Caso contrário, é um Histórico normal do E3. Esta
propriedade é somente de leitura.

5.7.2.16 UseTagQuality
Se esta propriedade está configurada para Verdadeiro, o Histórico usa o valor de qualidade da fonte do Tag. Caso
contrário, utiliza o método antigo de avaliação, ou seja, 0: Valor duvidoso ou 1: Valor bom.

5.7.2.17 VerificationInterval
Esta propriedade trabalha em conjunto com a propriedade VerificationUnit para controlar o intervalo de tempo
que o E3 verifica a antiguidade dos dados do Histórico, para depois descartá-los. O valor padrão desta propriedade
é 1 (uma unidade de tempo indicada na propriedade VerificationUnit).

5.7.2.18 VerificationUnit
Esta propriedade trabalha em conjunto com a propriedade VerificationInterval e indica a unidade de tempo em
que é realizada a verificação para descarte dos dados do Histórico. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)
· 3 - dtMinute: Minutos

337 Objetos de Servidor


5.7.3 Fields
Esta seção contém informações sobre métodos e propriedades do objeto Fields (HistFieldsCollection). Este objeto
não possui eventos associados.

NOTA
O objeto Fields pode ser acessado através da propriedade Fields do Histórico.

5.7.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Fields (HistFieldsCollection).

5.7.3.1.1 AddField
AddField([Name], [SourceLink], [Type], [Size])
Este método adiciona um novo Campo de Histórico no objeto Fields e retorna o objeto criado. Em caso de erro, este
método retorna Nothing. Todos os parâmetros deste método são opcionais. A tabela a seguir contém a descrição de
cada um dos parâmetros.
Parâmetros do método AddField
PARÂMETRO DESCRIÇÃO
Name Nome do Campo de Histórico. Se este parâmetro é
omitido, o nome recebe a expressão "Campo" e é
autoincrementado, se necessário. Este parâmetro
corresponde à propriedade Name do Campo de
Histórico. Consulte a propriedade geral Name para mais
informações sobre os caracteres permitidos nos nomes
de objetos

SourceLink Fonte de dados do Campo de Histórico. Se este


parâmetro é omitido, a fonte de dados recebe uma
String vazia. Este parâmetro corresponde à propriedade
Link do Campo de Histórico

Type Tipo de dados do Campo de Histórico. Se este


parâmetro é omitido, o tipo de dados é configurado
como 1: Integer. Este parâmetro corresponde à
propriedade Type do Campo de Histórico

Size Tamanho do Campo de Histórico. Se este parâmetro é


omitido, o tamanho do Campo de Histórico recebe o
valor 0 (zero). Este parâmetro corresponde à
propriedade Size do Campo de Histórico

NOTA
Para Históricos cuja tabela no Banco de Dados seja criada pelo usuário, este método retorna um erro.

5.7.3.1.2 DeleteField
DeleteField(Index)
Remove o Campo de Histórico informado no parâmetro Index, que pode ser a posição do Campo de Histórico
(iniciando em um) ou o valor da propriedade Name do Campo de Histórico, se este Campo de Histórico existir no
objeto Fields. Caso contrário, este método retorna um erro de script.

NOTA
O Campo de Histórico E3TimeStamp, criado automaticamente pelo E3, não pode ser removido.

5.7.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fields (HistFieldsCollection).

Objetos de Servidor 338


5.7.3.2.1 Count
Retorna a quantidade de objetos Campo de Histórico no objeto Fields. Esta propriedade é somente de leitura.

5.7.3.3 Campo de Histórico


Esta seção contém informações sobre as propriedades do objeto Campo de Histórico (HistField). Este objeto não
possui eventos nem métodos associados.

5.7.3.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo de Histórico (HistField).

5.7.3.3.1.1 Field
Esta propriedade determina o nome do Campo de Histórico na tabela do banco de dados. O valor padrão desta
propriedade é uma String vazia, ou seja, usa o valor da propriedade Name como nome do Campo na tabela do
banco de dados. Se esta propriedade contém um valor diferente de uma String vazia, este valor é usado como o
nome deste Campo de Histórico na tabela do banco de dados.

NOTA
Para aplicações criadas em versões anteriores à versão 5.0 e abertas na versão 5.0 ou mais recente em que a
propriedade Name contém um valor que não pode ser usado como nome de objeto no E3, a expressão "Campo_" é
concatenada ao valor da propriedade Name e usada como nome deste Campo de Histórico na tabela do banco de
dados.

5.7.3.3.1.2 Link
Esta propriedade determina a fonte de dados associada ao Campo de Histórico. Esta propriedade não pode ser
alterada em tempo de execução em tabelas criadas pelo Histórico, apenas em tabelas criadas pelo usuário.

5.7.3.3.1.3 Name
Esta propriedade retorna ou configura o nome deste Campo de Histórico no objeto Histórico. Através desta
propriedade é possível buscar itens na Coleção de Campos de Histórico, ou seja, na propriedade Fields. O valor
padrão desta propriedade é uma String vazia. Não é permitido utilizar as expressões "Null", "Empty", "Nothing",
"Application", "True" ou "False" para esta propriedade. Consulte a propriedade geral Name para mais informações
sobre os caracteres permitidos no nome deste objeto.

5.7.3.3.1.4 PrimaryKey
Esta propriedade indica se este Campo de Histórico é usado na definição da chave primária do Histórico. O valor
padrão desta propriedade é Falso.

5.7.3.3.1.5 Size
Esta propriedade indica o tamanho do Campo de Histórico. O valor desta propriedade geralmente é usado para
Campos de Histórico cuja propriedade Type seja igual a 0: fdText. Este valor não pode ser negativo e seu valor
padrão é 0 (zero).

5.7.3.3.1.6 Type
Esta propriedade indica o tipo de dados do Campo de Histórico. Os valores possíveis para esta propriedade são
0: fdText, 1: fdInteger, 2: fdDouble ou 3: fdDateTime. O valor padrão desta propriedade é 1: fdInteger.

5.7.4 Indexes
Este objeto representa todos os Índices disponíveis em um Histórico e não contém eventos, métodos ou propriedades
específicos, somente gerais. Estes podem ser visualizados na seção Eventos, Métodos e Propriedades Gerais dos
Objetos.

NOTA
O objeto Indexes não pode ser inserido em um Histórico com tabelas criadas pelo usuário.

339 Objetos de Servidor


5.7.4.1 Índice de Histórico
Esta seção contém informações sobre as propriedades do objeto Índice de Histórico (HistIndex). Este objeto não
possui eventos nem métodos associados.

5.7.4.1.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Índice de Histórico (HistIndex).

5.7.4.1.1.1 IndexName
Esta propriedade indica o nome deste Índice na tabela do banco de dados. O valor padrão desta propriedade é
uma String vazia. Neste caso, usa o nome do objeto como nome do Índice. Se esta propriedade é preenchida, o valor
deve ser único entre os Índices criados para o Histórico.

5.7.4.1.1.2 Unique
Esta propriedade define se os Campos que compõem este Índice devem ter registros únicos na tabela do banco de
dados. O valor padrão desta propriedade é Falso.

5.7.4.1.2 Campo de Índice


Esta seção contém informações sobre as propriedades do objeto Campo de Índice (HistIndexField). Este objeto não
possui eventos nem métodos associados.

5.7.4.1.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo de Índice (HistIndexField).
Field
Esta propriedade define o nome de um campo na tabela do banco de dados usado como Índice no Histórico. O
valor padrão desta propriedade é uma String vazia.
Order
Esta propriedade define a ordenação deste Campo no Índice. As opções disponíveis para esta propriedade são 0:
foAscending (padrão) ou 1: foDescending.

5.7.5 PrimaryKey
Esta seção contém informações sobre as propriedades do objeto PrimaryKey. Este objeto não tem eventos nem
métodos associados e representa todas as Chaves Primárias disponíveis em um Histórico.

NOTA
O objeto PrimaryKey não pode ser inserido em um Histórico com tabelas criadas pelo usuário.

5.7.5.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto PrimaryKey.

5.7.5.1.1 KeyName
Esta propriedade indica o nome desta Chave Primária na tabela do banco de dados. O valor padrão desta
propriedade é "E3Index".

5.7.5.2 Campo de Chave Primária


Esta seção contém informações sobre as propriedades do objeto Campo de Chave Primária (HistPrimaryKeyField).
Este objeto não possui eventos nem métodos associados.

5.7.5.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo de Chave Primária (HistPrimaryKeyField).

Objetos de Servidor 340


5.7.5.2.1.1 Field
Esta propriedade define o nome de um campo na tabela do banco de dados usado como Chave Primária no
Histórico. O valor padrão desta propriedade é uma String vazia.

5.7.5.2.1.2 Order
Esta propriedade define a ordenação deste Campo na Chave Primária. As opções disponíveis para esta
propriedade são 0: foAscending (padrão) ou 1: foDescending.

5.8 Informações do Servidor


Esta seção contém informações sobre as propriedades do objeto Informações do Servidor (ServerNode). Este objeto
não possui eventos nem métodos associados.

NOTAS
· Este objeto e todos os seus objetos filhos possuem as propriedades gerais Count, Name e Parent, além do
método geral Item. Também é possível utilizar a declaração For Each em scripts para enumerar os objetos filhos.
· A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?Server]", é obrigatória.

5.8.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações do Servidor (ServerNode).

5.8.1.1 ProductString
Retorna o nome do produto e a versão do servidor, como por exemplo "E3 6.1.101". Esta propriedade é somente
de leitura.

5.8.2 Informações da Sessão


Esta seção contém informações sobre propriedades do objeto Informações da Sessão (SessionNodeBase). Este
objeto não possui eventos nem métodos associados.

NOTA
A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?
Server].Clients.RemoteDomains", é obrigatória.

Os objetos Informações da Sessão atualmente disponíveis são os seguintes:


· RemoteDomains: Conexões de Domínios remotos
· Studios: Conexões de E3 Studios
· Viewers: Conexões de E3 Viewers

5.8.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações da Sessão (SessionNodeBase).

5.8.2.1.1 Address
Retorna o endereço IPv4 da máquina cliente, no formato XXX.XXX.XXX.XXX, onde XXX é um valor entre 0 (zero) e
255. Esta propriedade é somente de leitura.

5.8.2.1.2 Machine
Retorna o nome da máquina cliente. Esta propriedade é somente de leitura.

5.8.2.1.3 ReadOnly
Indica se a sessão do cliente está no modo somente leitura. Esta propriedade é somente de leitura.

341 Objetos de Servidor


NOTA
Esta propriedade não está disponível para os objetos de sessões Studios, em "[?Server].Clients.Studios".

5.8.2.1.4 StartTime
Indica a data e hora do estabelecimento da conexão com o cliente. Esta propriedade é somente de leitura.

5.8.2.1.5 User
Retorna o nome de login do usuário da sessão ou uma String vazia no caso de um usuário anônimo. Esta
propriedade é somente de leitura.

5.8.2.1.6 Version
Retorna a versão do cliente, como por exemplo "6.1.101". Esta propriedade é somente de leitura.

5.8.3 Informações das Licenças


Esta seção contém informações sobre propriedades do objeto Informações das Licenças (LicenseNode). Este objeto
não possui eventos nem métodos associados.

NOTAS
· Este objeto e todos os seus objetos filhos possuem as propriedades gerais Count, Name e Parent, além do
método geral Item. Também é possível utilizar a declaração For Each em scripts para enumerar os objetos filhos.
· A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?Server].License", é
obrigatória.

5.8.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações das Licenças (LicenseNode).

5.8.3.1.1 DbAvailable
Indica se a licença atual permite o recurso de bancos de dados. Esta propriedade é somente de leitura.

5.8.3.1.2 DeviceType
Indica o tipo de dispositivo da licença atual. Os valores possíveis para esta propriedade são 0: Não encontrado, 1:
HASP, 2: TimeHasp ou 3: Softkey. Esta propriedade é somente de leitura.

5.8.3.1.3 ErrorMessage
Retorna a mensagem de erro relacionada à licença atual ou uma String vazia caso não haja nenhuma mensagem de
erro, que é o valor padrão. Esta propriedade é somente de leitura.

5.8.3.1.4 ExpireDate
Indica a data de expiração da licença atual ou 0 (zero) se a licença atual não tem data de expiração. Esta
propriedade é somente de leitura.

5.8.3.1.5 ID
Retorna o identificador único do dispositivo de proteção da licença atual ou uma String vazia caso o E3 esteja em
modo de demonstração. Esta propriedade é somente de leitura.

5.8.3.1.6 IsDemo
Indica se a licença atual está em modo de demonstração, ou seja, não foi encontrada nenhuma licença válida. Esta
propriedade é somente de leitura.

5.8.3.1.7 MaxRuntime
Indica o tempo máximo permitido de execução do Domínio, em minutos. Esta propriedade é somente de leitura.

Objetos de Servidor 342


5.8.3.1.8 OpcClientAvailable
Indica se a licença atual permite a utilização de um cliente OPC DA. Esta propriedade é somente de leitura.

5.8.3.1.9 ReportsAvailable
Indica se a licença atual permite a utilização do recurso de Relatórios. Esta propriedade é somente de leitura.

5.8.3.1.10 TrendAnalysisAvailable
Indica se a licença atual permite a utilização do recurso de TrendAnalysis. Esta propriedade é somente de leitura.

5.8.3.1.11 UaClientAvailable
Indica se a licença atual permite a utilização de um cliente OPC UA. Esta propriedade é somente de leitura.

5.8.3.1.12 VersionRange
Indica o intervalo de versões permitido pela licença atual, como por exemplo "4.7-5.0", ou seja, a licença atual pode
ser utilizada entre as versões 4.7 e 5.0. Esta propriedade é somente de leitura.

5.8.3.2 Informações dos Tipos de Licenças


Esta seção contém informações sobre propriedades do objeto Informações dos Tipos de Licenças
(LicenseCounterNode). Este objeto não possui eventos nem métodos associados.

NOTA
A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?Server].License.IoDrivers", é
obrigatória.

Os objetos Informações dos Tipos de Licenças atualmente disponíveis são os seguintes:


· ViewersControl: Licenças de E3 Viewer
· ViewersOnly: Licenças de E3 Viewer Only
· Studios: Licenças de E3 Studio
· IoPoints: Licenças de pontos de entrada e saída
· StorageTags: Licenças de Tags de Storage
· RemoteServers: Licenças de Domínios remotos servidores
· RemoteClients: Licenças de Domínios remotos clientes
· OpcServer: Licenças de servidor OPC
· IoDrivers: Licenças de Drivers para qualquer Driver, ou seja, licenças ilimitadas de Drivers
· IoDriversId<nnn>: Licenças de Drivers, em que nnn é um valor numérico entre 1 (um) e 65535, quando há licenças
para um ID específico de Driver de entrada e saída

5.8.3.2.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações das Licenças (LicenseNode).

5.8.3.2.1.1 IsUnlimited
Indica se o Tipo de Licença atual é ilimitado, ou seja, o valor da propriedade Limit não é usado. Esta propriedade é
somente de leitura.

5.8.3.2.1.2 Limit
Indica o limite de licenças para este Tipo de Licença ou -1 (menos um) se este Tipo de Licença é ilimitado. Esta
propriedade é somente de leitura.

5.8.3.2.1.3 Used
Indica o número total de licenças já consumidas por este Tipo de Licença. Esta propriedade é somente de leitura.

343 Objetos de Servidor


5.8.4 Informações de Servidores Remotos
O objeto Informações de Servidores Remotos (RemoteDomainServerNode) não tem eventos, métodos ou
propriedades específicos associados, somente as propriedades gerais Count, Name e Parent, além do método geral
Item. Também é possível utilizar a declaração For Each em scripts para enumerar os objetos filhos.

NOTAS
A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?
Server].Domain.RemoteDomains", é obrigatória.

5.8.4.1 Informações de um Servidor Remoto


Esta seção contém informações sobre propriedades do objeto Informações de um Servidor Remoto
(RemoteDomainNode). Este objeto não possui eventos nem métodos associados.

NOTA
A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?
Server].Domain.RemoteDomains.Nome_Dominio", é obrigatória.

5.8.4.1.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações de um Servidor Remoto
(RemoteDomainNode).

5.8.4.1.1.1 ActiveServer
Indica o nome do servidor remoto com a conexão ativa, caso a conexão esteja estabelecida, ou uma String vazia se
o servidor remoto não está conectado.

5.8.4.1.1.2 BackupAddress
Indica o endereço do servidor remoto secundário para este Domínio remoto ou uma String vazia se o servidor
secundário está desabilitado.

5.8.4.1.1.3 Connected
Indica se há uma conexão estabelecida no momento com algum servidor remoto, principal ou secundário.

5.8.4.1.1.4 DomainFile
Indica o nome do arquivo de Domínio configurado para este Domínio remoto.

5.8.4.1.1.5 LastError
Mensagem de diagnóstico sobre o motivo da falha de conexão com o servidor principal ou uma String vazia caso
haja uma conexão ativa.

5.8.4.1.1.6 LastErrorBackup
Mensagem de diagnóstico sobre o motivo da falha de conexão com o servidor secundário ou uma String vazia
caso haja uma conexão ativa.

5.8.4.1.1.7 ServerAddress
Indica o endereço do servidor remoto principal para este Domínio remoto ou uma String vazia se o servidor
principal está desabilitado.

5.8.5 Informações do Domínio


Esta seção contém informações sobre métodos e propriedades do objeto Informações do Domínio (DomainNode).
Este objeto não possui eventos associados.

Objetos de Servidor 344


NOTAS
· Este objeto e todos os seus objetos filhos possuem as propriedades gerais Count, Name e Parent, além do
método geral Item. Também é possível utilizar a declaração For Each em scripts para enumerar os objetos filhos.
· A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?Server].Domain", é
obrigatória.

5.8.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Informações do Domínio (DomainNode).

5.8.5.1.1 Refresh
Refresh()
Força a atualização do Domínio atual.

NOTA
· Este método não pode ser utilizado a partir de um Viewer Read-Only.
· Ao utilizar este método pelo E3 Viewer ou pelo Domínio, há uma verificação se o usuário logado tem permissão
para esta ação, de acordo com as configurações do Domínio.

5.8.5.1.2 Stop
Stop()
Para o Domínio em execução.

NOTA
· Este método não pode ser utilizado a partir de um Viewer Read-Only.
· Ao utilizar este método pelo E3 Viewer ou pelo Domínio, há uma verificação se o usuário logado tem permissão
para esta ação, de acordo com as configurações do Domínio.

5.8.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações do Domínio (DomainNode).

5.8.5.2.1 Domain
Nome amigável do Domínio, configurado no item Nome do Domínio do grupo Geral na aba Propriedades da
janela de configurações do Domínio. Esta propriedade é somente de leitura.

5.8.5.2.2 FullPath
Caminho completo do arquivo de Domínio. Esta propriedade é somente de leitura.

5.8.5.2.3 HotStandby
Retorna Verdadeiro se o modo Hot-Standby está habilitado no Domínio. Esta propriedade é somente de leitura.

5.8.5.2.4 State
Indica o estado do Domínio. Os valores possíveis para esta propriedade são -1: Fechado ou sem Domínio, 0:
Parado mas carregado, 1: Em modo Hot-Standby ou 2: Executando. Esta propriedade é somente de leitura.

5.8.5.3 Informações dos Servidores do Domínio


Esta seção contém informações sobre propriedades do objeto Informações dos Servidores do Domínio
(DomainServerNode). Este objeto não possui eventos nem métodos associados.

NOTA
A utilização de colchetes na referência a este objeto em scripts, como por exemplo "[?
Server].Domain.Servers.LocalServer", é obrigatória.

345 Objetos de Servidor


Os objetos Informações dos Servidores do Domínio atualmente disponíveis são LocalServer (Servidor do Domínio
local) e RemoteServer (Servidor do Domínio remoto).

5.8.5.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Informações dos Servidores do Domínio
(DomainServerNode).

5.8.5.3.1.1 Connection
Indica uma mensagem de diagnóstico sobre o estado atual da conexão do servidor local com o servidor remoto.
Corresponde ao texto da coluna Conexão da lista Servidores conectados da janela Monitor do E3 Admin. Esta
propriedade é somente de leitura e só está disponível para o objeto RemoteServer.

5.8.5.3.1.2 Disabled
Configura o servidor como desabilitado ou em manutenção.

NOTA
Ao modificar o valor desta propriedade pelo E3Run, considera-se esta ação sempre permitida e associada ao
usuário System, o mesmo usuário que reconhece alarmes automaticamente. Ao modificar o valor desta propriedade
pelo E3 Viewer ou pelo Domínio, há uma verificação se o usuário logado tem permissão para esta ação, de acordo
com as configurações do Domínio.

5.8.5.3.1.3 DomainState
Indica o estado do Domínio no servidor remoto. Os valores possíveis para esta propriedade são -1: Fechado ou
sem Domínio, 0: Parado mas carregado, 1: Em modo Hot-Standby ou 2: Executando. Normalmente o valor desta
propriedade é o mesmo valor da propriedade State do objeto Informações do Domínio se o outro servidor está com
o mesmo Domínio carregado. Esta propriedade é somente de leitura e só está disponível para o objeto
RemoteServer.

5.8.5.3.1.4 FailuresWeight
Indica o peso total de falhas ativas no servidor ou 0 (zero) para indicar que o servidor está em modo Hot e
apresenta falhas. Esta propriedade é somente de leitura.

5.8.5.3.1.5 IsCandidate
Indica se este servidor está pronto ou não para assumir a execução do Domínio. Esta propriedade é somente de
leitura.

5.8.5.3.1.6 IsIoActive
Indica se há servidores de I/O executando neste servidor. Esta propriedade é somente de leitura.

5.8.5.3.1.7 IsPrioritySet
Indica se este servidor requisitou ou não prioridade de execução, ou seja, se este servidor requisitou ou não
prioridade para ser o servidor ativo. Esta propriedade é somente de leitura.

5.8.5.3.1.8 NetworkAddress
Indica o nome do servidor na rede. Este nome corresponde ao nome de host, não ao endereço IPv4. Esta
propriedade é somente de leitura.

5.8.5.3.1.9 Online
Retorna Verdadeiro se a conexão com o servidor remoto está funcionando. Esta propriedade é somente de leitura
e só está disponível para o objeto RemoteServer.

5.8.5.3.1.10 Ping
Indica se o comando ping realizado do servidor local para o servidor remoto está funcionando ou não, ou seja, se
há resposta. Esta propriedade é somente de leitura e só está disponível para o objeto RemoteServer.

Objetos de Servidor 346


5.8.5.3.1.11 ServerName
Indica o nome ou alias do servidor, conforme a configuração do Domínio. Esta propriedade é somente de leitura.

5.8.5.3.1.12 State
Retorna o estado de execução do Domínio no servidor. Os valores possíveis para esta propriedade são -1:
Fechado ou sem Domínio, 0: Parado mas carregado, 1: Em modo Hot-Standby ou 2: Executando. Esta propriedade é
somente de leitura.

5.9 Objetos em Tempo de Configuração


Esta seção contém informações sobre objetos que só podem ser utilizados em tempo de configuração.

5.9.1 E3StudioApplication
Esta seção contém informações sobre métodos e propriedades do objeto E3StudioApplication. Este objeto não
possui eventos associados.

5.9.1.1 Métodos
Esta seção contém informações sobre os métodos do objeto E3StudioApplication.

NOTA
Os métodos aqui descritos só podem ser utilizados no E3 Studio, não estando disponíveis em tempo de execução.

5.9.1.1.1 CreateFile
CreateFile(ProjectName, ClassName, [FileName], [FolderName], [RunWizard], [OpenView])
Cria um novo objeto em um arquivo de projeto (.prj). Os parâmetros deste método são os seguintes:
· ProjectName: O nome do arquivo de projeto onde o objeto é inserido. Este parâmetro não pode ser vazio, e o
arquivo de projeto deve estar carregado no E3 Studio. Pode ser o caminho completo do arquivo de projeto ou o
caminho relativo ao arquivo de Domínio. Não há necessidade de adicionar a extensão .prj
· ClassName: O nome da classe do objeto que é criado. Veja a tabela a seguir para os valores permitidos neste
parâmetro
· FileName: O nome do objeto inserido. Se este parâmetro é omitido, utiliza o nome padrão para a criação do
objeto de tipo indicado em ClassName. O tamanho máximo permitido para este parâmetro é de 32 caracteres e,
se já existir, é automaticamente incrementado
· FolderName: O nome da Pasta onde o objeto é criado. Se este parâmetro é omitido, o objeto é criado na raiz do
arquivo de projeto. O nome da Pasta deve obedecer às mesmas regras da seção de Notas do método
RenameFolder
· RunWizard: Booleano que indica se o assistente de configuração da classe indicada por ClassName é aberto após
a execução deste método. Se este parâmetro é omitido, o assistente de configuração é aberto
· OpenView: Booleano que indica se o Editor do objeto inserido é aberto após a execução deste método. Se este
parâmetro é omitido, o Editor do objeto é aberto
Valores possíveis para o parâmetro ClassName
OBJETO A SER CRIADO VALOR DO PARÂMETRO
Banco de Dados DB.DBServer

Configuração de Alarmes DB.AlarmConfig

Driver de Comunicação IODrv.IODriver

Driver de Comunicação OPC IODrv.OPCDriver

Driver de Comunicação OPC UA IODrv.UaDriver

Fórmula DB.Formula

Histórico DB.Hist

Quadro Panel.FrameSet

347 Objetos de Servidor


OBJETO A SER CRIADO VALOR DO PARÂMETRO
Relatório Panel.Report

Servidor de Alarmes DB.AlarmServer

Servidor de Dados Panel.DataServer

Storage DB.Historian

Tela Panel.Screen

Viewer Panel.Viewer

5.9.1.1.2 CreateFolder
CreateFolder(ProjectName, FolderName, [ParentFolder])
Cria uma nova Pasta com o nome definido em FolderName, dentro do arquivo de projeto (.prj) ProjectName, e cujo
objeto pai é indicado por ParentFolder. As seguintes restrições se aplicam a este método:
· O arquivo de projeto indicado no parâmetro ProjectName deve existir, e estar aberto no E3 Studio
· Se o parâmetro FolderName é vazio, utiliza-se o nome padrão para criação de Pastas. Por exemplo, "Pasta1"
· O tamanho máximo permitido para o parâmetro FolderName é de 32 caracteres
· Se o nome indicado no parâmetro FolderName já existir, o nome é automaticamente incrementado
· O nome da Pasta em FolderNome deve obedecer às mesmas regras da seção de Notas do método
RenameFolder
· A Pasta indicada no parâmetro ParentFolder deve existir. Se este parâmetro é omitido, a nova Pasta é criada na
raiz do arquivo de projeto

5.9.1.1.3 CreatePRJ
CreatePRJ(Filename)
Cria um novo arquivo de projeto (.prj) com o nome Filename, e o adiciona ao Domínio corrente, se existir. Se o
parâmetro Filename não é um caminho absoluto, utiliza-se um caminho relativo ao Domínio, ou o caminho padrão
para arquivos de projeto (salvo no Registro do Windows). A extensão .prj é adicionada automaticamente, se
necessário.

5.9.1.1.4 DeleteFile
DeleteFile(PRJName, FileName, [Folder])
Apaga um objeto em um arquivo de projeto (.prj). Os parâmetros deste método são os seguintes:
· PRJName: O nome do arquivo de projeto que contém o objeto a ser apagado. Este parâmetro não pode ser
vazio e o arquivo de projeto deve estar carregado no E3 Studio. Pode ser o caminho completo do arquivo de
projeto ou o caminho relativo ao arquivo de Domínio. Não há necessidade de adicionar a extensão .prj
· FileName: O nome do objeto a ser apagado
· Folder: O nome da Pasta onde o objeto deve ser apagado. Se este parâmetro é omitido, o objeto é excluído da
raiz do arquivo de projeto

5.9.1.1.5 ListFiles
ListFiles([FileClass], [Domain])
Retorna uma coleção de objetos de uma determinada classe em um Domínio. Os parâmetros deste método são os
seguintes:
· FileClass: Uma String opcional com o nome da classe do objeto desejado. Se o nome da classe não existir, este
método retorna um erro de script. Se este parâmetro é omitido, retorna uma coleção com todos os objetos do
Domínio especificado. Se o Domínio especificado não contém nenhum objeto da classe informada, este método
retorna uma coleção vazia, ou seja, com zero itens
· Domain: Uma String opcional com o nome de um Domínio remoto. Se este parâmetro é omitido, especifica o
Domínio local. Se o Domínio remoto não existir, este método retorna um erro de script

Objetos de Servidor 348


A coleção retornada por este método contém a propriedade Count, que indica o total de objetos existentes, e o
método Item, que permite acessar um item específico da coleção. Esta coleção também pode ser utilizada com a
declaração For Each do VBScript.

NOTAS
· O método Item da coleção retornada por este método permite o acesso somente pelo índice numérico (iniciando
em um).
· Ao omitir o parâmetro Domain, e portanto retornar uma coleção de objetos no Domínio local, é possível listar
objetos do contexto de visualização, ou seja, E3 Viewers, Telas e Quadros. Nos casos em que o parâmetro
Domain indica um Domínio remoto, os objetos do contexto de visualização daquele Domínio não são retornados
por este método.

5.9.1.1.6 RenameFolder
RenameFolder(OldName, NewName)
Permite renomear uma Pasta em um arquivo de projeto aberto no E3 Studio, pertencente ou não ao Domínio. O
parâmetro OldName é o caminho completo da Pasta que se deseja renomear, e o parâmetro NewName é o novo
nome, sem o caminho.

NOTAS
· Se o caminho completo da Pasta no parâmetro OldName ou o novo nome no parâmetro NewName, começa com
um caractere que não seja uma letra (sem acentos nem "ç"), ou se possui um caractere qualquer que não seja uma
letra (sem acentos nem "ç"), um algarismo (0-9) ou sublinhado, é obrigatório o uso de colchetes no nome.
· Se o parâmetro NewName é inválido, se o parâmetro OldName contém um erro de sintaxe, ou ainda se o caminho
indicado em OldName não foi encontrado em nenhum arquivo de projeto aberto, ocorre um erro de script.
· Arquivos de projeto protegidos por senha devem ser desbloqueados antes da utilização deste método.

5.9.1.1.7 Trace
Trace(MessageText, [LogTimeStamp], [BreakLine])
Este método permite registrar mensagens no log do E3. Este método pode ser usado, por exemplo, para registrar
mensagens de depuração de scripts executados no E3 Studio.
Parâmetros do método Trace
PARÂMETRO DESCRIÇÃO
MessageText Mensagem definida pelo usuário

LogTimeStamp Booleano que indica se cada registro deve ter a data e a


hora (timestamp). Este parâmetro é opcional e é
ignorado no E3 Studio

BreakLine Booleano que indica a presença ou não de uma quebra


de linha ao final de cada mensagem. Este parâmetro é
opcional e é ignorado no E3 Studio

5.9.1.1.8 Verify
Verify(OutputFile, [ObjectLink], [FixQuestionsDefault])
Executa uma verificação de erros no Domínio atual e exporta uma lista de erros encontrados durante esta verificação
para um arquivo no formato CSV (Comma-Separated Values). Os parâmetros deste método são os seguintes:
· OutputFile: Caminho onde deve ser salvo o arquivo com a lista de erros encontrados
· ObjectLink: Caminho para um objeto do Domínio a ser verificado. Se este parâmetro é omitido, a verificação é
realizada em todo o Domínio
· FixQuestionsDefault: Indica como devem ser tratados os erros que podem ser consertados automaticamente
pelo E3 Studio. Os valores possíveis são 0 (zero, padrão), equivalente a responder Não para todos na opção
Verificação de Domínio do E3 Studio, e 1 (um), equivalente a responder Sim para todos na opção Verificação
de Domínio do E3 Studio. Neste caso, os erros corrigidos não são incluídos no arquivo de saída

349 Objetos de Servidor


O arquivo gerado contém as colunas Objeto, Erro, Descrição e Solução. Este método retorna o total de erros
encontrados durante a verificação.

5.9.1.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto E3StudioApplication.

NOTA
As propriedades aqui descritas só podem ser utilizadas no E3 Studio, não estando disponíveis em tempo de
execução.

5.9.1.2.1 ProductString
Esta propriedade contém uma String com o nome do produto e a versão do E3 Studio, como por exemplo "E3
6.1.101" ou "E3 (64-bits) 6.1.101". Esta propriedade é somente de leitura.

5.9.1.2.2 ProductVersionBuild
Esta propriedade contém o número de build da versão do E3 Studio. Por exemplo, se a versão instalada é a 6.1.101,
esta propriedade contém o valor 101. Esta propriedade é somente de leitura.

5.9.1.2.3 ProductVersionMajor
Esta propriedade contém o número principal da versão do E3 Studio. Por exemplo, se a versão instalada é a
6.1.101, esta propriedade contém o valor 6. Esta propriedade é somente de leitura.

5.9.1.2.4 ProductVersionMinor
Esta propriedade contém o número secundário da versão do E3 Studio. Por exemplo, se a versão instalada é a
6.1.101, esta propriedade contém o valor 1. Esta propriedade é somente de leitura.

5.10 Objetos em Tempo de Execução do Servidor


Esta seção contém informações sobre objetos que só podem ser utilizados em tempo de execução, o Servidor
(ServerApplicationE3) e a Pasta de Aplicativo (RuntimeFolder).

5.10.1 Pasta de Aplicativo


O objeto Pasta de Aplicativo (RuntimeFolder) é semelhante ao objeto Pasta de Dados, do objeto Servidor de Dados,
permitindo agrupar objetos do Servidor dentro de pastas. Contudo, existem diferenças importantes:
· O objeto Pasta de Aplicativo só está disponível em tempo de execução
· O objeto possui as propriedades gerais Application, Count, Name, Parent e PathName, além dos métodos
gerais Item e Save
· O objeto permite utilizar a declaração For Each para enumerar seus objetos filhos, mas este acesso leva em conta
apenas os objetos do Servidor, não listando, por exemplo, Telas e Recursos que estejam dentro das Pastas
· A pasta raiz a partir da qual é possível enumerar os objetos é sempre o objeto Servidor

5.10.2 Servidor
Esta seção contém informações sobre métodos e propriedades do objeto Server (ServerApplicationE3). Este objeto
possui os métodos gerais Item e Save, além das propriedades Name e Count, descritos na seção Eventos, Métodos
e Propriedades Gerais dos Objetos. Este objeto não possui eventos associados.

5.10.2.1 Métodos
Esta seção contém informações sobre os métodos do objeto Servidor (ServerApplicationE3).

NOTA
Os métodos aqui descritos só podem ser utilizados em tempo de execução, não estando disponíveis no E3 Studio.

Objetos de Servidor 350


5.10.2.1.1 ClearFailure
ClearFailure(FailureName)
Este método deve ser chamado para indicar que uma falha reportada pelo método ReportFailure não está mais ativa.
O parâmetro FailureName contém o nome da falha (definido pelo usuário) e deve ser passado para o método
ReportFailure quando de sua chamada.

5.10.2.1.2 E3GetActor
E3GetActor()
Este método retorna o nome de logon do usuário que iniciou a requisição atual no E3Run. Se o E3Run não estiver
atualmente tratando uma operação gerada por outro processo, retorna a String "System". Se não houver nenhum
usuário logado no processo que gerou a requisição atual, retorna a String "Anonymous".

5.10.2.1.3 IsUserMemberOfGroup
IsUserMemberOfGroup(GroupName, [UserName])
Este método verifica se um usuário pertence a um determinado grupo. Possui os seguintes parâmetros:
· GroupName: Nome do grupo de usuários que se quer verificar
· UserName: Nome do usuário que se quer verificar. Se este parâmetro é omitido ou é igual a uma String vazia, o
método considera o usuário retornado pelo método E3GetActor

Este método retorna Verdadeiro se o usuário pertencer ao grupo indicado por GroupName ou Falso caso contrário.

5.10.2.1.4 LoadReport
LoadReport(ReportName)
Carrega um modelo de Relatório. Veja o método LoadReport do objeto Viewer para um exemplo de uso.

NOTA
O método PrintPreview do objeto Relatório não está disponível em Relatórios carregados utilizando este método.

5.10.2.1.5 ReportFailure
ReportFailure(FailureName, FailureDescription, FailureWeight)
Este método permite que uma aplicação reporte falhas para o Servidor, que podem ser visualizadas clicando com o
botão direito do mouse no ícone do E3 na Área de Notificações do Windows. Quando este método é usado, o ícone
do E3 na Área de Notificações do Windows começa a piscar em vermelho, indicando a ocorrência da falha. As falhas
reportadas são normalmente condições que impedem que a aplicação funcione parcialmente (problema de
comunicação em uma porta serial, link de rede inativo, banco de dados sem conexão, etc.), e que normalmente não
podem ser detectadas pelo Servidor. Este método tem duas finalidades:
· Avisar o operador do sistema a respeito de problemas em um servidor
· Auxiliar o gerenciador automático de Hot-Standby a decidir qual servidor está mais apto para executar a
aplicação

NOTA
O método ReportFailure só está disponível no Servidor.

O método ReportFailure possui os parâmetros descritos na tabela a seguir.


Parâmetros do método ReportFailure
NOME DESCRIÇÃO
FailureName Contém o nome da falha (definido pelo usuário). Este
mesmo parâmetro deve ser passado para o método
ClearFailure quando a aplicação detectar que a falha
não está mais ativa. Por exemplo, "Falha COM1"

351 Objetos de Servidor


NOME DESCRIÇÃO
FailureDescription Descrição textual da falha (definida pelo usuário). Por
exemplo, "Falha de comunicação na porta COM1"

FailureWeight Define a severidade (ou peso) da falha. O valor 0 (zero)


indica um aviso (sem gravidade). Valores maiores que
zero indicam falhas. Quanto maior o valor, mais grave é
a falha

Exemplo:
Sub TagEstadoSerial_OnValueChanged()
If Value then
' O valor do Tag é True, indica que está em falha
Application.ReportFailure "FALHA_COM1", "Falha de "_
& "comunicação na COM1", 100
Else
' O valor do Tag é False, limpa a falha
' (indica que está OK)
Application.ClearFailure "FALHA_COM1"
End If
End Sub

5.10.2.1.6 Trace
Trace(MessageText, [LogTimeStamp], [BreakLine])
Este método permite registrar mensagens em um arquivo texto. As mensagens são gravadas em um arquivo com o
mesmo nome e caminho do arquivo de Domínio e com a extensão .txt. Cada nova mensagem é adicionada sempre ao
final deste arquivo. Caso haja falha no registro do arquivo (como por exemplo, direito de acesso negado, falta de
espaço em disco, etc.), ocorre um erro de script. Adicionalmente, esta mensagem é registrada no log do E3. Este
método pode ser usado, por exemplo, para registrar mensagens de depuração de scripts executados no servidor.
Parâmetros do método Trace
PARÂMETRO DESCRIÇÃO
MessageText Mensagem definida pelo usuário

LogTimeStamp Booleano que indica se cada registro deve ter a data e a


hora (timestamp). Este parâmetro é opcional e, se
omitido, assume o valor Verdadeiro

BreakLine Booleano que indica a presença ou não de uma quebra


de linha ao final de cada mensagem. Em Falso, força com
que o arquivo tenha todos os registros em uma só linha.
Este parâmetro é opcional e, se omitido, assume o valor
Verdadeiro

5.10.2.1.7 TrackEvent
TrackEvent(EventMessage, [EventComment], [EventTimestamp])
O método TrackEvent permite gerar eventos via script manualmente. Veja o método TrackEvent do objeto Viewer
para mais informações.

5.10.2.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Servidor (ServerApplicationE3).

NOTA
As propriedades aqui descritas só podem ser utilizadas em tempo de execução, não estando disponíveis no E3
Studio.

5.10.2.2.1 ProductString
Esta propriedade contém uma String com o nome do produto e a versão do Servidor, como por exemplo "E3
6.1.101" ou "E3 (64-bits) 6.1.101". Esta propriedade é somente de leitura.

Objetos de Servidor 352


5.10.2.2.2 ProductVersionBuild
Esta propriedade contém o número de build da versão do Servidor. Por exemplo, se a versão instalada é a 6.1.101,
esta propriedade contém o valor 101. Esta propriedade é somente de leitura.

5.10.2.2.3 ProductVersionMajor
Esta propriedade contém o número principal da versão do Servidor. Por exemplo, se a versão instalada é a 6.1.101,
esta propriedade contém o valor 6. Esta propriedade é somente de leitura.

5.10.2.2.4 ProductVersionMinor
Esta propriedade contém o número secundário da versão do Servidor. Por exemplo, se a versão instalada é a
6.1.101, esta propriedade contém o valor 1. Esta propriedade é somente de leitura.

5.11 Servidor de Dados


Esta seção contém informações sobre eventos, métodos e propriedades dos objetos Consulta, Filtro de Alarmes,
Impressora de Linha, Pasta de Dados, Tag Contador, Tag Demo, Tag Interno e Tag Timer.

5.11.1 Consulta
Esta seção contém informações sobre eventos, métodos e propriedades do objeto Consulta (E3Query).

5.11.1.1 Eventos
Esta seção contém informações sobre os eventos do objeto Consulta (E3Query).

5.11.1.1.1 OnAsyncQueryFinish
OnAsyncQueryFinish(Recordset, Error)
Ocorre no retorno do método GetAsyncADORecordset. O parâmetro Recordset é um objeto ADO Recordset gerado
pela Consulta e o parâmetro Error é um Booleano que, quando verdadeiro, mostra que não foi possível gerar o
objeto. Exemplo:
Sub Consulta1_OnAsyncQueryFinish(Recordset, Error)
MsgBox "Retornou " + CStr(Recordset.RecordCount) + " registros"
End Sub

5.11.1.2 Métodos
Esta seção contém informações sobre os métodos do objeto Consulta (E3Query).

5.11.1.2.1 AddField
AddField(Name, [Table])
O método AddField adiciona um novo campo da tabela na Consulta. O parâmetro Name determina o nome do novo
campo que é adicionado à Consulta. O parâmetro Table determina o nome da tabela a que o campo pertence.
Exemplo:
Sub Botao1_Click()
Screen.Item("E3Browser").Item("Consulta").AddField "Campo1"
End Sub

NOTAS
· Este método falha se a propriedade QueryType estiver configurada para o valor 1 - qtStorage.
· Se o parâmetro Table é omitido, o objeto Consulta tenta inserir o campo informado no parâmetro Name na
primeira tabela encontrada no banco de dados.

5.11.1.2.2 AddStorageTag
AddStorageTag(Name, FieldType)
Adiciona um Tag pertencente ao Storage à Consulta. O parâmetro Name recebe o nome do Tag a ser adicionado. O
parâmetro FieldType indica o tipo deste Tag (0: Double, 1: Bit, 2: String, 3: Integer). Retorna um Booleano indicando
o sucesso (ou não) da operação.

353 Objetos de Servidor


NOTA
Este método falha se a propriedade QueryType estiver configurada para o valor 0 - qtDBServer.

5.11.1.2.3 AddTable
AddTable(Name)
Adiciona uma tabela do banco de dados na Consulta. O parâmetro Table determina o nome da tabela a ser
adicionada.

NOTA
Este método falha se a propriedade QueryType estiver configurada para o valor 1 - qtStorage.

5.11.1.2.4 AddUaField
AddUaField(Name, [Alias], [Aggregate])
Este método adiciona, em tempo de execução, um campo a uma consulta configurada para o tipo OPC UA. O método
retorna Verdadeiro se for bem sucedido e Falso se houver falha. Os parâmetros deste método são os seguintes:
· Name: Uma String com o caminho (Coluna) do campo
· Alias: Uma String com o título do campo. Se este parâmetro é omitido, assume uma String vazia
· Aggregate: Uma String com o tipo de função de agregação do campo, caso seja usada uma consulta do tipo
Dados Processados. Se este parâmetro é omitido, assume o valor Interpolative

Em uma consulta de tipo Dados Brutos (propriedade UaQueryType com valor igual a zero), este método falha se já
houver um campo definido. Este método só tem efeito se a propriedade QueryType estiver configurada para OPC UA
(valor igual a 2 - qtOpcUa). Do contrário, retorna Falso.

5.11.1.2.5 Execute
Execute([ImmediateExecute])
O método Execute executa um comando SQL que não tenha retorno (como DELETE, UPDATE ou INSERT),
configurado na propriedade SQL da Consulta. O parâmetro ImmediateExecute indica se a operação passa pelas filas
de operações (arquivos .e3i e .e3o) antes de chegar ao Banco de Dados (caso esteja configurada como Falso) ou se é
enviada diretamente para o Banco de Dados (caso esteja configurada como Verdadeiro). Se este parâmetro é
omitido, a operação é enviada diretamente para o Banco de Dados. A vantagem de se utilizar a Consulta para
executar comandos é a utilização de variáveis, como em uma consulta simples. Exemplo de comandos SQL:
DELETE FROM teste WHERE cod > 10
UPDATE teste SET cod = 10 WHERE cod > 10
INSERT INTO teste(cod) VALUES(10)

Exemplo:
Sub CommandButton1_Click()
Screen.Item("Consulta1").Execute
End Sub

5.11.1.2.6 GetADORecordSet
GetADORecordSet()
O método GetADORecordSet retorna um Recordset do tipo ADO (ActiveX Data Object), resultante da execução da
Consulta configurada. Exemplo:
Sub Botao1_Click()
Set rec = Screen.Item("Consulta1").GetADORecordset()
strDatas = " "
i = 0

' Mostra uma mensagem com os 10 primeiros


' registros da coluna E3TimeStamp
While (NOT rec.EOF AND i < 10)
strDatas = strDatas & CStr(rec.Fields.Item("E3TimeStamp").Value) & _
Chr(10) & Chr(13)
i = i + 1
rec.MoveNext()
Wend

Objetos de Servidor 354


MsgBox strDatas
End Sub

NOTA
Para maiores informações sobre o objeto ADORecordset retornado por este método, consulte a documentação da
Microsoft no link http://msdn.microsoft.com/en-us/library/ms675841(VS.85).aspx (somente em inglês).

5.11.1.2.7 GetAsyncADORecordSet
GetAsyncADORecordSet()
Cria uma Consulta e, quando ela estiver finalizada, gera o evento OnAsyncQueryFinish do próprio objeto, passando
para este evento o resultado (Recordset) gerado pela Consulta.

5.11.1.2.8 GetE3QueryFields
GetE3QueryFields()
O método GetE3QueryFields retorna a Coleção de Campos (colunas) de uma Consulta. Cada item desta Coleção
possui propriedades que podem ser modificadas, conforme descrito no tópico Campo da Consulta. Exemplo:
Sub Botao1_Click()
' Percorre a coleção de Campos,
' mostrando-os em uma caixa de mensagem
' e ajustando-os como visíveis
' na configuração da Consulta.

Set Browser = Screen.Item("E3Browser")


Set Consulta = Browser.Item("Consulta")
Set Campos = Consulta.GetE3QueryFields()
For Each campo In Campos
MsgBox CStr(campo.TableName) & "-" & CStr(campo.ColumnName)
campo.Visible = True
Next
' Refaz a Consulta do E3Browser, que acabou de ser
' modificada, para que todos os campos apareçam.
Browser.RetrieveE3QueryFields()
Browser.Requery()
End Sub

NOTA
Para usar este método, a Consulta deve ser previamente criada em tempo de configuração.

5.11.1.2.9 RemoveField
RemoveField(FieldName, [Table])
O método RemoveField remove um campo previamente incluído em uma Consulta. O parâmetro FieldName determina
o nome do campo a ser removido. O parâmetro Table determina o nome da tabela a qual o campo pertence.
Exemplo:
Sub CommandButton1_Click()
Screen.Item("E3Browser").Item("Consulta")._
RemoveField "Campo1"
End Sub

NOTA
Se o parâmetro Table é omitido, o objeto Consulta tenta remover o campo informado no parâmetro Name na
primeira tabela encontrada no banco de dados.

5.11.1.2.10 RemoveStorageTag
RemoveStorageTag(Name)
Remove um Tag previamente configurado na Consulta. O parâmetro Name indica o nome do Tag. Retorna um
Booleano indicando o sucesso ou não da operação.

355 Objetos de Servidor


NOTA
Este método falha se a propriedade QueryType estiver configurada para o valor 0 - qtDBServer.

5.11.1.2.11 RemoveTable
RemoveTable(TableName)
Remove uma tabela da Consulta. O parâmetro TableName determina o nome da tabela a ser removida.

NOTA
Este método falha se a propriedade QueryType estiver configurada para o valor 1 - qtStorage.

5.11.1.2.12 RemoveUaField
RemoveUaField(Name)
Este método remove o campo com o nome especificado, se existir. O parâmetro Name é uma String com o nome
(Coluna) do campo. O método retorna Verdadeiro se for bem sucedido e Falso se houver falha. Este método só tem
efeito se a propriedade QueryType estiver configurada para OPC UA (valor igual a 2 - qtOpcUa). Do contrário,
retorna Falso.

5.11.1.2.13 SetVariableValue
SetVariableValue(VarName, Value)
O método SetVariableValue ajusta o valor de uma variável configurada na Consulta, de forma que este valor possa
ser informado como um filtro ou parâmetro antes de a Consulta ser realizada. Deve ser definido o nome da variável
(VarName) e seu valor (Value), que pode ser um número, um texto ou uma data e hora. Exemplo:
Sub CommandButton_Click()
Set cons = Screen.Item("E3Browser1").Item("Consulta1")
DataInicial = Now - 1
DataFinal = Now
cons.SetVariableValue "DataIni", DataInicial
cons.SetVariableValue "DataFim", DataFinal
End Sub

5.11.1.3 Propriedades
Esta seção contém informações sobre as propriedades do objeto Consulta (E3Query).

NOTA
Não é recomendável o acesso direto destas propriedades via scripts. O ideal é acessar o objeto Consulta, passando
parâmetros através do método SetVariableValue e modificando filtros ou campos através da coleção retornada
com o método GetE3QueryFields.

5.11.1.3.1 CursorLocation
Define o local onde a Consulta é gerada e manipulada, sob o ponto de vista do SGBD (Sistema Gerenciador do
Banco de Dados). As opções disponíveis são as seguintes:
· 0 - clServer: A Consulta é gerada no SGBD (servidor)
· 1 - clClient: A Consulta é gerada no Servidor (cliente, padrão)

Veja também a propriedade CursorType.

NOTA
Esta propriedade não tem efeito para Bancos de Dados em que a propriedade SourceType seja igual a 0 - stAccess,
pois neste caso é sempre o Servidor que gera e manipula a Consulta. Entretanto, para SourceType igual a 1 -
stOracle ou 2 - stSqlServer, aconselha-se utilizar a opção 1 - clClient. Para maiores informações, consulte a
documentação da propriedade CursorLocation e da enumeração CursorLocationEnum do objeto ADO (ActiveX
Data Object).

Objetos de Servidor 356


5.11.1.3.2 CursorType
Define o tipo de Consulta de acordo com a visualização dos dados. O valor padrão desta propriedade é 0 -
ctKeyset. Todas as opções disponíveis estão na tabela a seguir.
Opções disponíveis para CursorType
OPÇÃO DESCRIÇÃO
0 - ctKeyset Qualquer mudança nos registros inicialmente retornados
pela Consulta é visível (padrão)

1 - ctStatic Nenhuma mudança nos registros inicialmente retornados


pela Consulta é visível

2 - ctDynamic Todos os novos registros adicionados na Consulta são


visíveis, além das mudanças nos registros inicialmente
retornados pela Consulta

5.11.1.3.3 DataSource
Indica o objeto Banco de Dados, Storage ou Driver de Comunicação OPC UA que é usado na Consulta.

5.11.1.3.4 Fields
Texto com os campos a serem visualizados na Consulta, separados por vírgula. Corresponde ao argumento da
cláusula SELECT do código SQL da Consulta. Em branco (vazio), determina que a Consulta deve mostrar todos os
campos da tabela.

5.11.1.3.5 FunctionSubType
Especifica o subtipo da função indicada por FunctionType. Apenas as opções 1 - ftArchivedValue, 2 -
ftTagAttribute e 6 - ftCalculatedData possuem subtipos. Para as outras funções, FunctionSubType assume o valor -
1 - fsNoSubType. A tabela a seguir mostra os possíveis valores da propriedade, de acordo com a função selecionada
na propriedade FunctionType.
Subtipos para função ArchivedValue (FunctionType igual a 1)
SUBTIPO DESCRIÇÃO
0 - fsPreviousArchivedValue Valor armazenado imediatamente anterior ao timestamp
fornecido

1 - fsInterpolatedArchivedValue Valor calculado a partir do valor anterior e posterior

2 - fsNextArchivedValue Valor armazenado imediatamente posterior ao timestamp

3 - fsExactArchivedValue Se um valor armazenado é encontrado no exato instante


foi fornecido pelo timestamp

Subtipos para função TagAttribute (FunctionType igual a 2)


SUBTIPO DESCRIÇÃO
0 - fsTagAttributeDescription Significado ou descrição do Tag

1 - fsTagAttributeSource Caminho do Tag que está sendo armazenado

2 - fsTagAttributeType Tipo de dados: Double, Boolean ou String

3 - fsTagAttributeEU Unidade de engenharia

4 - fsTagAttributeLowEng Limite inferior

5 - fsTagAttributeHighEng Limite superior

6 - fsTagAttributeDeadBand Banda morta para gravação

7 - fsTagAttributeDeadBandUnit Unidade da banda morta (valor absoluto ou


porcentagem)

8 - fsTagAttributeMinRecTime Tempo mínimo para gravação (variações menores que


este intervalo são desprezadas)

357 Objetos de Servidor


SUBTIPO DESCRIÇÃO
9 - fsTagAttributeMaxRecTime Tempo máximo para gravação (a ausência de variação
nestes intervalos força uma gravação)

Subtipos para função CalculatedData (FunctionType igual a 6)


SUBTIPO DESCRIÇÃO
0 - fsTotalCalculatedData Total dos valores

1 - fsMinimumCalculatedData Valor mínimo

2 - fsMaximumCalculatedData Valor máximo

3 - fsStandardCalculatedData Desvio padrão

4 - fsRangeCalculatedData Amplitude dos valores

5 - fsMeanCalculatedData Média dos valores

6 - fsMedianCalculatedData Mediana dos valores

5.11.1.3.6 FunctionType
Esta propriedade é válida quando um objeto Storage é fonte da Consulta (isto é indicado pela propriedade
DataSource). Ela especifica a função que define os dados gerados pela Consulta. Algumas funções possuem
subfunções, que podem ser indicadas na propriedade FunctionSubType. A propriedade FunctionType pode assumir
os valores descritos na tabela a seguir.
Opções disponíveis para FunctionType
OPÇÃO DESCRIÇÃO
-1 - ftNoFunction Não há nenhuma função definida (padrão). Este valor
não está disponível quando a propriedade QueryType
está configurada para o valor 1 - qtStorage

0 - ftLastValue Retorna o último valor armazenado no banco de dados

1 - ftArchivedValue Retorna um valor armazenado em relação a um


determinado instante de tempo definido na variável
TimeStamp. O tipo de relação é definido na
propriedade FunctionSubType

2 - ftTagAttribute Devolve um atributo do Tag, definido na propriedade


FunctionSubType

3 - ftCompressedDataNValues Retorna, para um único Tag, N valores definidos na


variável NumVals, armazenados a partir de um instante
inicial definido na variável StartTime

4 - ftCompressedDataStartEndTime Retorna, para um único Tag, os valores armazenados


que estão entre o intervalo definido pelas variáveis
StartTime e EndTime

5 - ftSampledData Retorna, para um ou mais Tags, os valores interpolados,


ou seja, estimados entre os instantes definidos pelas
variáveis StartTime e EndTime, a intervalos fixos
definidos pela variável TimeInterval

6 - ftCalculatedData Retorna, para um ou mais Tags, o resultado de


operações matemáticas aplicadas aos dados entre os
instantes definidos pelas variáveis StartTime e EndTime,
a intervalos fixos definidos pela variável TimeInterval

NOTA
As variáveis também podem ser definidas em tempo de execução a partir da chamada do método SetVariableValue
da Consulta.

Objetos de Servidor 358


5.11.1.3.7 GroupBy
Texto correspondente ao argumento da cláusula GROUP BY do código SQL da Consulta.

5.11.1.3.8 Having
Texto correspondente ao argumento da cláusula HAVING do código SQL da Consulta. Esta propriedade é
normalmente utilizada com a propriedade GroupBy.

5.11.1.3.9 IgnoreQuality
Permite indicar se os dados com qualidade ruim são incluídos ou não no resultado da Consulta. Esta propriedade
só tem efeito se o objeto Consulta estiver utilizando um objeto Storage como fonte de dados.

5.11.1.3.10 OrderBy
Texto correspondente ao argumento da cláusula ORDER BY do código SQL da Consulta.

5.11.1.3.11 QueryType
Indica o tipo de consulta a ser realizada. Os valores possíveis para esta propriedade são os seguintes:
· -1 - qtUndefined: O objeto Consulta inicialmente tenta executar a consulta em um objeto Banco de Dados. Se
falhar, tenta executá-la em um objeto Storage. Este é o valor padrão para Consultas criadas no E3 Studio ou em
tempo de execução
· 0 - qtDBServer: O objeto Consulta tenta executar a consulta somente em um objeto Banco de Dados
· 1 - qtStorage: O objeto Consulta tenta executar a consulta somente em um objeto Storage
· 2 - qtOpcUa: O objeto Consulta tenta executar a consulta somente em um objeto Driver de Comunicação OPC UA

NOTAS
· No caso de manipulação de Consultas em tempo de execução, recomenda-se configurar esta propriedade para o
tipo desejado antes de efetuar as demais configurações do objeto, especialmente no caso de reutilização de um
objeto Consulta para diferentes fontes de dados.
· Para aplicações criadas em versões anteriores, ao abrir a aplicação no E3 Studio esta propriedade é
automaticamente configurada para -1 - qtUndefined.
· Os métodos AddStorageTag e RemoveStorageTag falham se esta propriedade estiver configurada para 0 -
qtDBServer.
· A propriedade FunctionType não aceita o valor -1 - ftNoFunction se esta propriedade estiver configurada para o
valor 1 - qtStorage.
· Os métodos AddField, AddTable e RemoveTable falham se esta propriedade estiver configurada para o valor 1 -
qtStorage.
· Se esta propriedade estiver configurada para -1 - qtUndefined, a tentativa de executar a Consulta em um objeto
Storage (ao falhar a Consulta em um objeto Banco de Dados) falha se a propriedade FunctionType estiver
configurada para -1 - ftNoFunction ou se a propriedade FunctionSubType estiver configurada para um valor
inválido.

5.11.1.3.12 SQL
Contém o código SQL especificado para a Consulta.

5.11.1.3.13 Table
A propriedade Table contém as tabelas que são consultadas (por exemplo, Alarms é a tabela de alarmes ou
eventos). Corresponde ao argumento da cláusula FROM do código SQL da Consulta.

5.11.1.3.14 UaNamespaceArray
Esta propriedade retorna um objeto que é uma Coleção de Namespaces OPC UA, usada pelos campos
configurados na Consulta. Esta propriedade é somente de leitura.

359 Objetos de Servidor


5.11.1.3.15 UaQueryType
Esta é uma propriedade de leitura e escrita que permite determinar se a Consulta é do tipo Dados Brutos (0 -
uqtRaw) ou do tipo Dados Processados (1 - uqtProcessed, padrão). No E3 Studio esta propriedade é somente de
leitura. Em tempo de execução ela permite configurar o tipo da consulta OPC UA, mas só aceita escritas se a
propriedade QueryType estiver configurada para OPC UA (valor igual a 2 - qtOpcUa).

5.11.1.3.16 Where
Determina a condição da Consulta que filtra os registros da tabela a serem visualizados, ou seja, só são visualizados
os registros que satisfizerem a condição. Corresponde à cláusula WHERE do código SQL da Consulta.

5.11.1.4 Coleção de Campos


Esta seção contém informações sobre métodos e as propriedades do objeto Coleção de Campos da Consulta
(E3QueryCollection). Este objeto não possui eventos associados.

5.11.1.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Campos da Consulta (E3QueryCollection).

5.11.1.4.1.1 Add
Add(NewItem)
Adiciona um novo objeto Campo da Consulta na Coleção de Campos de uma Consulta, indicado pelo parâmetro
NewItem.

5.11.1.4.1.2 Item
Item(Index)
Retorna um objeto Campo da Consulta da Coleção de Campos. O parâmetro Index pode ser o índice númerico deste
Campo ou seu nome.

5.11.1.4.1.3 RefreshUaNodeIds
RefreshUaNodeIds()
Atualiza todos os Campos da Consulta, buscando os Identificadores de Nós OPC UA (NodeIds) no servidor e
atualizando a propriedade UaNodeId dos Campos da Consulta. Para que este método funcione, as seguintes
condições devem ser atendidas:
· A propriedade QueryType da Consulta deve estar configurada para 2 - qtOpcUa
· A Consulta deve apontar para um Driver de Comunicação OPC UA válido
· O Driver de Comunicação OPC UA configurado na Consulta deve estar ativo e conectado

5.11.1.4.1.4 Remove
Remove(Index)
Remove um objeto Campo da Consulta da Coleção de Campos de uma Consulta. O parâmetro Index pode ser tanto
uma String com o nome do Campo da Consulta quanto o índice deste objeto na Coleção de Campos.

5.11.1.4.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Campos da Consulta
(E3QueryCollection).

5.11.1.4.2.1 Count
Retorna o número de objetos Campo da Consulta nesta Coleção. Esta propriedade é somente de leitura.

5.11.1.4.3 Campo da Consulta


Esta seção contém informações sobre as propriedades do objeto propriedades do objeto Campo da Consulta
(E3QueryField). As propriedades disponíveis nesta seção são as seguintes:

Objetos de Servidor 360


5.11.1.4.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo da Consulta (E3QueryField).
Alias
Apelido do Campo na Consulta.
ColumnName
Nome da coluna. Este nome deve existir nas tabelas adicionadas nesta Consulta.
Criteria
Filtro que é aplicado sobre o Campo.
Function
Função para a qual o Campo pode ser passado como parâmetro.
GroupBy
Em Verdadeiro, indica que o Campo faz parte de um agrupamento.
OrderBy
Ordenação dos dados do Campo. Os valores válidos são "ASC" (ordenação ascendente), "DESC" (ordenação
descendente) ou uma String vazia (sem ordenação). Qualquer valor diferente significa que o Campo não possui
ordenação.
OrderNumber
Número de ordem do Campo em relação aos outros Campos que compõem a ordenação da Consulta. Este valor só
é aceito como maior que 0 (zero) se o Campo tiver um tipo de ordenação (definido na propriedade OrderBy). Este
valor tem que ser menor ou igual ao número de Campos que compõem a ordenação da Consulta.
TableName
Nome da tabela a que pertence o Campo. Esta tabela deve ter sido adicionada na configuração da Consulta.
UaNodeId
Retorna um objeto do tipo Identificador de Nó OPC UA, com a configuração do Nó que identifica um campo de
uma consulta OPC UA em um determinado servidor OPC UA. No E3 Studio esta propriedade é apenas representada
por um ícone, na coluna Id da configuração de campos da Consulta. Esta propriedade é somente de leitura.
Visible
Em Verdadeiro, indica que o Campo está visível.

5.11.1.5 Coleção de Namespaces OPC UA


Esta seção contém informações sobre métodos e propriedades do objeto Coleção de Namespaces OPC UA
(UaNamespaceArray). Este objeto não possui eventos associados.

5.11.1.5.1 Métodos
Esta seção contém informações sobre os métodos do objeto Coleção de Namespaces OPC UA (UaNamespaceArray).

5.11.1.5.1.1 Add
Add(Item)
Adiciona um identificador de Namespace, sempre ao final da Coleção. O parâmetro Item é uma String que define o
Namespace. Este parâmetro não pode ser vazio.

5.11.1.5.1.2 Item
Item(Index)
Retorna o identificador de Namespace do índice especificado. O parâmetro Index deve ser um LONG variando entre 0
(zero) e Count menos 1 (um).

361 Objetos de Servidor


5.11.1.5.1.3 Remove

Remove(Index)
Remove o Namespace do índice especificado. Note que isto implica em mudar os índices dos Namespaces de índice
superior ao removido. Não é possível remover os índices 0 (zero) e 1 (um). O parâmetro Index é um valor (LONG) que
identifica o Namespace que se deseja remover da Coleção, variando entre 2 (dois) e Count menos 1 (um).

5.11.1.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Coleção de Namespaces OPC UA
(UaNamespaceArray).

5.11.1.5.2.1 Count
Retorna o número de Namespaces da coleção. O valor mínimo desta propriedade é sempre 2 (dois), já que os
índices 0 (zero) e 1 (um) estão sempre presentes. Esta propriedade é somente de leitura.

5.11.1.5.3 Identificador de Nó OPC UA


Esta seção contém informações sobre propriedades do objeto Identificador de Nó OPC UA (E3UaNodeId). Este objeto
não possui eventos nem métodos associados.

5.11.1.5.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Identificador de Nó OPC UA (E3UaNodeId).
GUID
Propriedade de leitura e escrita que identifica este objeto, caso a propriedade Type seja igual a 2 - nitGUID. Se a
propriedade Type for diferente de 2 (dois), a leitura desta propriedade retorna erro. Já a escrita nesta propriedade
força sempre com que a propriedade Type seja modificada para 2 (dois). O valor desta propriedade é uma String do
tipo GUID (Globally Unique Identifier, ou Identificador Único Global), um valor de 128 bits. Caso esta propriedade seja
configurada com o valor "{00000000-0000-0000-0000-000000000000}", este objeto é identificado como Null.
NamespaceIndex
Propriedade de leitura e escrita que identifica a qual Namespace se refere este Identificador. Este índice deve estar
entre 0 (zero) e o número de Namespaces menos 1 (um) que o servidor possuir. No caso da definição do campo na
Consulta, o índice se refere à Coleção de Namespaces OPC UA definida no objeto Consulta (que em um dado
momento pode ser diferente da Coleção de Namespaces do servidor). Seu valor nunca pode ser maior que 65535,
pois o padrão OPC UA define que este é um valor de 16 bits.
Numeric
Propriedade de leitura e escrita que identifica este objeto, caso a propriedade Type seja igual a 0 - nitNumeric. Se
a propriedade Type for diferente de 0 (zero), a leitura desta propriedade retorna erro. Já a escrita nesta propriedade
força sempre com que a propriedade Type seja modificada para 0 (zero). Um valor 0 (zero) nesta propriedade
identifica este objeto como Null.
Opaque
Propriedade de leitura e escrita que identifica este objeto, caso a propriedade Type seja igual a 3 - nitOpaque. O
valor desta propriedade é um vetor de bytes, ou seja, uma String de caracteres não necessariamente válidos ou
imprimíveis. Se a propriedade Type for diferente de 3 (três), a leitura desta propriedade retorna erro. Já a escrita
nesta propriedade força sempre com que a propriedade Type seja modificada para 3 (três). Uma String vazia nesta
propriedade identifica este objeto como Null.
String
Propriedade de leitura e escrita que identifica este objeto, caso a propriedade Type seja igual a 1 - nitString. Se a
propriedade Type for diferente de 1 (um), a leitura desta propriedade retorna erro. Já a escrita na propriedade força
sempre com que a propriedade Type seja modificada para 1 (um). Uma String vazia nesta propriedade identifica este
objeto como Null.
Type
Propriedade de leitura e escrita que determina qual o tipo de identificador este objeto utiliza. Os valores possíveis
para esta propriedade são os seguintes:
· 0 - nitNumeric: O identificador é um número (LONG)
· 1 - nitString: O identificador é uma String

Objetos de Servidor 362


· 2 - nitGUID: O identificador é uma String do tipo GUID (Globally Unique Identifier)
· 3 - nitOpaque: O identificador é um vetor de bytes

Sempre que esta propriedade é modificada, o valor do identificador é forçado para Null.

5.11.2 Filtro de Alarmes


Esta seção contém informações sobre métodos e as propriedades do objeto Filtro de Alarmes (AlarmFilter). Este
objeto não possui eventos associados.

5.11.2.1 Métodos
Esta seção contém informações sobre os métodos do objeto Filtro de Alarmes (AlarmFilter).

5.11.2.1.1 GetEventByIndex
GetEventByIndex(Index)
Retorna um objeto Evento de uma Coleção de Eventos, especificado pelo parâmetro Index, que corresponde ao
índice do objeto na Coleção. Para mais informações sobre as propriedades do objeto retornado por este método,
consulte o tópico Evento - Propriedades. Exemplo de script para este método:
Sub CommandButton_Click()
For i = 0 To Screen.Item("FiltroAlarmes1").AlarmCount - 1
str = ""
set evt = Screen.Item("FiltroAlarmes1").GetEventByIndex(i)
str = str & "AlarmSourceName = " &_
evt.AlarmSourceName & Chr(13)
str = str & "FullAlarmSourceName = " &_
evt.FullAlarmSourceName & Chr(13)
str = str & "EventTime = " &_
evt.EventTime & Chr(13)
str = str & "EventTimeUTC = " &_
evt.EventTimeUTC & Chr(13)
str = str & "InTime = " &_
evt.InTime & Chr(13)
str = str & "OutTime = " &_
evt.OutTime & Chr(13)
str = str & "AckTime = " &_
evt.AckTime & Chr(13)
str = str & "CurrentValue = " &_
evt.CurrentValue & Chr(13)
str = str & "ActorID = " &_
evt.ActorID & Chr(13)
str = str & "Area = " &_
evt.Area & Chr(13)
str = str & "ConditionName = " &_
evt.ConditionName & Chr(13)
str = str & "EventCategory = " &_
evt.EventCategory & Chr(13)
str = str & "EventType = " &_
evt.EventType & Chr(13)
str = str & "Message = " &_
evt.Message & Chr(13)
str = str & "Quality = " &_
evt.Quality & Chr(13)
str = str & "Source = " &_
evt.Source & Chr(13)
str = str & "SubConditionName = " &_
evt.SubConditionName & Chr(13)
str = str & "FormattedValue = " &_
evt.FormattedValue & Chr(13)
str = str & "UserField(1) = " &_
evt.UserField(1) & Chr(13)
str = str & "UserField(2) = " &_
evt.UserField(2) & Chr(13)
str = str & "UserField(3) = " &_
evt.UserField(3) & Chr(13)
str = str & "UserField(4) = " &_
evt.UserField(4) & Chr(13)
str = str & "Severity = " &_
evt.Severity & Chr(13)
str = str & "Acked = " &_
363 Objetos de Servidor
evt.Acked & Chr(13)
str = str & "AckRequired = " &_
evt.AckRequired & Chr(13)
str = str & "ConditionActive = " &_
evt.ConditionActive & Chr(13)
str = str & "Enabled = " &_
evt.Enabled & Chr(13)
str = str & "EventCLSID = " &_
evt.EventCLSID & Chr(13)
MsgBox str
Next
End Sub

5.11.2.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Filtro de Alarmes (AlarmFilter).

5.11.2.2.1 ActiveAlarms
Determina o número de alarmes ativos em um Filtro de Alarmes. Esta propriedade é somente de leitura.

5.11.2.2.2 ActiveCritAlarms
Indica o número de alarmes ativos com severidade Crítica em um Filtro de Alarmes. Esta propriedade é somente de
leitura.

5.11.2.2.3 ActiveCritNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Crítica em um Filtro de Alarmes. Esta propriedade é
somente de leitura.

5.11.2.2.4 ActiveHighAlarms
Indica o número de alarmes ativos com severidade Alta em um Filtro de Alarmes. Esta propriedade é somente de
leitura.

5.11.2.2.5 ActiveHighNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Alta em um Filtro de Alarmes. Esta propriedade é
somente de leitura.

5.11.2.2.6 ActiveLowAlarms
Indica o número de alarmes ativos com severidade Baixa em um Filtro de Alarmes. Esta propriedade é somente de
leitura.

5.11.2.2.7 ActiveLowNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Baixa em um Filtro de Alarmes. Esta propriedade é
somente de leitura.

5.11.2.2.8 ActiveMedAlarms
Indica o número de alarmes ativos com severidade Média em um Filtro de Alarmes. Esta propriedade é somente de
leitura.

5.11.2.2.9 ActiveMedNACKAlarms
Indica o número de alarmes não reconhecidos com severidade Média em um Filtro de Alarmes. Esta propriedade é
somente de leitura.

5.11.2.2.10 ActiveNACKAlarms
Indica o número de alarmes que estão sem reconhecimento em um Filtro de Alarmes. Esta propriedade é somente
de leitura.

5.11.2.2.11 AlarmCount
Determina o número de alarmes em um Filtro de Alarmes. Esta propriedade é somente de leitura.

Objetos de Servidor 364


5.11.2.2.12 AlarmServer
Nome do Servidor de Alarmes único existente em uma aplicação.

5.11.2.2.13 AreaFilter
Controla as Áreas de alarmes visíveis no Filtro de Alarmes. Se o valor não é uma String vazia, são apresentados
eventos cujo nome das Áreas comecem com o texto indicado. Por exemplo, se AreaFilter é igual a "Ana", são
mostrados os alarmes de Áreas como "Analogicos.Producao" ou "Analise", mas não "Digitais.Analise" ou
"Digitais.Producao". Quando a propriedade SimpleAreaFilter está configurada como Falso, a Área de Alarme também
permite o uso de caracteres curinga para a filtragem e múltiplos filtros de Área, separados por dois pontos. Os
caracteres curinga permitidos são:
· "*": Aceita nenhum ou qualquer quantidade de caracteres
· "?": Aceita um caractere qualquer
· "#": Aceita um dígito qualquer
· "[ ]": Permite especificar um conjunto de caracteres
· "[ab]": Aceita um caractere se for "a" ou "b"
· "[f-h]": Aceita um caractere entre "f" e "h"
· "[!cz]": Aceita um caractere que não seja nem "c" nem "z"
· "[!m-p]": Aceita um caractere que não esteja entre "m" e "p"

O valor padrão desta propriedade é uma String vazia, ou seja, sem filtragem por Área. Consulte também as
propriedades CustomFilter, SimpleAreaFilter, ShowCriticalPriority, ShowHighPriority, ShowMediumPriority e
ShowLowPriority.

5.11.2.2.14 Connections
Retorna uma coleção de Conexões em um Filtro de Alarmes. Esta propriedade é somente de leitura. Para mais
informações sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Conexões.

5.11.2.2.15 CustomFilter
Permite informar um filtro personalizado para os alarmes, na forma de uma expressão. A tabela a seguir contém os
campos disponíveis para utilização na expressão deste filtro.
Campos disponíveis para a propriedade CustomFilter
CAMPO TIPO DE DADOS DESCRIÇÃO
Acked Booleano Indica se a mensagem já foi
reconhecida

AckRequired Booleano Indica se é necessário reconhecer a


mensagem

AckTime Data e Hora Data e hora em que a condição de


alarme foi reconhecida ou 0 (zero) se
ainda não foi reconhecida

ActiveSource Inteiro Fonte de medida ativa. Os valores


possíveis são -1: None, 0:
ActiveSource, 1: Scada, 2: Operator, 3:
CCLink, 4: Billing, 5: Calculated, 6:
Database, 100: TopologyProcessor,
101: PowerFlow, 102: StateEstimator,
103: LoadShedding, 104:
DistLoadModelling, 105: SelfHealing
ou 106: ExternalReader

ActorID String Login do usuário que reconheceu a


mensagem ou uma String vazia se a
mensagem ainda não foi reconhecida

AlarmSourceName String Nome do objeto Fonte de Alarme,


sem o caminho completo

365 Objetos de Servidor


CAMPO TIPO DE DADOS DESCRIÇÃO
AllowShelving Booleano Indica se o alarme pode ser
arquivado

Area String Área deste alarme

ChangeMask Inteiro Campo não utilizado pelo E3


atualmente, sempre em 0 (zero)

ConditionActive Booleano Indica se a condição de alarme está


ativa

ConditionName String Nome da última condição de alarme


ativa

Cookie Inteiro Identifica uma Fonte de Alarme


durante uma sessão de execução

CurrentValue Double Valor da Fonte no momento em que


a condição de alarme se torna ativa

Deleted Booleano Indica se o alarme foi removido

Enabled Booleano Indica se a verificação de alarmes na


Fonte de Alarme está habilitada

EventCLSID String Identificador único para toda a vida


de um alarme

EventCategory String Nome da categoria do alarme, como


por exemplo "Nível", "Taxa de
Variação", "Banda Morta", "Digital" ou
"Discreto"

EventTime Data e Hora Data e hora da última atualização do


evento

EventTimeUTC Data e Hora Data e hora da última atualização do


evento, no formato UTC

EventType String "Event" (evento) ou


"Condition" (alarme)

FormattedValue String Contém o valor formatado da Fonte


no momento em que a condição de
alarme se torna ativa

FullAlarmSourceName String Nome completo do objeto Fonte de


Alarme

InTime Data e Hora Data e hora em que a condição de


alarme se torna ativa

Message String Mensagem do alarme

OutTime Data e Hora Data e hora em que a condição saiu


de alarme ou 0 (zero) se ainda está
ativa

Quality String Qualidade, como por exemplo "Boa


(xxx)", "Ruim (xxx)" ou "Incerta (xxx)"

Severity Inteiro Severidade do alarme. Os valores


possíveis são -2: Crítica, 0: Alta, 1:
Média ou 2: Baixa

ShelveActorID String Login do usuário que arquivou o


alarme

ShelveCount Word Número de vezes que o evento foi


arquivado

Shelved Booleano Indica se o evento foi arquivado

Objetos de Servidor 366


CAMPO TIPO DE DADOS DESCRIÇÃO
ShelvedOutTime Data e Hora Data e hora em que este evento foi
desarquivado

ShelvedTime Data e Hora Data e hora em que este evento foi


arquivado

ShelveDuration Double Word Tempo, em minutos, que este evento


esteve arquivado

ShelveMaxCount Word Número máximo de vezes que este


evento pode ser arquivado

ShelveMaxDuration Double Word Tempo máximo, em minutos, que este


evento pode permanecer arquivado

ShelveReason String Motivo pelo qual este evento foi


arquivado

Source String Associação da Fonte de Alarme

SubConditionName String Nome da subcondição de alarme,


como por exemplo "LOLO", "LO", "HI",
"HIHI" ou "DIG"

Unbound Booleano Indica se o alarme está vinculado a


uma Fonte de Alarme

UserFieldArray Variant Campos definidos pelo usuário. Use


diretamente o nome do campo na
expressão, como por exemplo
"CampoUsuario1 = 123"

Ao todo, as mensagens que aparecem na listagem do Filtro de Alarmes sempre passam por estes filtros:
· Filtro por tipo, definido na propriedade FilterType
· Filtro por severidade, definida nas propriedades ShowCriticalPriority, ShowLowPriority, ShowMediumPriority e
ShowHighPriority
· Filtro por área, definida nas propriedades AreaFilter e SimpleAreaFilter
· Filtro pela propriedade CustomFilter
· Filtro do sumário de alarmes, equivalente à expressão "Enabled AND (ConditionActive OR (AckRequired AND NOT
Acked))"

Para exemplos de uso desta propriedade, consulte a propriedade CustomFilter do objeto E3Alarm.

5.11.2.2.16 Events
Retorna uma coleção de Eventos em um Filtro de Alarmes. Esta propriedade é somente de leitura. Para mais
informações sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Eventos. Exemplo de uso
desta propriedade:
Sub CommandButton1_Click()
For Each evt In Screen.Item("FiltroAlarmes1").Events
str = ""
str = str & "AlarmSourceName = " &_
evt.AlarmSourceName & Chr(13)
str = str & "FullAlarmSourceName = " &_
evt.FullAlarmSourceName & Chr(13)
str = str & "EventTime = " &_
evt.EventTime & Chr(13)
str = str & "EventTimeUTC = " &_
evt.EventTimeUTC & Chr(13)
str = str & "InTime = " &_
evt.InTime & Chr(13)
str = str & "OutTime = " &_
evt.OutTime & Chr(13)
str = str & "AckTime = " &_
evt.AckTime & Chr(13)
str = str & "CurrentValue = " &_

367 Objetos de Servidor


evt.CurrentValue & Chr(13)
str = str & "ActorID = " &_
evt.ActorID & Chr(13)
str = str & "Area = " &_
evt.Area & Chr(13)
str = str & "ConditionName = " &_
evt.ConditionName & Chr(13)
str = str & "EventCategory = " &_
evt.EventCategory & Chr(13)
str = str & "EventType = " &_
evt.EventType & Chr(13)
str = str & "Message = " &_
evt.Message & Chr(13)
str = str & "Quality = " &_
evt.Quality & Chr(13)
str = str & "Source = " &_
evt.Source & Chr(13)
str = str & "SubConditionName = " &_
evt.SubConditionName & Chr(13)
str = str & "FormattedValue = " &_
evt.FormattedValue & Chr(13)
str = str & "UserField(1) = " &_
evt.UserField(1) & Chr(13)
str = str & "UserField(2) = " &_
evt.UserField(2) & Chr(13)
str = str & "UserField(3) = " &_
evt.UserField(3) & Chr(13)
str = str & "UserField(4) = " &_
evt.UserField(4) & Chr(13)
str = str & "Severity = " &_
evt.Severity & Chr(13)
str = str & "Acked = " &_
evt.Acked & Chr(13)
str = str & "AckRequired = " &_
evt.AckRequired & Chr(13)
str = str & "ConditionActive = " &_
evt.ConditionActive & Chr(13)
str = str & "Enabled = " &_
evt.Enabled & Chr(13)
str = str & "EventCLSID = " &_
evt.EventCLSID & Chr(13)
MsgBox str
Next
End Sub

5.11.2.2.17 Filters
Retorna uma coleção de Filtros em um Filtro de Alarmes. Esta propriedade é somente de leitura. Para mais
informações sobre a coleção retornada nesta propriedade, consulte o tópico Coleção de Filtros.

5.11.2.2.18 FilterType
Efetua os filtros de alarme. As opções disponíveis são 1 - OnlyAlarms: Mostra apenas alarmes (padrão), 2 -
OnlyEvents: Mostra apenas eventos ou 3 - AlarmsAndEvents: Mostra tanto alarmes quanto eventos.

5.11.2.2.19 FourthSortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo quaternário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

5.11.2.2.20 FourthSortField
Determina o campo quaternário para a ordenação dos eventos em um Filtro de Alarmes. O nome do campo deve
ser sempre especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão
desta propriedade é uma String vazia. Esta propriedade não tem efeito quando as propriedades PrimarySortField,
SecondarySortField ou ThirdSortField são configuradas como uma String vazia.

5.11.2.2.21 InactiveCritNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Crítica em um Filtro de Alarmes. Esta
propriedade é somente de leitura.

Objetos de Servidor 368


5.11.2.2.22 InactiveHighNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Alta em um Filtro de Alarmes. Esta
propriedade é somente de leitura.

5.11.2.2.23 InactiveLowNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Baixa em um Filtro de Alarmes. Esta
propriedade é somente de leitura.

5.11.2.2.24 InactiveMedNACKAlarms
Indica o número de alarmes inativos e não reconhecidos com severidade Média em um Filtro de Alarmes. Esta
propriedade é somente de leitura.

5.11.2.2.25 InactiveNACKAlarms
Determina o número total de alarmes inativos e não reconhecidos em um Filtro de Alarmes. Esta propriedade é
somente de leitura.

5.11.2.2.26 PrimarySortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo primário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

5.11.2.2.27 PrimarySortField
Determina o campo primário para a ordenação dos eventos em um Filtro de Alarmes. O nome do campo deve ser
sempre especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é "EventTime". Quando esta propriedade é uma String vazia, as propriedades SecondarySortField,
ThirdSortField e FourthSortField não têm efeito.

5.11.2.2.28 SecondarySortAscending
Quando esta propriedade estiver configurada para Verdadeiro, a ordenação de eventos pelo campo secundário é
no sentido ascendente. Caso contrário, o sentido é descendente. O valor padrão desta propriedade é Falso.

5.11.2.2.29 SecondarySortField
Determina o campo secundário para a ordenação dos eventos em um Filtro de Alarmes. O nome do campo deve
ser sempre especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão
desta propriedade é uma String vazia. Esta propriedade não tem efeito quando a propriedade PrimarySortField é
configurada como uma String vazia.

5.11.2.2.30 ShowCriticalPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Crítica. O valor padrão
desta propriedade é Verdadeiro.

5.11.2.2.31 ShowHighPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Alta. O valor padrão
desta propriedade é Verdadeiro.

5.11.2.2.32 ShowLowPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Baixa. O valor padrão
desta propriedade é Verdadeiro.

5.11.2.2.33 ShowMediumPriority
Se esta propriedade está configurada para Verdadeiro, mostra os alarmes com severidade Média. O valor padrão
desta propriedade é Verdadeiro.

369 Objetos de Servidor


5.11.2.2.34 SimpleAreaFilter
Quando esta propriedade é igual a Verdadeiro, o comportamento de filtragem pelo nome de uma Área de Alarmes
é baseado apenas na coincidência da parte inicial do nome. Quando é igual a Falso, o comportamento leva em conta
todo o nome da Área, mas permite o uso de caracteres curinga e múltiplos filtros de Área, que devem ser separados
por dois pontos. Consulte também a propriedade AreaFilter, que especifica o filtro por nome de Área.

5.11.2.2.35 ThirdSortAscending
Quando esta propriedade estiver configurada para Falso, a ordenação de eventos pelo campo terciário é no
sentido descendente. Caso contrário, o sentido é ascendente. O valor padrão desta propriedade é Falso.

5.11.2.2.36 ThirdSortField
Determina o campo terciário para a ordenação dos eventos em um Filtro de Alarmes. O nome do campo deve ser
sempre especificado em inglês. Consulte os campos disponíveis no Manual do Usuário do E3. O valor padrão desta
propriedade é uma String vazia. Esta propriedade não tem efeito quando as propriedades PrimarySortField ou
SecondarySortField são configuradas como uma String vazia.

5.11.3 Impressora de Linha


Esta seção contém informações sobre métodos e as propriedades do objeto Impressora de Linha (LinePrinter). Este
objeto não possui eventos associados.

5.11.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Impressora de Linha (LinePrinter).

5.11.3.1.1 Write
Write(Value)
Envia a String passada no parâmetro Value para a impressora selecionada no objeto Impressora de Linha. Caso o
valor passado por este método exceda o número de linhas pendentes configurado na propriedade
MaxPendingLines, este método retorna erro e a String é descartada.
O parâmetro Value é enviado à impressora configurada como dados brutos, ou seja, sem nenhum tipo de formatação.
Para imprimir caracteres especiais, como nova linha ou tabulação, utilize constantes de String ou o método Chr do
VBScript, que recebe o código ANSI do caractere a ser impresso. A tabela a seguir contém as constantes mais comuns
para impressão em impressoras matriciais. Para maiores informações sobre caracteres específicos, consulte o manual
do usuário da impressora desejada.
Constantes mais comuns para impressão de caracteres especiais
CONSTANTE VALOR DESCRIÇÃO
vbCr Chr(13) Caractere de retorno de carro

vbLf Chr(10) Caractere de nova linha

vbCrLf Chr(13) & Chr(10) Caracteres de retorno de carro e


nova linha

vbNewLine Chr(13) & Chr(10) ou Chr(10) Caracteres de retorno de carro e


nova linha ou somente o caractere de
nova linha, dependendo da
impressora utilizada

vbTab Chr(9) Caractere de tabulação

5.11.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Impressora de Linha (LinePrinter).

5.11.3.2.1 MaxPendingLines
Número máximo de linhas pendentes a serem impressas. Caso a fila de espera da impressora atinja este valor e
mais linhas sejam enviadas, utilizando o método Write, é gerado um erro de script e a linha enviada é descartada. O
valor padrão desta propriedade é 1000.

Objetos de Servidor 370


5.11.3.2.2 PrinterName
Nome da impressora utilizada pelo objeto Impressora de Linha. O valor padrão desta propriedade é uma String
vazia, ou seja, o objeto Impressora de Linha utiliza a impressora padrão do Windows.

NOTAS
· Caso esta propriedade esteja configurada com uma String vazia e a propriedade UseDefaultPrinter esteja
configurada para Falso, não é possível imprimir e a propriedade PrinterStatus retorna o valor 0 (zero,
psUnknown).
· A impressora padrão do Windows para o usuário atualmente logado pode ser diferente da impressora padrão
utilizada pelo E3 Server. Esta impressora está identificada pelo ícone na janela E3 Admin - Impressora (clique
com o botão direito do mouse no ícone do E3 Admin na Área de Notificações do Windows e selecione a opção
Impressora).

5.11.3.2.3 PrinterStatus
Indica o status da impressora selecionada para o objeto Impressora de Linha. Esta propriedade é somente de
leitura e pode apresentar os seguintes valores:
· 0 - psUnknown: Status desconhecido (padrão)
· 1 - psOffline: A impressora não está disponível
· 2 - psError: Houve um erro na impressão
· 3 - psReady: A impressora está pronta para impressão

5.11.3.2.4 UseDefaultPrinter
Configura o objeto Impressora de Linha para utilizar a impressora padrão do Windows. O valor padrão desta
propriedade é Verdadeiro.

NOTAS
· Caso esta propriedade esteja configurada para Falso e a propriedade PrinterName esteja configurada com uma
String vazia, não é possível imprimir e a propriedade PrinterStatus retorna o valor 0 (zero, psUnknown).
· A impressora padrão do Windows para o usuário atualmente logado pode ser diferente da impressora padrão
utilizada pelo E3 Server. Esta impressora está identificada pelo ícone na janela E3 Admin - Impressora (clique
com o botão direito do mouse no ícone do E3 Admin na Área de Notificações do Windows e selecione a opção
Impressora).

5.11.4 Pasta de Dados


O objeto Pasta de Dados não possui eventos, métodos ou propriedades específicos associados, somente métodos e
propriedades gerais. Estes podem ser visualizados nas seções Eventos, Métodos e Propriedades Gerais dos
Objetos.

5.11.5 Tag Contador


Esta seção contém informações sobre eventos e propriedades do objeto Tag Contador (CounterTag). Este objeto não
possui métodos associados.

5.11.5.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tag Contador (CounterTag).

5.11.5.1.1 OnPreset
OnPreset()
Ocorre toda vez que o valor da propriedade Preset é alcançado.

5.11.5.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag Contador (CounterTag).

371 Objetos de Servidor


5.11.5.2.1 AutoRestart
Indica que a contagem deve ser recomeçada do zero após ter sido atingido o valor estabelecido na propriedade
Preset. Esta propriedade somente é válida quando a propriedade CounterType está configurada com o valor 0 -
Preset.

5.11.5.2.2 CounterType
Define o comportamento do contador. Os valores disponíveis para esta propriedade são:
· 0 - Preset: A contagem é interrompida quando o valor estabelecido na propriedade Preset é atingido (padrão)
· 1 - Infinite: A contagem prossegue indefinidamente

5.11.5.2.3 Enabled
Inicia ou para o contador. Em Verdadeiro, a contagem é iniciada; em Falso, ela é interrompida.

5.11.5.2.4 Increment
Define o intervalo de atualização da propriedade Value. Caso esta propriedade tenha seu valor modificado
enquanto a contagem estiver em curso, esta modificação só tem efeito quando o contador for parado e reiniciado.

5.11.5.2.5 Preset
Limite a ser atingido pelo contador, em segundos. Caso o valor de Preset não seja um múltiplo de Increment, o Tag
atinge este valor antes do próximo incremento.

5.11.5.2.6 ResetCounterWhenEnabled
Habilita o reinício da contagem (do zero) cada vez que o valor da propriedade Enabled retorna a Verdadeiro.
Quando desabilitada, o contador reinicia a contagem de onde ela foi interrompida anteriormente.

5.11.5.2.7 Value
Mostra a contagem do contador, em segundos. Esta propriedade é somente de leitura. Esta propriedade recebe
valores múltiplos de Increment, exceto quando a propriedade Enabled é ajustada para Falso. Neste caso, o valor é o
do momento em que o Tag foi desabilitado. Ao reiniciar a contagem, o valor da propriedade é o próximo múltiplo de
Increment. O valor máximo desta propriedade é 2147483647 (0x7FFFFFFF).

5.11.6 Tag Demo


Esta seção contém informações sobre métodos e propriedades do objeto Tag Demo (DemoTag). Este objeto não
possui eventos associados.

5.11.6.1 Métodos
Esta seção contém informações sobre os métodos do objeto Tag Demo (DemoTag).

5.11.6.1.1 Reset
Reset()
Zera a fase (deslocamento em tempo) da forma de onda do Tag. A fase da onda somente é zerada quando o Tag
estiver habilitado. Este método, quando o Tag estiver habilitado, não tem efeito nos Tags do tipo CurrentTime e
Random, que não são periódicos. Quando o Tag estiver desabilitado, seu valor é simplesmente zerado,
independentemente do tipo de Tag.

5.11.6.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag Demo (DemoTag).

5.11.6.2.1 Enabled
A propriedade Enabled habilita ou desabilita a variação do Tag Demo. Se Enabled estiver configurado para Falso, a
variação está desabilitada. Caso contrário, o Tag atualiza a propriedade Value conforme a configuração das
propriedades Period e Scan. O valor padrão desta propriedade é Verdadeiro.

Objetos de Servidor 372


5.11.6.2.2 Maximum
A propriedade Maximum determina o valor máximo do Tag. O valor padrão desta propriedade é 100. Exemplo:
Sub CommandButton2_Click()
' Ao clicar no botão, abre uma caixa de mensagens,
' indicando o valor da propriedade Maximum do TagDemo6
MsgBox Application.GetObject("Dados.TagDemo6").Maximum
End Sub

5.11.6.2.3 Minimum
A propriedade Minimum determina o valor mínimo do Tag. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub CommandButton2_Click()
' Ao clicar no botão, abre um messagebox indicando o valor
' da propriedade Minimum do TagDemo6
MsgBox Application.GetObject("Dados.TagDemo6").Minimum
End Sub

5.11.6.2.4 Period
Define o comprimento da forma de onda, em milissegundos. Não se aplica quando a propriedade Type estiver
configurada para 0 - Random ou 3 - CurrentTime. O valor padrão desta propriedade é 10000 ms. Exemplo:
Sub TagDemo1_OnStartRunning()
Period = 1000
End Sub

5.11.6.2.5 Scan
A propriedade Scan define o intervalo de tempo, em milissegundos, entre duas variações da propriedade Value.
Utilize esta propriedade se o usuário desejar maior ou menor quantidade de dados gerados pelo Tag Demo. O valor
padrão desta propriedade é 1000. O valor do scan deve ser maior que 0 (zero). Exemplo:
Sub Linha1_Click()
Application.GetObject("Dados.TagDemo2").Scan = 200
End Sub

5.11.6.2.6 TimeStamp
A propriedade TimeStamp é atualizada sempre que ocorrer alguma mudança de valor ou estado nas
propriedades Value ou Quality. Ela informa qual a data e hora associada tanto ao valor quanto à qualidade do Tag
Demo. Esta propriedade é somente de leitura. O valor padrão desta propriedade é 00:00:00.

5.11.6.2.7 Type
Determina o tipo de onda do Tag. Modifique a propriedade conforme a tabela a seguir. Quando a propriedade
Type estiver configurado para 3 (três, CurrentTime), a propriedade Value contém a data e hora atual do servidor.
Opções disponíveis para Type
VALOR FORMA DE ONDA
0 Random (aleatória)

1 Sine (onda senoide, padrão)

2 Square (onda quadrada)

3 CurrentTime (data e hora)

4 RampUp (borda de subida)

5 RampDown (borda de descida)

6 RampUpDown (borda de subida e descida)

Exemplo:
Sub Linha1_Click()
Application.GetObject("Dados.TagDemo2").Type = 2
End Sub

373 Objetos de Servidor


5.11.6.2.8 Value
A propriedade Value varia de acordo com o tipo da forma de onda, estabelecida na propriedade Type. Esta
propriedade é somente de leitura. O valor padrão desta propriedade é 0 (zero). Exemplo:
Sub Figura1_Click()
MsgBox Application.GetObject("Dados.TagDemo2").Value = 10
End Sub

5.11.7 Tag Interno


Esta seção contém informações sobre métodos e propriedades do objeto Tag Interno (InternalTag). Este objeto não
possui eventos associados.

5.11.7.1 Métodos
Esta seção contém informações sobre os métodos do objeto Tag Interno (InternalTag).

5.11.7.1.1 WriteEx
WriteEx([NewValue], [NewTimestamp], [NewQuality])
Permite modificar o valor, a data e hora e a qualidade de um Tag Interno em uma única operação. Este método
retorna um Booleano que indica o sucesso ou não da operação.
O parâmetro NewValue especifica o novo valor do Tag. Se omitido, o valor do Tag não é modificado. O parâmetro
NewTimestamp especifica a nova data e hora do Tag. Se omitido, utiliza-se a data e hora do momento da chamada do
método. O parâmetro NewQuality especifica a nova qualidade do Tag. Se omitido, assume a qualidade Boa (192).
Exemplo:
Sub CommandButton12_Click()
Dim Ret
Ret = Application.GetObject("Dados.TagInterno1")._
WriteEx(123.456, "1/1/2001", 193)
If Ret Then
MsgBox "Funcionou!"
Else
MsgBox "Falhou!"
End If
End Sub

5.11.7.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag Interno (InternalTag).

5.11.7.2.1 Quality
Informa a qualidade do valor contido na propriedade Value. Esta propriedade é de leitura e escrita, mas sempre
que o valor do Tag Interno for modificado, seja por script ou por uma Associação, ela é atualizada de acordo.
Exemplo:
Sub CommandButton1_Click()
MsgBox Application.GetObject("Dados.TagInterno1").Quality
End Sub

NOTA
Para maiores informações sobre qualidade, consulte o tópico Qualidade no Manual do Usuário do E3.

5.11.7.2.2 Retentive
Esta propriedade determina se o valor do Tag Interno deve ser armazenado automaticamente ou não, caso o
Domínio seja parado. Isto garante que o valor do Tag é sincronizado com um servidor em standby. Assim, quando o
servidor é executado, o valor do Tag é o mesmo do servidor que parou. Caso contrário, o valor do Tag é ajustado
para o valor inicial sempre que o Domínio é executado ou se ocorrer troca do servidor ativo. Esta propriedade não
pode ser alterada com o objeto ativo. Exemplo:
Sub CommandButton1_Click()
Dim status
status = Application.GetObject("Dados.TagInterno1").Retentive
MsgBox status
Select Case status
Case True

Objetos de Servidor 374


MsgBox "O valor do Tag Interno é _
armazenado automaticamente."
Case False
MsgBox "O valor do Tag Interno é ajustado para o valor _
inicial sempre que o Domínio é executado ou _
se ocorrer troca do servidor ativo."
End Select
End Sub

NOTA
Esta propriedade só é válida para Tags Internos contidos no Servidor. Tags Internos contidos no Viewer não podem
ser retentivos.

5.11.7.2.3 TimeStamp
A propriedade TimeStamp informa a data e hora associada ao valor contido na propriedade Value. Esta
propriedade é de leitura e escrita, mas sempre que o valor do Tag Interno for modificado, seja por script ou por uma
Associação, ela é atualizada de acordo.

5.11.7.2.4 Value
A propriedade Value é do tipo Variant, o que permite armazenar valores de todo e qualquer tipo, desde um inteiro
até referências para objetos (veja o exemplo a seguir). Utilize-o para guardar valores dentro do Viewer ou Servidor e
para trocar dados entre os diversos pontos da aplicação. O valor padrão desta propriedade é vazio. Esta
propriedade é de leitura e escrita. Exemplo:
Sub Meses_OnStartRunning()
' Meses é um tag do tipo InternalTag.
' Utiliza-se o evento para inicializar o vetor.
Value = Array("Janeiro", "Fevereiro", "Março", _
"Abril", "Maio", "Junho", "Julho", "Agosto", _
"Setembro", "Outubro", "Novembro", "Dezembro")
End Sub

5.11.8 Tag Timer


Esta seção contém informações sobre eventos e propriedades do objeto Tag Timer (TimerTag). Este objeto não
possui eventos associados.

5.11.8.1 Eventos
Esta seção contém informações sobre os eventos do objeto Tag Timer (TimerTag).

5.11.8.1.1 OnPreset
OnPreset()
Ocorre toda vez que o valor da propriedade NextExecTime é alcançado.

5.11.8.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Tag Timer (TimerTag).

5.11.8.2.1 Enabled
Habilita ou desabilita o Timer. O valor padrão desta propriedade é Verdadeiro.

5.11.8.2.2 NextExecTime
Exibe o próximo horário de disparo. Esta propriedade é somente de leitura.

5.11.8.2.3 RepeatInterval
Esta propriedade indica um intervalo de tempo para a repetição de uma ação. Esta propriedade só está disponível
se a propriedade TriggerType estiver configurada para o valor 1 - ttContinuous. Os valores possíveis para esta
propriedades estão no intervalo entre 00:00:01 (um segundo, valor padrão) e 23:59:59.

375 Objetos de Servidor


5.11.8.2.4 StartTime
Data e hora inicial do Timer. Para a propriedade TriggerType com o valor 0 - ttSingle, é a própria data e hora de
disparo. Para os demais valores, é o momento a partir do qual o Timer começa a disparar. O valor padrão desta
propriedade é o dia e a hora locais.

5.11.8.2.5 TriggerType
Tipo de disparo do Timer. As opções disponíveis estão descritas na tabela a seguir.
Opções disponíveis para TriggerType
OPÇÃO DESCRIÇÃO
0 - ttSingle Disparo único

1 - ttContinuous Disparo contínuo (padrão)

2 - ttDaily Disparo diário

3 - ttMonthly Disparo mensal

5.12 Storage
Esta seção contém informações sobre métodos e propriedades do objeto Storage (Historian). Este objeto não possui
eventos associados.

5.12.1 Métodos
Esta seção contém informações sobre os métodos do objeto Storage (Historian).

5.12.1.1 CreateNewSession
CreateNewSession([DefaultType], [DefaultMinRecTime], [DefaultMaxRecTime],
[DefaultDeadBand], [DefaultDeadBandUnit], [DefaultScanTime])
Cria uma Sessão com a capacidade de incluir dados em um Storage, de forma independente da aquisição normal. Os
parâmetros opcionais são utilizados nas configurações dos Tags da Sessão, caso não informados em sua criação. São
eles, respectivamente:
· DefaultType: Tipo de dados (0: Double, 1: Bit, 2: String ou 3: Integer). Se este parâmetro é omitido, utiliza o
valor 0: Double
· DefaultMinRecTime: Intervalo mínimo de tempo entre gravações. Se este parâmetro é omitido, utiliza o valor 0
(zero)
· DefaultMaxRecTime: Intervalo máximo de tempo sem gravações. Se este parâmetro é omitido, utiliza o valor
3600
· DefaultDeadBand: Banda morta. Se este parâmetro é omitido, utiliza o valor 1 (um)
· DefaultDeadBandUnit: Unidade da banda morta do Tag (0: Porcentagem ou 1: Absoluta). Se este parâmetro é
omitido, utiliza o valor 1: Absoluta
· DefaultScanTime: Tempo de varredura. Se este parâmetro é omitido, utiliza o valor 0 (zero)

Este método funciona mesmo que o objeto Storage não tenha nenhum Campo configurado.

5.12.1.2 StartAcquisition
StartAcquisition()
Inicia ou retoma a geração de dados que vão para o Banco de Dados. O Storage recebe notificações sobre quais
Tags cadastrados sofreram modificação e, quando isto acontece, o Storage verifica se os registros são gravados ou
não. Quando este método é utilizado, a notificação de mudança e a geração de gravações são iniciadas ou
retomadas. Exemplo:
Sub Botao1_Click()
' Ao clicar neste botão, habilita o Storage
Application.GetObject("Storage1").StartAcquisition()
End Sub

Objetos de Servidor 376


5.12.1.3 StopAcquisition
StopAcquisition()
Para a geração de dados que vão para o Banco de Dados. O Storage recebe notificações sobre quais Tags
cadastrados sofreram modificação e, quando isto acontece, o Storage verifica se os registros são gravados ou não.
Quando este método é utilizado, a notificação de mudança e a geração de gravações são paralisadas. Exemplo:
Sub Storage1_OnStartRunning()
' Desabilita o Storage após iniciar
StopAcquisition()
End Sub

5.12.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Storage (Historian).

5.12.2.1 BackupDiscardInterval
Indica o intervalo máximo de tempo (minutos, horas, dias ou meses) dos dados na tabela de backup do Storage até
serem descartados, independente do tempo que os dados permanecem na tabela principal. Por exemplo, para
manter os dados por 24 meses na tabela principal e mais seis meses na tabela de backup, o valor desta propriedade
deve ser de 30 meses. Esta propriedade trabalha em conjunto com a propriedade BackupDiscardTimeUnit. O valor
padrão desta propriedade é 12 (doze unidades de tempo indicadas na propriedade BackupDiscardTimeUnit).

NOTA
O tempo total indicado pela combinação desta propriedade e da propriedade BackupDiscardTimeUnit deve ser
maior que o tempo indicado pelas propriedades DiscardInterval e DiscardTimeUnit.

5.12.2.2 BackupDiscardTimeUnit
Esta propriedade indica a unidade de tempo em que os dados de backup do Storage permanecem armazenados,
até serem descartados. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)
· 3 - dtMinute: Minutos

Esta propriedade trabalha em conjunto com a propriedade BackupDiscardInterval.

5.12.2.3 CacheSize
Define o tamanho do bloco de registros que deve ser lido pelo Storage antes de ser enviado para o banco de
dados. Por exemplo, se esta propriedade é igual a 4 (quatro), são enviados blocos contendo quatro registros cada
um para o objeto Banco de Dados associado. O valor padrão desta propriedade é 10.

NOTA
O bloco de registros é enviado a cada um segundo, mesmo que não se tenha atingido o tamanho configurado nesta
propriedade.

5.12.2.4 CompressionRate
Mostra a taxa de compressão de dados obtida até o momento. Esta propriedade é somente de leitura.

5.12.2.5 DBServer
Indica o objeto Banco de Dados utilizado no Storage para criação de tabelas e registros de dados. O valor padrão
desta propriedade é uma String vazia.

5.12.2.6 DiscardInterval
Esta propriedade trabalha em conjunto com a propriedade DiscardTimeUnit e indica o intervalo de tempo durante
o qual os dados do Storage permanecem armazenados na tabela do banco de dados até serem descartados. O valor
padrão desta propriedade é 1 (uma unidade de tempo indicada em DiscardTimeUnit). Se esta propriedade é

377 Objetos de Servidor


configurada com um valor menor ou igual ao valor da propriedade BackupDiscardInterval, o E3 automaticamente
ajusta o valor de BackupDiscardInterval com o dobro do valor desta propriedade.

5.12.2.7 DiscardTimeUnit
Esta propriedade trabalha em conjunto com a propriedade DiscardInterval e indica a unidade de tempo em que
os dados do Storage permanecem armazenados até serem descartados. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)
· 3 - dtMinute: Minutos

5.12.2.8 EnableBackupTable
Cria uma tabela de backup onde os dados descartados do Storage permanecem por segurança. Se configurada
para Verdadeiro, a tabela é criada. Caso contrário, não há tabela de backup. O valor padrão desta propriedade é
Falso.

5.12.2.9 EnableDiscard
Habilita o descarte dos dados do Storage após um determinado tempo. Se configurada para Falso, os dados são
armazenados indefinidamente na tabela. Caso contrário, são descartados após determinado tempo. O valor padrão
desta propriedade é Falso.

5.12.2.10 Fields
Esta propriedade retorna um objeto que representa a coleção de Campos criados em um Storage e é somente de
leitura. Para mais informações sobre o objeto retornado nesta propriedade, consulte o tópico Fields.

NOTAS
· Em aplicações criadas antes da versão 5.0 do E3, a propriedade Fields é uma coleção que suporta o método Item
para acessar os Campos disponíveis. A partir da versão 5.0, esta propriedade também retorna um objeto e,
portanto, a forma de acesso aos Campos é diferente para ambas as formas. O exemplo a seguir demonstra a
forma correta de utilização desta propriedade.
· Aplicações salvas na versão 5.0 convertem os objetos Storage do formato de coleção para objeto e NÃO podem
mais ser abertas em versões anteriores.

Para acessar a coleção de Campos do Storage tanto como uma coleção quanto como um objeto, use a sintaxe
descrita no exemplo a seguir.
'A aplicação contém um objeto chamado Storage1
'que contém um Campo chamado Campo1.
'Para acessar este Campo a partir de uma coleção,
'use a seguinte sintaxe:
Set campoColecao = Application.GetObject("Storage1").Fields.Item("Campo1")
'Para acessar este mesmo Campo como um objeto,
'use a seguinte sintaxe:
Set campoNativo = Application.GetObject("Storage1.Fields.Campo1")

5.12.2.11 StringFieldSize
Esta propriedade especifica o tamanho máximo que os Campos do tipo String do objeto Storage podem ter (é o
tamanho utilizado na criação do campo Value da tabela de Strings).

5.12.2.12 TableName
Define o nome da tabela que é utilizada no Storage.

5.12.2.13 VerificationInterval
Esta propriedade trabalha em conjunto com a propriedade VerificationUnit para controlar o intervalo de tempo
que o E3 verifica a antiguidade dos dados do Storage, para depois descartá-los. O valor padrão desta propriedade é
1 (uma unidade de tempo indicada na propriedade VerificationUnit).

Objetos de Servidor 378


5.12.2.14 VerificationUnit
Esta propriedade trabalha em conjunto com a propriedade VerificationInterval e indica a unidade de tempo em
que é realizada a verificação para descarte dos dados do Storage. As opções disponíveis são as seguintes:
· 0 - dtHour: Horas
· 1 - dtDay: Dias
· 2 - dtMonth: Meses (padrão)
· 3 - dtMinute: Minutos

5.12.3 Fields
Esta seção contém informações sobre métodos e propriedades do objeto Fields (IStorageFieldsCollection). Este
objeto não possui eventos associados.

NOTA
O objeto Fields pode ser acessado através da propriedade Fields do Storage.

5.12.3.1 Métodos
Esta seção contém informações sobre os métodos do objeto Fields (IStorageFieldsCollection).

5.12.3.1.1 AddField
AddField(FieldLink, [FieldName], [FieldType], [FieldMinRecTime], [FieldMaxRecTime],
[FieldScanTime], [FieldDeadBand], [FieldDeadBandUnit])
Este método adiciona um objeto Campo do Storage no objeto Fields. Os parâmetros deste método estão descritos
na tabela a seguir.
Parâmetros do método AddField
PARÂMETRO DESCRIÇÃO
FieldLink Fonte de dados associada a este Campo do Storage.
Este parâmetro é obrigatório e corresponde à
propriedade Link do Campo do Storage

FieldName Nome do Campo do Storage no objeto Fields. Este


parâmetro é opcional e, se omitido, recebe a expressão
"Campo". Este parâmetro corresponde à propriedade
Name do Campo do Storage. Consulte a propriedade
geral Name para mais informações sobre os caracteres
permitidos nos nomes de objetos

FieldType Tipo de dados do Campo do Storage. Os valores


possíveis para este parâmetro são 0: eStorageDouble,
1: eStorageBit, 2: eStorageText ou 3: eStorageInteger.
Este parâmetro é opcional e, se omitido, utiliza o valor 0
(zero). Este parâmetro corresponde à propriedade Type
do Campo do Storage

FieldMinRecTime Tempo mínimo, em milissegundos, para que um novo


dado seja gravado. Este parâmetro é opcional e, se
omitido, este tempo é configurado em 0 (zero), ou seja,
desabilita o tempo mínimo. Este parâmetro corresponde
à propriedade MinRecTime do Campo do Storage

FieldMaxRecTime Tempo máximo, em segundos, sem que nenhum dado


seja gravado. Este parâmetro é opcional e, se omitido,
este tempo é configurado com o valor 3600 (uma hora).
Este parâmetro corresponde à propriedade
MaxRecTime do Campo do Storage

379 Objetos de Servidor


PARÂMETRO DESCRIÇÃO
FieldScanTime Indica de quanto em quanto tempo, em milissegundos, o
valor do Tag é realimentado no algoritmo de
compactação de dados, caso não esteja variando. Este
parâmetro é opcional e, se omitido, utiliza o valor
configurado no parâmetro FieldMaxRecTime. Este
parâmetro corresponde à propriedade ScanTime do
Campo do Storage

FieldDeadBand Banda morta utilizada para cálculo do algoritmo do


Storage. Este parâmetro é opcional e, se omitido, utiliza
o valor 1 (um). Este parâmetro corresponde à
propriedade DeadBand do Campo do Storage

FieldDeadBandUnit Unidade de banda morta do parâmetro FieldDeadBand


como um percentual de banda morta (0: dbPercent) ou
em unidades absolutas (1: dbAbsolute). Este parâmetro
é opcional e, se omitido, utiliza o valor 0 (zero,
percentual). Este parâmetro corresponde à propriedade
DeadBandUnit do Campo do Storage

5.12.3.1.2 DeleteField
DeleteField(Index)
Remove o Campo do Storage informado no parâmetro Index, que pode ser a posição do Campo do Storage
(iniciando em um) ou o valor da propriedade Name do Campo do Storage, se este Campo do Storage existir no
objeto Fields. Caso contrário, este método retorna um erro de script.

5.12.3.1.3 RemoveAll
RemoveAll()
Este método remove todos os objetos Campo do Storage do objeto Fields.

5.12.3.2 Propriedades
Esta seção contém informações sobre as propriedades do objeto Fields (IStorageFieldsCollection).

5.12.3.2.1 Count
Retorna a quantidade de objetos Campo do Storage no objeto Fields. Esta propriedade é somente de leitura.

5.12.3.3 Campo do Storage


Esta seção contém informações sobre propriedades do objeto Campo do Storage (IStorageField). Este objeto não
possui eventos nem métodos associados.

5.12.3.3.1 Propriedades
Esta seção contém informações sobre as propriedades do objeto Campo do Storage (IStorageField).

5.12.3.3.1.1 DeadBand
Banda morta utilizada para cálculo do algoritmo do Storage. Indica a precisão que o usuário está disposto a perder
em cada Campo do Storage a ser armazenado. Quanto maior o valor desta propriedade, mais compacto é o banco
de dados (menos dados são gravados). Este valor pode ser especificado em unidades absolutas ou como um
percentual do valor atual do Tag, conforme configurado na propriedade DeadBandUnit. O valor padrão desta
propriedade é 1 (um).

5.12.3.3.1.2 DeadBandUnit
Unidade da propriedade DeadBand. Este valor pode ser especificado como um percentual do valor atual do Tag
(0: dbPercent) ou em unidades absolutas (1: dbAbsolute). O valor padrão desta propriedade é 0 (zero).

Objetos de Servidor 380


5.12.3.3.1.3 Link
Determina a fonte de dados associada a este Campo do Storage. Esta propriedade não pode ser alterada em
tempo de execução, mesmo que o Campo do Storage esteja inativo.

5.12.3.3.1.4 MaxRecTime
Diferença máxima, em segundos, entre as estampas de tempo de dois registros consecutivos armazenados no
banco de dados, isto é, o tempo máximo sem que nenhum dado seja gravado. Por exemplo, se um Tag não estiver
variando de valor, mesmo assim o valor atual deve ser escrito no banco de dados sempre que o número de
segundos configurado nesta propriedade é atingido. Este comportamento pode ser desabilitado utilizando-se o valor
0 (zero). O valor padrão desta propriedade é 3600 (uma hora).

5.12.3.3.1.5 MinRecTime
Diferença mínima, em milissegundos, entre as estampas de tempo de dois registros quaisquer de mesma qualidade
armazenados no banco de dados, isto é, o tempo mínimo para que um novo dado seja gravado. Este parâmetro
serve para limitar o número de registros escritos em um banco de dados, no caso de um Tag sofrer variações
bruscas de valor. Este comportamento pode ser desabilitado utilizando-se o valor 0 (zero, valor padrão).

5.12.3.3.1.6 Name
Esta propriedade retorna ou configura o nome deste Campo do Storage no objeto Storage. Através desta
propriedade é possível buscar itens na Coleção de Campos do Storage (propriedade Fields). O valor padrão desta
propriedade é uma String vazia. Não é permitido utilizar as expressões "Null", "Empty", "Nothing", "Application",
"True" ou "False" para esta propriedade. Esta propriedade não pode ser alterada em tempo de execução. Consulte a
propriedade geral Name para mais informações sobre os caracteres permitidos no nome deste objeto.

5.12.3.3.1.7 ScanTime
Retorna ou configura o tempo de varredura em milissegundos de um Campo do Storage, ou seja, de quanto em
quanto tempo o valor do Tag é realimentado no algoritmo de compactação de dados, caso não esteja variando. Se o
valor desta propriedade é igual a 0 (zero), o valor da propriedade MaxRecTime é utilizado para este mesmo
propósito (comportamento padrão).

5.12.3.3.1.8 Type
Retorna o tipo de dados do Campo do Storage no formato do Storage. Esta propriedade é de leitura e escrita,
mas só aceita mudanças enquanto a coleta de dados para este Campo do Storage ainda não começou. Os valores
possíveis para esta propriedade são os seguintes:
· 0: Double (padrão)
· 1: Bit
· 2: Text
· 3: Integer

NOTA
Os tipos de dados Bit, Text e Integer não são submetidos ao algoritmo de compactação do Storage. Portanto,
sempre que há uma variação no valor ou na qualidade do Campo do Storage, o valor é gravado no banco de
dados. As propriedades DeadBand, DeadBandUnit, MaxRecTime e MinRecTime não têm efeito nestes tipos de
dados, pois são exclusivas do algoritmo de compactação.

5.12.4 Sessão do Storage


Esta seção contém informações sobre os métodos do objeto Sessão do Storage (StorageSession). Este objeto não
possui eventos nem propriedades associados.

5.12.4.1 Métodos
Esta seção contém informações sobre os métodos do objeto Sessão do Storage (StorageSession).

381 Objetos de Servidor


5.12.4.1.1 AddField
AddField(FieldName, [Type], [MinRecTime], [MaxRecTime], [DeadBand], [DeadBandUnit],
[ScanTime])
Este método é responsável pela inserção de Tags temporários na estrutura da Sessão. Se os parâmetros opcionais
são omitidos, utiliza-se os valores definidos na criação da Sessão pelo método CreateNewSession do Storage. Os
parâmetros deste método são descritos na tabela a seguir.
Parâmetros do método AddField
PARÂMETRO DESCRIÇÃO
FieldName Nome do Tag temporário (obrigatório). Consulte a
propriedade geral Name para mais informações sobre
os caracteres permitidos nos nomes de objetos

Type Tipo do Tag. Os valores possíveis são 0: Double, 1: Bit,


2: Text ou 3: Integer. Se este parâmetro é omitido,
utiliza o valor 0: Double

MinRecTime Intervalo mínimo de tempo entre as gravações. Se este


parâmetro é omitido, utiliza o valor 0 (zero)

MaxRecTime Intervalo máximo de tempo sem gravações. Se este


parâmetro é omitido, utiliza o valor 3600

DeadBand Banda morta do Tag temporário. Se este parâmetro é


omitido, utiliza o valor 1 (um)

DeadBandUnit Unidade de banda morta do Tag temporário. Os valores


possíveis são 0: Porcentagem ou 1: Absoluta. Se este
parâmetro é omitido, utiliza o valor 1: Absoluta

ScanTime Tempo de varredura do Tag temporário. Se este


parâmetro é omitido, utiliza o valor 0 (zero)

Este método retorna Verdadeiro se o Tag foi corretamente adicionado na Sessão e Falso caso contrário.

5.12.4.1.2 AddValue
AddValue(FieldName, Timestamp, Quality, Value)
Adiciona um valor a um Tag temporário na Sessão. Os parâmetros deste método estão descritos na tabela a seguir.
Parâmetros do método AddValue
PARÂMETRO DESCRIÇÃO
FieldName Nome do campo ao qual o valor é adicionado. Este
nome deve existir na configuração original do Storage,
ou então deve ter sido adicionado previamente pelo
método AddField

Timestamp Estampa de tempo do valor a ser adicionado

Quality Qualidade do valor a ser adicionado

Value Valor a ser adicionado

Este método retorna Verdadeiro se o valor foi adicionado corretamente e Falso caso contrário.

5.12.4.1.3 Commit
Commit()
Grava todos os dados mantidos em memória pela Sessão no banco de dados do Storage. Este método retorna
Verdadeiro se os dados foram gravados corretamente e Falso caso contrário.

Objetos de Servidor 382


CAPÍTULO
Dúvidas Mais Frequentes
6
Como abrir uma Tela janelada que mostre a barra de título com botões de minimizar, maximizar e
fechar?
Para isto, deve-se utilizar o método SetFrameOptions do Divisor. O parâmetro Flags especifica características da
janela. O valor 127 define uma janela com os botões Minimizar, Maximizar e Fechar visíveis.

Como abrir uma Tela modal?


Para abrir uma Tela modal, utilize o método DoModal do Viewer. Por exemplo:
Application.DoModal "Tela1", "Título1", 0, 0, 400, 200, 0, 1

Este código abre uma Tela de nome "Tela1", com o título "Título1", na posição (0, 0), com 400 pixels de largura e 200
pixels de altura, passa o valor 0 (zero) como parâmetro para a Tela e habilita a barra de título da janela.

Como copiar valores de uma linha do E3Browser para um Tag?


Primeiro, selecione a linha (ou o registro) desejada no E3Browser. Depois, utilize o método GetColumnValue do
E3Browser. O parâmetro Index é o índice da coluna a ser copiada (iniciando em zero).

Como impedir que o usuário digite uma String em um SetPoint?


Verifique se o valor digitado é numérico no evento Validate. Por exemplo:
Sub Text1_Validate(Cancel, NewValue)
If NOT IsNumeric(newValue) Then
MsgBox "O valor deve ser numérico."
Cancel = True
End If
End Sub

Como abrir um calendário para selecionar data e hora ao clicar em um SetPoint?


Usando o método ShowDatePicker no evento Click do SetPoint. Por exemplo:
Sub Text1_Click()
Dim datevalue
If Application.ShowDatePicker(datevalue) Then
Value = datevalue
End If
End Sub

Como reconhecer todos os alarmes de uma Área?


Para reconhecer todos os alarmes de uma Área por script, é possível utilizar o método AckArea. Este método tem
dois parâmetros, a saber:
· Area é o nome da Área de Alarmes da qual se quer reconhecer o alarme
· User é o nome do operador logado, que pode ser o item Application.User

Para reconhecer todos os alarmes ativos, pode-se utilizar o método AckAllAlarms.

Como executar uma ação ao clicar em um botão específico do mouse ou em uma tecla?
Usando os eventos KeyDown ou KeyUp da Tela. Estes eventos são disparados quando uma tecla é pressionada ou
solta e retornam dois parâmetros. Um é o código da tecla que foi pressionada, e o outro indica a condição das teclas
SHIFT e CTRL no momento em que a tecla foi pressionada. A ideia é comparar o parâmetro de retorno do evento com
o código do caractere esperado.

Como criar um script WhileRunning?


Criando um evento associado a alguma propriedade que tenha sempre o mesmo valor. Por exemplo, a propriedade
Visible de um objeto de Tela. Enquanto o objeto estiver visível (com a propriedade Visible igual a Verdadeiro), o

383 Dúvidas Mais Frequentes


script é executado. Porém, recomenda-se evitar o uso de scripts do tipo WhileRunning, pois podem prejudicar a
performance da aplicação. Na maioria dos casos, eles podem ser substituídos por Associações.

Como criar um script OnValueChanged?


Criando um evento associado à propriedade Value de um Tag, e que seja executado quando a propriedade alterar o
seu valor.

NOTA
Atenção para não usar métodos do Viewer no Servidor, como por exemplo o método MsgBox. Se for o caso, o
evento pode ser criado na Tela ou até no próprio objeto Viewer, ao invés de ser criado no Tag.

Como criar Tags e objetos de Tela em tempo de execução?


Usando o método AddObject. Por exemplo, o script a seguir cria Tags de Comunicação no Driver Driver1.
Set obj = Application.GetObject("Driver1")
For i = 1 To 100
Set tag = obj.AddObject("IOTag", false)
tag.Name = "IOTag" & CStr(i)
tag.Activate
Next

Como mostrar uma mensagem na Tela ao alterar o valor de um Tag?


Criando um evento na Tela associado à propriedade Value do Tag, e que seja executado quando a propriedade
alterar o seu valor. Neste evento, utilize o método MsgBox para mostrar a mensagem.

Como criar uma Consulta com filtro por data antes de montar um Relatório?
Para isto, é necessário configurar o objeto Consulta (veja o capítulo Consulta) que acompanha o Relatório e criar as
variáveis necessárias na coluna Filtro. No evento de chamada de Relatório, use um script semelhante a este:
Set relatorio = Application.LoadReport("[Relatório1]")
Set consulta = Relatorio.Query()
Consulta.SetVariableValue "Variavel1", Valor1
Consulta.SetVariableValue "Variavel2", Valor2
Relatorio.PrintPreview()

Onde:
· [Relatório1] é o nome do Relatório a ser chamado
· Variavel1 e Variavel2 são as variáveis criadas no filtro do campo E3TimeStamp
· Valor1 e Valor2 são as datas a serem consultadas

Para verificar outros tipos de filtros, consulte o capítulo Consulta ou a documentação disponível no Elipse
Knowledgebase.

Como depurar erros de script no E3 Viewer e no servidor?


Caso o evento seja executado no E3 Viewer, utilize o método Trace do Viewer. Caso o evento seja executado no
servidor, utilize o método Trace do servidor.

Dúvidas Mais Frequentes 384


Matriz Filial em São Paulo
Rua Mostardeiro, 322/Cj. 902, 1001 e 1002 Rua dos Pinheiros, 870/Cj. 141 e 142
90430-000 — Porto Alegre — RS 05422-001 — São Paulo — SP
Fone: (+55 51) 3346-4699 Fone: (+55 11) 3061-2828
Fax: (+55 51) 3222-6226 Fax: (+55 11) 3086-2338
E-mail: [email protected] E-mail: [email protected]

Filial no Paraná Filial em Minas Gerais


Av. Sete de Setembro, 4698/1708 Rua Antônio de Albuquerque, 156/705
80240-000 — Curitiba — PR 30112-010 — Belo Horizonte — MG
Fone: (+55 41) 4062-5824 Fone: (+55 31) 4062-5824
E-mail: [email protected] E-mail: [email protected]

Filial no Rio de Janeiro Filial em Taiwan


Av. José Silva de A. Neto, 200/Bl. 4/Sl. 109B 9F., No.12, Beiping 2nd St., Sanmin Dist.
22775-056 — Rio de Janeiro — RJ 807 — Kaohsiung City — Taiwan
Fone Comercial: (+55 21) 2430-5912 Fone: (+886 7) 323-8468
Suporte Técnico: (+55 21) 2430-5963 Fax: (+886 7) 323-9656
E-mail: [email protected] E-mail: [email protected]

Consulte nosso website para informações sobre um representante no seu estado

www.elipse.com.br
kb.elipse.com.br
forum.elipse.com.br
www.youtube.com/elipsesoftware
[email protected]

Gartner, Cool Vendors in Brazil 2014, April 2014.


Gartner does not endorse any vendor, product or service depicted in its
research publications, and does not advise technology users to select only
those vendors with the highest ratings. Gartner research publications
consist of the opinions of Gartner’s research organization and should not
be construed as statements of fact. Gartner disclaims all warranties,
expressed or implied, with respect to this research, including any warranties
of merchantability of fitness for a particular purpose.

Você também pode gostar