Skip to main content

Visual Basic Code in a Mimic Panel

Visual Basic is what is known as on Object Oriented Language, so you add Objects (Lines, Boxes, Shapes) to a form and then create some matching code which is executed when you Click (usually) on that object. 

The modified Form for the Points Program now looks like.

The objects on this form are Lines 1 and 2, Shapes 6 and 7 and a couple of Command Buttons called Clockwise and Anti Clockwise.  When we Click on Clockwise, then some code is executed.

This lot !!

Private Sub Clockwise_Click()
    MSComm1.Output = "C"                  ' Sends a "C" to the Arduino code which makes the Servo turn
    Clockwise.Enabled = False               ' Disables the "Clockwise" button so we can't press it by mistake
    Line2.BorderColor = &HC0C0FF    ' Changes Line 2 to a beige kind of colour
    Line1.BorderColor = &HC0C0FF    ' Does the same to line 1, which you can't really make out
    Shape7.FillColor = vbRed                 ' Changes the Signal (Shape7) from Green to Red
End Sub

At the end of the Arduino Code which rotates the Servo Clockwise, there's a line which looks like

   Serial.print("H"); delay(2000); Serial.write("h");

This sends an "H" back to the VB Program, pauses for a couple of seconds, then sends an "h".

This is the Code in the VB Program to receive the Input character and then carry out further code instructions depending on which character has been received.

Private Sub MSComm1_OnComm()                        'checks if something has happened at the Serial Port
    If MSComm1.CommEvent = comEvReceive Then      ' Checks to see if "something" is a receive
         inputchar = ""                                                           ' gets rid of anything left from beofre
         inputchar = MSComm1.Input                                 ' reads what character has just been received
            If inputchar = "H" Then Anticlock_Lines            ' If it is an "H" then go to a procedure called
                                                                                          '  Anticlock Lines    see below for what it's like.
            If inputchar = "h" Then Anticlock_Lights           ' Same idea
            If inputchar = "L" Then Clock_Lines
            If inputchar = "l" Then Clock_Lights
   End If
End Sub

Sub Anticlock_Lines()
      Line2.BorderColor = &H80FF80       'Changes the line colour to a kind of Beige
      Shape8.FillColor = vbRed                  ' Changes the Signal Colour to Red
      Line1.BorderColor = vbRed              ' Changes the Line1 colour to Red
      Line1.ZOrder (1)                               ' Brings line 1 to the top        (aesthetic appearance or the)
      Line2.ZOrder (0)                               ' Sends line 2 to the bottom  (overlap would look weird.)
End Sub

The complete Program

Private Sub EndProg_Click()
  MSComm1.Output = "E"
  End
End Sub

Private Sub Selectport_Click()
  On Error GoTo porterror
  portnumber = InputBox("Enter a number", "Choose Port 1 . . 8", 4)
  MSComm1.RThreshold = 1
  MSComm1.CommPort = portnumber
  MSComm1.PortOpen = True
  MSComm1.DTREnable = False
  MSComm1.Output = "X"
  Selectport.Visible = False
  EndProg.Visible = True
  Exit Sub
porterror:
  MsgBox ("Invalid Port Number" & Chr(13) & "Use numbers from 1 to 8")
End Sub

Private Sub AntiClock_Click()
  MSComm1.Output = "A"   ' Sends  A to Arduino (Anticlockwise)
  AntiClock.Enabled = False  ' VB Command to disable Anticlockwise Button
  MSComm1.Output = "g"       ' Sends  G  Switch on Green LED
  MSComm1.Output = "R"       ' Sends  r  Switch off Red LED
  Line1.BorderColor = &HC0C0FF
  Line2.BorderColor = &HC0C0FF
  Shape8.FillColor = vbRed
End Sub

Private Sub Clockwise_Click()
  MSComm1.Output = "C"
  Clockwise.Enabled = False
  Line2.BorderColor = &HC0C0FF
  Line1.BorderColor = &HC0C0FF
  Shape7.FillColor = vbRed
End Sub

Private Sub MSComm1_OnComm()
 If MSComm1.CommEvent = comEvReceive Then
   inputchar = ""
   inputchar = MSComm1.Input
     If inputchar = "H" Then Anticlock_Lines
     If inputchar = "h" Then Anticlock_Lights
     If inputchar = "L" Then Clock_Lines
     If inputchar = "l" Then Clock_Lights
 End If
End Sub

Sub Clock_Lines()
    Line2.BorderColor = vbRed
    Line1.BorderColor = &H80FF80
    Line1.ZOrder (0)
    Line2.ZOrder (1)
End Sub

Sub Clock_Lights()
    Shape8.FillColor = vbGreen
    AntiClock.Enabled = True
End Sub

Sub Anticlock_Lines()
      Line2.BorderColor = &H80FF80
      Shape8.FillColor = vbRed
      Line1.BorderColor = vbRed
      Line1.ZOrder (1)
      Line2.ZOrder (0)
End Sub

Sub Anticlock_Lights()
      Shape7.FillColor = vbGreen
      Clockwise.Enabled = True
End Sub

3 Pictures showing how some of the colours change and a video of the Servo working.
                      Before.                                     During                                         After  







Comments

  1. What are you using for serial communication between the PC and the Arduino?

    ReplyDelete

Post a Comment

Popular posts from this blog

3D Printing Presentation

Sunday's Zoom meeting had our largest audience so far with 19 members attending from various parts of the country. Alan Geekie gave us an excellent and well received presentation on 3D printing that included FDM (Fused Deposition Modeling) and SLA (Stereolithography apparatus) types He first showed how we can source "things to print" using sites like Thingiverse. His own filament printer was the Prusa i3 Mk 3S which is available either as a kit (£699) or pre-assembled (£899) and features a self leveling bed. It also benefited from an additional multi material upgrade kit and he demonstrated the start up sequence of leveling, homing, clearing remaining filament from the hot end and then beginning the print.  The process of slicing where a 3d object drawing file (.stl) is broken up into the x,y,z drawing coordinates for each individual layer was also explained. Alan then moved on to resin printers using another Prusa model, the SL1 and its associated curing and washing mach

Train sequence / timetable using Arduino

                              Following discussions in a MERG Zoom meeting about potential projects for the Cumbria virtual area group I have started this blog to share my ideas for building a train sequence / timetable system based on an Arduino UNO. The trigger for this project was Andy Robb's article in the MERG journal (June 2020 edition). In it Andy describes using an UNO with a OLED display to produce an electronic station display board.  Having tried out Andy's version I started thinking about expanding the idea and have come up the following list of possibilities: 1. Replace my card index train sequence with an electronic version. 2. Have the train sequence synchronised with the on platform displays. 3. Display an analogue clock on the station display and have it display the train times. 4. Store the position reached in the sequence so that it starts where it left off on power up.  To make the project of greater potential interest to other modellers the following

Arduino Book Recommendation

Welcome to the site which has been set up for all members of the Scottish Borders Group of MERG.  As you know, I have been working on various Arduino projects recently including the station and cafe displays.  There are many resources available online when you come across a problem but a good reference book which explains how things work is essential.  I have tried a few and found the following book the best so far. It is well written and laid out logically for the beginner to be able to develop new skills. The structure of the Chapters makes it easy to find the relevant section.   By clicking on the link below you will be able to look inside and see for yourself. https://amzn.to /38HfrWW If you decide to purchase through this link  you should be aware that I will receive a small commission on any sales generated which will help to finance further projects Andy R