B4R Question Washing machine control using esp8266

Cesar_Morisco

Active Member
Licensed User
Longtime User
Hello everyone
I am designing a washing machine control using esp8266
and the 3-pin encoder I have some problems with the menu function getting stuck
Here is the code
Could anyone tell me what is blocking the menu?
Thanks

B4R:
'Ctrl+Click to open the C code folder: ide://run?File=%WINDIR%\System32\explorer.exe&Args=%PROJECT%\Objects\Src
Sub Process_Globals
    Public Serial1 As Serial
    Private wifi As ESP8266WiFi
    Private server As WiFiServerSocket
    Private astream As AsyncStreams
    Private timer1 As Timer
    Private timer2 As Timer
    'Private timer3 As Timer
    Private ssd As AdafruitSSD1306
    Private ESPin As D1Pins
    Private LED As Pin
    Private BUZZ As Pin
    Private Relays As Int = 9
    Private Registers(Relays) As Boolean
    Private DS,STCP,SHCP As Pin
    Private bc As ByteConverter
    Private onewire As OneWire
    Private ssd As AdafruitSSD1306
 

    Dim Sensor_Pres As Pin
    Dim Start As Pin
   
    Dim EncoderPinA As Pin
    Dim EncoderPinB As Pin
    Private LastStateTime As Long = 0
   
    Private Counter As Int = 5
End Sub


Private Sub AppStart
    Serial1.Initialize(115200)
    Log("AppStart")
'  
'    ' Inicializa os pinos como entrada
    EncoderPinA.Initialize(9, EncoderPinA.MODE_INPUT_PULLUP) ' Inicializa o botão 1 com pull-up interno
    EncoderPinB.Initialize(10, EncoderPinB.MODE_INPUT_PULLUP)' Inicializa o botão 2 com pull-up interno
    EncoderPinA.AddListener("EncoderPinA_Changed")'Enconder de 3 pinos
    Sensor_Pres.Initialize(ESPin.D3,Sensor_Pres.MODE_INPUT_PULLUP) 'Inicializa o botão 3 com pull-up interno
    Start.Initialize(ESPin.D4,Start.MODE_INPUT_PULLUP) 'Inicializa o botão 4 com pull-up interno
   
   
    ssd.InitializeI2C(ESPin.D6,0x3C)            'initialise SSD1306 0x78
    LED.Initialize(ESPin.D7,LED.MODE_OUTPUT)
    BUZZ.Initialize(ESPin.D8,BUZZ.MODE_OUTPUT)
   
   
    BUZZ.DigitalWrite(True)
    Delay(100)
    BUZZ.DigitalWrite(False)
    LED.DigitalWrite(False)
   
    DS.Initialize(ESPin.D0,DS.MODE_OUTPUT)      'HS Pin 11 Serial In     ESP D6 GPIO 12
    STCP.Initialize(ESPin.D5,STCP.MODE_OUTPUT)  'HS Pin 12 RCK           ESP D5 GPIO 14
    SHCP.Initialize(ESPin.D6,SHCP.MODE_OUTPUT)  'HS Pin 14 Serial Clock  ESP D7 GPIO 16
    'Clear Register Values
    ClearAllReg
   
    ssd.InitializeI2C(ESPin.D6,0x3C)            'initialise SSD1306 0x78
    ssd.ClearDisplay
    ssd.GFX.SetCursor(0, 0)
    ssd.GFX.ConfigureText(1, ssd.WHITE, False)
    ssd.GFX.DrawText("Inicializando...").DrawText(CRLF).DrawText(CRLF)
    ssd.Display
   
    'example of connecting to a local network
    If wifi.Connect2("..........................","..................................") Then
        Log(wifi.LocalIp)
        ssd.ClearDisplay
        ssd.GFX.SetCursor(0, 0)
        ssd.GFX.ConfigureText(1, ssd.WHITE, False)
        ssd.GFX.DrawText("Conectado Wifi").DrawText(CRLF).DrawText(CRLF)
        ssd.Display
       
        Delay(2000)
       
        ssd.ClearDisplay
        ssd.GFX.SetCursor(2,0)
        ssd.GFX.ConfigureText(1,ssd.WHITE,False)
        ssd.GFX.DrawText("IP:")
        ssd.GFX.DrawText(wifi.LocalIp)
        ssd.Display
        LED.DigitalWrite(True)
    Else
        Log("Falha ao se Conectatr.")
        Return
    End If
   
    onewire.Initialize(ESPin.D4)
    timer1.Initialize("Menu",100) 'Menu de função
    timer1.Enabled = True
    timer2.Initialize("Start_Ente",200) 'Start Enter

    server.Initialize(80, "server_NewConnection")
    server.Listen

