sábado, 8 de maio de 2010

Navegando num formulário contínuo do Access...

... com a mesma facilidade do Excel.
Este código é de autoria do Jaques Zetune da ForumAccess.
Estou deixando aqui mais para consultas, pois as vezes eu preciso e não tenho à mão.
Não esquecer de colocar um checkbox com o nome chkNavegLoop, valor padrão 1.


;-)




Option Explicit

Const cDataSheet = 2, cContinuous = 1

Private Sub Form_Load()
Me.KeyPreview = True
End Sub

Private Sub Form_KeyDown(KeyCode As Integer, Shift As Integer)
DoKeys Me, KeyCode, Shift
End Sub

Public Sub DoKeys(wForm As Form, KeyCode As Integer, Shift As Integer)
Dim wCtl As Control, wIgnore As Integer
'a tecla Shift está pressionada ?
If Shift <> 0 Then Exit Sub
'o formulário está sendo visualizado em modo contínuo?
If wForm.CurrentView <> cDataSheet And wForm.DefaultView <> cContinuous Then Exit Sub

On Error Resume Next

Set wCtl = Screen.ActiveControl
'testa o comportamento da tecla Enter no controle
wIgnore = (wCtl.EnterKeyBehavior <> 0)
'verifica se a barra de rolagem está ativada If Not wIgnore Then wIgnore = (wCtl.ScrollBars <> 0)
'verifica se o controle em questão está com o texto “Ignore Setas” na propriedade Tag
'indicando que a intercepção de teclas deve ser ignorada no mesmo
If Not wIgnore Then wIgnore = (InStr(wCtl.Tag, "Ignore Setas") > 0)
If wIgnore Then Exit Sub
'sincroniza o registro corrente do formulário com o seu RecordsetClone
Me.RecordsetClone.Bookmark = Me.Bookmark

Select Case KeyCode
Case vbKeyDown
If Me.RecordsetClone.AbsolutePosition + 1 = Me.RecordsetClone.RecordCount And Me!chkNavegLoop Then
'tentou ir além do topo e a navegação em loop está ativa
DoCmd.GoToRecord , , acFirst
Else
DoCmd.GoToRecord , , acNext
End If
KeyCode = 0
Case vbKeyUp
If Me.RecordsetClone.AbsolutePosition = 0 And Me!chkNavegLoop Then
'tentou ir além do final e a navegação em loop está ativa
DoCmd.GoToRecord , , acLast
Else
DoCmd.GoToRecord , , acPrevious
End If
KeyCode = 0
End Select
End Sub



Um comentário:

Fabio disse...

Muito obrigado. Estava procurando outra coisa e acabou me ajudando no meu formulário
estou procurando um log de alterações num formulário continuo, mas para um campo sim/não

Abraço

Fabio

Pesquisar este blog

Arquivo do blog

Quem sou eu

Minha foto
Administrador de Empresas/Técnico em Processamento de Dados. Microsoft Office User Specialist - Excel Proficient. Pós-graduado em Business Intelligence.