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.