Mudanças entre as edições de "Bibliotecas Gráficas"

De UniWiki
Ir para: navegação, pesquisa
Linha 180: Linha 180:
  
 
Esse formulário é a base dos forms utilizados no sistema unilab. A partir desse modelo são criados os três tipos de interface do sistema: Rel, Sel e Cad, Que por sua vez são herdadas nas interfaces da biblioteca R03.
 
Esse formulário é a base dos forms utilizados no sistema unilab. A partir desse modelo são criados os três tipos de interface do sistema: Rel, Sel e Cad, Que por sua vez são herdadas nas interfaces da biblioteca R03.
====constructor TFBase.Create(AOwner: TComponent);====
+
{| class="wikitable"
Todo formulário possui um componente com os eventos e dados referentes ao formulário. formulários mais especializados podem ter FormData especializados.  
+
|-
 +
|constructor TFBase.Create(AOwner: TComponent);||Todo formulário possui um componente com os eventos e dados referentes ao formulário. formulários mais especializados podem ter FormData especializados.  
  
 
A checagem do FormData é feita na constructor dos Forms. Além disso, este construtor cria o helptimer. O helptimer serve para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.
 
A checagem do FormData é feita na constructor dos Forms. Além disso, este construtor cria o helptimer. O helptimer serve para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.
  
====procedure FormClose(Sender: TObject; var Action: TCloseAction);====
+
|-
Evento para fechar o form e destruí-lo. Não entendi como funcionam as mensagens que ele procura e manda antes de fechar o form.
+
|procedure FormClose(Sender: TObject; var Action: TCloseAction);||Evento para fechar o form e destruí-lo. Não entendi como funcionam as mensagens que ele procura e manda antes de fechar o form.
  
====function FormHelp(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean;====
+
|-
Chama a ajuda relacionada à tela quando usuário pressiona F1. O arquivo de help deve estar no <path do executável>\<LibParam.ProgHelp>\<nome do form>.p. Se o arquivo não existir copia para ele o arquivo “<path onde esta o executável>\manunilab..p”. Por fim, executa o help.  
+
|function FormHelp(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean;||Chama a ajuda relacionada à tela quando usuário pressiona F1. O arquivo de help deve estar no <path do executável>\<LibParam.ProgHelp>\<nome do form>.p. Se o arquivo não existir copia para ele o arquivo “<path onde esta o executável>\manunilab..p”. Por fim, executa o help.  
 
*Obs: Utiliza o helptimer para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.
 
*Obs: Utiliza o helptimer para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.
  
====function  SearchMsg(s:string): TUMsg;====
+
|-
Procura pela mensagem - nil se nao encontrar. Chama o SearchMsg do PS do Form.
+
|function  SearchMsg(s:string): TUMsg;||Procura pela mensagem - nil se nao encontrar. Chama o SearchMsg do PS do Form.
  
====function  SearchMsgStarting(s:string): TUMsg;====
+
|-
Procura pela mensagem começando por s - nil se não encontrar. Chama o SearchMsgStarting do PS do Form.
+
|function  SearchMsgStarting(s:string): TUMsg;||Procura pela mensagem começando por s - nil se não encontrar. Chama o SearchMsgStarting do PS do Form.
  
====function  CreateMsg(pnome, pcs, pps: string;pforcenew:boolean=True): TUMsg;====
+
|-
Criação de mensagem de comunicação com outro processo. Chama o CreateMsg do PS do form.
+
|function  CreateMsg(pnome, pcs, pps: string;pforcenew:boolean=True): TUMsg;||Criação de mensagem de comunicação com outro processo. Chama o CreateMsg do PS do form.
  
====procedure CreateCall(pname,pcs,pps,pretorno:string;pmodal:boolean=False); overload;====
+
|-
Cria uma chamada a uma tela de seleção - CreateCall('nome','cs','ps','ret'). Chama uma tela de seleção. Se a tela já existir, dá foco nela.
+
|procedure CreateCall(pname,pcs,pps,pretorno:string;pmodal:boolean=False); overload;||Cria uma chamada a uma tela de seleção - CreateCall('nome','cs','ps','ret'). Chama uma tela de seleção. Se a tela já existir, dá foco nela.
  
====procedure CallCad(pmode: TModoCadastro;pname,pcs,pps:string;key:TUPars=nil; pmodal:boolean=False); overload;====
+
|-
Cria uma chamada a uma tela de CAD. Idêntico ao CreateCall, mas adicionado à possibilidade de definir o modo (inserção, alteração, exclusão) e os valores da  
+
|procedure CallCad(pmode: TModoCadastro;pname,pcs,pps:string;key:TUPars=nil; pmodal:boolean=False); overload;||Cria uma chamada a uma tela de CAD. Idêntico ao CreateCall, mas adicionado à possibilidade de definir o modo (inserção, alteração, exclusão) e os valores da chave.
  
====procedure Answer(pmsg: TUMsg); virtual;====
+
|-
tratamento das mensagens
+
|procedure Answer(pmsg: TUMsg); virtual;||tratamento das mensagens
  
====procedure DoAfterCreateForm;====
+
|-
apos a criar e mostrar o form
+
|procedure DoAfterCreateForm;||apos a criar e mostrar o form
  
====procedure DoAfterLoaded(pcalled:boolean);====
+
|-
apos a carregar o form, independente se direto ou por chamada msg (f2...)
+
|procedure DoAfterLoaded(pcalled:boolean);||apos a carregar o form, independente se direto ou por chamada msg (f2...)
  
====procedure DoAfterCreateMsg(pmsg:TUMsg);=====
+
|-
apos criar uma mensagem de ligacao com outro processo
+
|procedure DoAfterCreateMsg(pmsg:TUMsg);||apos criar uma mensagem de ligacao com outro processo
  
====procedure DoBeforeDestroy;====
+
|-
antes de destruir o PS
+
|procedure DoBeforeDestroy;||antes de destruir o PS
  
====procedure DoOnDoneUpdated(pdone:Extended);====
+
|-
o processo avancou
+
|procedure DoOnDoneUpdated(pdone:Extended);||o processo avancou
 
      
 
      
====property PS:TUPS read FPS write FPS default nil;====
+
|-
qual instancia de processo e dono do form
+
|property PS:TUPS read FPS write FPS default nil;||qual instancia de processo e dono do form
  
====procedure Confirm(pclose:boolean=False);====
+
|-
Confirma a execucao do processo. Metodo chamado pelo programador para confirmar o form e chamar o processo que o form executa - no evento OnProcess do FormData.
+
|procedure Confirm(pclose:boolean=False);||Confirma a execucao do processo. Metodo chamado pelo programador para confirmar o form e chamar o processo que o form executa - no evento OnProcess do FormData.
  
====procedure Cancel(pclose:boolean=True);====
+
|-
cancela a execucao do processo
+
|procedure Cancel(pclose:boolean=True);||cancela a execucao do processo
  
====property  Done:extended read GetDone write SetDone;====
+
|-
Informa o quanto o processo esta pronto (%)
+
|property  Done:extended read GetDone write SetDone;||Informa o quanto o processo esta pronto (%)
  
====procedure PSDestroy(pmsg: TUMsg); virtual;====
+
|-
o PS que comunicava pela mensagem enviada foi destruido
+
|procedure PSDestroy(pmsg: TUMsg); virtual;||o PS que comunicava pela mensagem enviada foi destruido
  
====property  Msg[s:string]: TUMsg        read GetMsg;====
+
|-
====property  Processing  : boolean      read FProcessing;====
+
|property  Msg[s:string]: TUMsg        read GetMsg;|| ?
 +
 
 +
|-
 +
|property  Processing  : boolean      read FProcessing;|| ?
 +
 
 +
|}
  
  
 
===USys===
 
===USys===

Edição das 17h03min de 12 de maio de 2011

Desenvolvendo interfaces com a Biblioteca Uniware

Esse guia tem por funcionalidade auxiliar o desenvolvedor na programação de interfaces utilizando a biblioteca da Uniware.

É importante observar que esse artigo não aborda a instalação dos componentes gráficos. Para isso, visite Instalação Delphi



Getting Started

Nesse capítulo podem ser encontrados materiais referentes ao desenvolvimento do unilab para quem está começando.

Banco de dados

Toda alteração no banco de dados é replicada na função TFAtualiza@Ver_Ultimas.

Em casos de views, é necessário escreve-las em:

  • TFAtualiza@CreateViews;
  • TFAtualiza@DropViews.

Criando interfaces

Acessando os templates

Os templates de interface da Uniware encontram-se em Arquivo > Novo... > aba 'UNIWARE_BETA'. utilize os templates:

  • FBaseSelR03;
  • FBaseCadR03;
  • FBaseRelR03.

R03 é a biblioteca de componentes visuais que a Uniware utiliza em seus templates e o tipo varia de acordo com a necessidade, como explicado abaixo:

Ao criar uma unit, adicionar o tipo ao sufixo:

  • Sel, Listagem de registros;
  • Cad, Manipulação de dados;
  • Rel, Referentes aos relatórios.

Será necessário adicionar ao uses a unit UFMain, para integrar-se com o projeto todo.

Já no uses da interface, as principais bibliotecas a serem adicionadas são Ulib e ULibR03

A Unit, ao ser criada, possui uma parte do código assim:

var
  Form1: TForm1;

No projeto essa parte é desnecessária, visto que o FMain realiza a instanciação das interfaces de outra forma.

Componentes disponíveis da lib. R04

Ao apagar o código acima de uma unit, remover do programa UNILAB_BETA a criação automática da interface, como na linha:

  Application.CreateForm(TForm1, Form1);



Propriedades da Interface

O capítulo a seguir identifica possíveis problemas que o programador pode encontrar ao desenvolver suas primeiras interfaces. Relevando as propriedades principais:

TFBase???R03

??? pode-se interpretar como 'Cad' ou 'Sel'.

Dentro da unit UFMain, adicionar o PS (Se necessário, adicionar um CS próprio) para gerenciamento da interface a ser criada.

Desabilite a propriedade BorderIcons.biHelp, pois não disponibilizamos o help por interfaces, ainda.

FormStyle = fsMDIChild, não me lembro bem o objetivo, mas é necessário.

Para ser instanciado, é necessário adicionar aos eventos do TUPS???:

Result := NOME_CLASSE;

No evento do click do Menu, para abrir a interface Sel, sua interface deve ser chamada utilizando UMenuCall('nomeCS','nomePS');

ps. Quando a tela não for da biblioteca, utilizar ChamaForm(TIPO_FORM);

TUQuery

Componente TUQuery
  • Nome Default: Q;
    • Generico: Essa propriedade define a consulta a ser utilizada;
    • SQL, SQLIB, SQLMS, SQLMySQL e SQLORACLE: consulta destinada à um tipo de banco. SQL deve ser configurada caso seja determinado Generico = true;
    • TabelaPrincipal: Deve conter o nome da tabela utilizada no SQL, em interfaces SEL, é comum o uso de Views para essa consulta;
    • TabelaPrincipalAlias: Caso a tabela possua um alias na SQL, ele deve ser informado aqui;
    • UDataBase: referencia FMain.UDB que é a database do sistema.

TDataSource

CompDS.png
  • Nome Default: DS;
    • UQuery: Esse campo deve estar referenciado para o componente anteriormente descrito, Q.

TUDataEntry

Componente TUDataEntry
  • Nome Default: DE;
    • Limite: Determina a quantidade máxima de cadastros de detalhes;
    • LinhasVisiveis: Define quantos campos aparecem abaixo do edit de detalhe (inclusive);
    • UCadastro:Precisa referenciar o TUCadastro associado à grid;
    • UDataSource: Esse campo deve estar referenciado para o componente anteriormente descrito, DS;
    • UDataEntry: Quando for utilizar relações mestre-detalhe na interface, o Data Entry responsável pelo detalhe referencia o Data Entry do mestre.
    • UsaScrollBar: Necessário quando o numero de 'Limite' ultrapassa 'LinhasVisiveis'.

TUDataEntry

CompCAD.png
  • Nome Default: CAD;
    • UDataEntry: Esse campo deve estar referenciado para o componente anteriormente descrito, DE.

Para poder trabalhar as configurações visuais da grid, como largura da coluna, propriedades de leitura, etc.

Use o RightClick nesse componente e selecione colunas da grid de procura.

(Você acessa a coluna individualmente buscando a propriedade Columns da DBGridP)

TUField

Para acessar os Campos do dataset, DoubleClick o componente de Query.
Exemplo de uma interface de QFields
  • Nome Default: Q concatenado do mesmo nome da coluna do banco;
    • Campo: Qual campo do banco ele representará;
    • ChavePrimaria: Identificar a PK da tabela;
    • Edicao: Indica o componente visual que edita esse valor;
    • Filtra: Habilita o campo a ser uma chave no botão Filtra;
    • NaNavegacao: Define se a coluna aparecerá na Grid;
    • Ordena: Permite o usuário Ordenar os resultados utilizando a coluna como parâmetro, é obrigatório no mínimo 1 dos campos ser True;
    • PreencheChave: Em uma situação mestre-detalhe, esse parâmetro permite que seja inserido no campo a chave primária do mestre;
    • Procura: Habilita a procura de valores na coluna pelo botão Procura;
    • Tabela: Indica a qual tabela o campo pertence;
    • TabelaAlias: Preenchido caso a tabela possua alias;
    • Titulo: valor a ser apresentado no cabeçalho da coluna;

TUFBase???R03Data

CompData.png
??? pode-se interpretar como 'Cad' ou 'Sel'.
  • Nome Default: ???Data;
    • No SelData:
      • CallCadModal: Não permite que seja aberta mais de uma tela de Cad;
      • CallCs: Nome do CS que gerenciará essa interface (UFMain);
      • CallPs: Identificar o processo da interface (UFMain);

TUOrdemCombo

Question.png
(Esse é um componente Invisível)
  • Nome Default: OC;
    • AliasInicial: Coluna definida para que o edit possa fazer uma busca;

TUEdit ou outras formas de input

Caso o componente esteja referenciando um CODI, Alterar:

  • AJCod - Preenche o campo com zeros;
  • MaxLength - Define o tamanho máximo do campo.


Problemas Conhecidos

Abaixo estão listadas algumas peculiaridades da biblioteca (problemas ou bug's) que podem impedir o bom funcionamento tanto do software em si quanto o ambiente de programação.

O campo CODI

A biblioteca, hoje, trabalha a chave primária como string, e somente com esse tipo de dados;

Além disso, ela suporta um limite de nove caracteres, e para uma melhor visualização, a Uniware preenche os valores com zeros à esqueda.

Recarregando o DataSource

Quando for alterado alguma estrutura do banco de dados, será necessário recarregar o datasource da interface caso ela esteja aberta.

Para isso, alterar algum campo da interface e fechar/abrir novamente a unit. (Há casos que não é necessário a alteração da propriedade)

Remover um campo calculado

Ao remover um campo calculado da lista de TUFields, nenhum outro registro é selecionado.

Se o programador selecionar alguma interface sem antes selecionar um campo da lista,

o Delphi encerrará acusando um erro.


Outros componentes importantes

Talvez você não os use, mas é importante registrar aqui outros componentes da biblioteca para futuras consultas:


UFBase

Esse formulário é a base dos forms utilizados no sistema unilab. A partir desse modelo são criados os três tipos de interface do sistema: Rel, Sel e Cad, Que por sua vez são herdadas nas interfaces da biblioteca R03.

constructor TFBase.Create(AOwner: TComponent); Todo formulário possui um componente com os eventos e dados referentes ao formulário. formulários mais especializados podem ter FormData especializados.

A checagem do FormData é feita na constructor dos Forms. Além disso, este construtor cria o helptimer. O helptimer serve para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.

procedure FormClose(Sender: TObject; var Action: TCloseAction); Evento para fechar o form e destruí-lo. Não entendi como funcionam as mensagens que ele procura e manda antes de fechar o form.
function FormHelp(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean; Chama a ajuda relacionada à tela quando usuário pressiona F1. O arquivo de help deve estar no <path do executável>\<LibParam.ProgHelp>\<nome do form>.p. Se o arquivo não existir copia para ele o arquivo “<path onde esta o executável>\manunilab..p”. Por fim, executa o help.
  • Obs: Utiliza o helptimer para evitar que o usuário abra várias vezes o help pressionando F1 várias vezes.
function SearchMsg(s:string): TUMsg; Procura pela mensagem - nil se nao encontrar. Chama o SearchMsg do PS do Form.
function SearchMsgStarting(s:string): TUMsg; Procura pela mensagem começando por s - nil se não encontrar. Chama o SearchMsgStarting do PS do Form.
function CreateMsg(pnome, pcs, pps: string;pforcenew:boolean=True): TUMsg; Criação de mensagem de comunicação com outro processo. Chama o CreateMsg do PS do form.
procedure CreateCall(pname,pcs,pps,pretorno:string;pmodal:boolean=False); overload; Cria uma chamada a uma tela de seleção - CreateCall('nome','cs','ps','ret'). Chama uma tela de seleção. Se a tela já existir, dá foco nela.
procedure CallCad(pmode: TModoCadastro;pname,pcs,pps:string;key:TUPars=nil; pmodal:boolean=False); overload; Cria uma chamada a uma tela de CAD. Idêntico ao CreateCall, mas adicionado à possibilidade de definir o modo (inserção, alteração, exclusão) e os valores da chave.
procedure Answer(pmsg: TUMsg); virtual; tratamento das mensagens
procedure DoAfterCreateForm; apos a criar e mostrar o form
procedure DoAfterLoaded(pcalled:boolean); apos a carregar o form, independente se direto ou por chamada msg (f2...)
procedure DoAfterCreateMsg(pmsg:TUMsg); apos criar uma mensagem de ligacao com outro processo
procedure DoBeforeDestroy; antes de destruir o PS
procedure DoOnDoneUpdated(pdone:Extended); o processo avancou
property PS:TUPS read FPS write FPS default nil; qual instancia de processo e dono do form
procedure Confirm(pclose:boolean=False); Confirma a execucao do processo. Metodo chamado pelo programador para confirmar o form e chamar o processo que o form executa - no evento OnProcess do FormData.
procedure Cancel(pclose:boolean=True); cancela a execucao do processo
property Done:extended read GetDone write SetDone; Informa o quanto o processo esta pronto (%)
procedure PSDestroy(pmsg: TUMsg); virtual; o PS que comunicava pela mensagem enviada foi destruido
property Msg[s:string]: TUMsg read GetMsg;  ?
property Processing  : boolean read FProcessing;  ?


USys