End Sub

Private Sub Server_NewConnection (NewSocket As WiFiSocket)
    Log("Cliente Conectado")
    astream.Initialize(NewSocket.Stream, "astream_NewData", "astream_Error")
End Sub

Sub astreamCom_Error
    Log("error")
End Sub

Sub Astream_NewData (Buffer() As Byte)
    Log(Buffer)
    Dim value As String = bc.StringFromBytes(Buffer)
    Select value
        Case "CMDA"
            Log("OI BONITÃO")
    End Select
    WriteToReg
End Sub

Sub AStream_Error
    Log("Desconectado")
    server.Socket.Close
    server.Listen
End Sub

' Método chamado quando o pino A do encoder muda de estado
Sub EncoderPinA_Changed (State As Boolean)
    Dim StateTime As Long = Millis()
    If StateTime - LastStateTime > 200 Then 'Only run if statechange firing interval is larger than 50ms, adjust to suit
        If EncoderPinB.DigitalRead Then Counter = Counter - 1 Else Counter = Counter + 1 'Adjust the counter +-1
        Counter = Min(21, Max(4, Counter)) 'Limit the counter between 0 and 100
        LastStateTime = StateTime 'Store last state time
        Log("Position: ", Counter)
    End If
End Sub

Sub Menu'Ligar  o Menu  Timer 1
   
    Select Counter
        Case 5
            Log("Menu 1")
            ssd.ClearDisplay
            ssd.GFX.SetCursor(2,0)
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("PROGRAMAS:")
            ssd.GFX.SetCursor(2,18)'18
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("PESADO")
            ssd.Display
            If Start.DigitalRead = False Then ' Botão pressionado (leitura é LOW devido ao pull-up)
                timer2.Enabled = True 'Botão  Start Enter
            End If
        Case 10
            Log("Menu 2")
            ssd.ClearDisplay
            ssd.GFX.SetCursor(2,0)
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("PROGRAMAS:")
            ssd.GFX.SetCursor(2,18)'18
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("NORMAL")
            ssd.Display
            If Start.DigitalRead = False Then ' Botão pressionado (leitura é LOW devido ao pull-up)
                timer2.Enabled = True 'Botão  Start Enter
            End If
        Case 15
            Log("Menu 3")
            ssd.ClearDisplay
            ssd.GFX.SetCursor(2,0)
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("PROGRAMAS:")
            ssd.GFX.SetCursor(2,18)'18
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("RAPIDO")
            ssd.Display
            If Start.DigitalRead = False Then ' Botão pressionado (leitura é LOW devido ao pull-up)
                timer2.Enabled = True 'Botão  Start Enter
            End If
        Case 20
            Log("Menu 4")
            ssd.ClearDisplay
            ssd.GFX.SetCursor(2,0)
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("PROGRAMAS:")
            ssd.GFX.SetCursor(2,18)'18
            ssd.GFX.ConfigureText(2,ssd.WHITE,False)
            ssd.GFX.DrawText("DIA A DIA")
            ssd.Display
            If Start.DigitalRead = False Then ' Botão pressionado (leitura é LOW devido ao pull-up)
                timer2.Enabled = True'Botão  Start Enter
            End If
    End Select

