Nesse vídeo demonstraremos a utilização da função Processa, que serve para criar uma tela com uma régua de processamento.
Abaixo o código fonte desenvolvido para o exemplo em vídeo acima:
//Bibliotecas
#Include "TOTVS.ch"
#Include "TopConn.ch"
/*/{Protheus.doc} User Function zExe393
Cria uma régua de processamento
@type Function
@author Atilio
@since 28/03/2023
@obs
Função Processa
Parâmetros
Bloco de Código a ser executado
Título da janela
Mensagem inicial da janela
Se será possível abortar o processo (.T.) ou não (.F.)
Retorno
Função não tem retorno
**** Apoie nosso projeto, se inscreva em https://www.youtube.com/TerminalDeInformacao ****
/*/
User Function zExe393()
Local aArea := FWGetArea()
Processa({|| fExemplo()}, "Filtrando...")
FWRestArea(aArea)
Return
Static Function fExemplo()
Local aArea := FWGetArea()
Local nAtual := 0
Local nTotal := 0
Local cQryAux := ""
//Executa a consulta
cQryAux := " SELECT " + CRLF
cQryAux += " BM_GRUPO, " + CRLF
cQryAux += " BM_DESC " + CRLF
cQryAux += " FROM " + CRLF
cQryAux += " " + RetSQLName("SBM") + " SBM " + CRLF
cQryAux += " WHERE " + CRLF
cQryAux += " BM_FILIAL = '" + FWxFilial('SBM') + "' " + CRLF
cQryAux += " AND SBM.D_E_L_E_T_ = ' ' " + CRLF
TCQuery cQryAux New Alias "QRY_AUX"
//Conta quantos registros existem, e seta no tamanho da regua
Count To nTotal
ProcRegua(nTotal)
//Percorre todos os registros da query
QRY_AUX->(DbGoTop())
While ! QRY_AUX->(EoF())
//Incrementa a mensagem na regua
nAtual++
IncProc("Analisando registro " + cValToChar(nAtual) + " de " + cValToChar(nTotal) + "...")
Sleep(100)
QRY_AUX->(DbSkip())
EndDo
QRY_AUX->(DbCloseArea())
FWRestArea(aArea)
Return
Bom pessoal, por hoje é só.
Abraços e até a próxima.