End Sub
Sub Start_Ente'Start Enter Timer 2
    timer1.Enabled = False'Menu
    ssd.ClearDisplay
    ssd.GFX.SetCursor(2,0)
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("PESADO.")
    ssd.GFX.SetCursor(2,18)'18
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("Tempo 1:03")
    ssd.Display
    Registers(1) = True 'Abrir Valvola
    WriteToReg
    Delay(600)
    If Sensor_Pres.DigitalRead = False Then ' Botão pressionado (leitura é LOW devido ao pull-up)
        Lavagem_Normal
        Registers(1) = False'Abrir Valvola
        WriteToReg
    End If
End Sub
'
Private Sub Lavagem_Normal()
    ssd.ClearDisplay
    ssd.GFX.SetCursor(2,0)
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("Lavendo.")
    ssd.GFX.SetCursor(2,18)'18
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("Aguarde...")
    ssd.Display
    Registers(1) = False'Fechar Valvola
    WriteToReg
    Delay(3000)
       
        For i = 0 To 20
        Registers(2) = True 'Ligar Motor
        WriteToReg
        Delay (200) 'Delei de 2 Mile Segundos
        Registers(2) = False 'Desligar Motor
        WriteToReg
        Delay (200) 'Delei de 2 Mile Segundos
        Registers(3) = True 'Ligar Motor
        WriteToReg
        Delay (200) 'Delei de 2 Mile Segundos
        Registers(3) = False'Desligar Motor
        WriteToReg
        Delay (200) 'Dele de 2 segundo
        Next
       
        Delay(10000)  'PAUSA DE 1 SEGUNDO
               
        For i = 0 To 20
        Registers(2) = True 'Ligar Motor
        WriteToReg
        Delay (200) 'Delei de 2 Mile Segundos
        Registers(2) = False 'Desligar Motor
        WriteToReg
        Delay(200) 'Delei de 2 Mile Segundos
        Registers(3) = True 'Ligar Motor
        WriteToReg
        Delay (200) 'Delei de 2 Mile Segundos
        Registers(3) = False'Desligar Motor
        WriteToReg
        Delay (200) 'Dele de 2 segundo
        Next
    Centrifugar
End Sub

Private Sub Centrifugar()
    ssd.ClearDisplay
    ssd.GFX.SetCursor(2,0)
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("Centrifugando.")
    ssd.GFX.SetCursor(2,18)'18
    ssd.GFX.ConfigureText(2,ssd.WHITE,False)
    ssd.GFX.DrawText("Aguarde...")
    ssd.Display
    Registers(4) = True 'Ligar Motor do dreno
    WriteToReg
    Delay(6000)'Aguardar
    Delay(6000)'Aguardar
    Registers(3) = True 'Ligar Motor esquerdo
    WriteToReg
    Delay(6000)
    Delay(6000)
    Registers(4) = False 'Desligar Motor do dreno
    WriteToReg
    Registers(3) = False'Desligar Motor esquerdo
    WriteToReg
    For  I = 0 To 5 'LIGAR O BUZZER DEPOIS DE TERMINA A LAVANGEM
        BUZZ.DigitalWrite(True)
        Delay(200)
        BUZZ.DigitalWrite(False)
        Delay(200)
        BUZZ.DigitalWrite(True)
        Delay(200)
        BUZZ.DigitalWrite(False)
    Next
    timer1.Enabled = True  'Voltar para o menu
    timer2.Enabled = False 'Desligar Start Enter
End Sub

'Write To Registers
Private Sub WriteToReg()
    STCP.DigitalWrite(False)
    Dim i As Int = 0
    Do While i <= Relays - 1
        SHCP.DigitalWrite(False)
        DS.DigitalWrite(Registers(i))
        SHCP.DigitalWrite(True)
        i = i + 1
    Loop
    STCP.DigitalWrite(True)
End Sub

'Clear All Registers
Private Sub ClearAllReg()
    Dim i As Int = Relays - 1
    Do While i >= 0
        Registers(i) = False 'True = NO
        i = i - 1
        WriteToReg
    Loop
End Sub


 
Cookies are required to use this site. You must accept them to continue using the site. Learn more…