[ Kiter @ 07.04.2008. 22:35 ] @
Imam uređaj koji se spaja na com port, dakle, relej sa 8 'dioda' - kad je recimo 1. upaljen, onda 1. svijetli i tako redom do 8 :)

Ne mogu preko visual basica zadati naredbu da ukljuci 2 te žaruljice odjednom, već samo jednu.
A to ide preko neke varijable recimo:

a$ = chr(3) + chr(0) + chr(0) + chr(3) ---> to je recimo da se upali 1. dioda

b$ = chr(3) + chr(1) + chr(0) + chr(6) ---> to je recimo da se upali 2. dioda

- onda ovu varijablu (recimo a$) saljem na mscomm. komponentu (koja se povezuje preko com porta na uređaj) i upali se 1. dioda

Ali ne mogu istovremeno upalit obadvije! Ako pošaljem ove dvije varijable, pročita prvih 4 znakova i opet zasvijetli prva i dalje ništa.
Kako to riješiti?
[ stefanpn @ 07.04.2008. 23:54 ] @
Na 3, 0, 0, 3 se pali prva, a na 3, 1, 0, 6 druga...

Imas li semu tog uredjaja, ili bar neko uputstvo?

Moras znati zasto se za paljenje jedne diode salje 4 bajta.

Jer da je tako jednostavno slao bi se samo jedan bajt i sa njim bi se pokrile sve kombinacije. Za svaki bit po jedna dioda, ukupno 256 kombinacija.

Moja predpostavka je da je 3 - signal za inicijalizaciju ili promenu stanja, jer se javlja u oba primera.

Sad samo jos da se provali za sta sluze ostala 3 bajta.

Mogao bi da nam postavis i kombinacije za ostale diode, mozda se nesto da i zakljuciti iz toga.
[ dava @ 08.04.2008. 07:28 ] @
Da dobro bi bilo da posaljes i ostale kombinacije. Moguce je recimo da se sa trecim bajtom koji je 0 gase ostale diode pa zato ne mozes upaliti dve od jednom.
Probavaj razne kombinacije i prati.
[ Kiter @ 08.04.2008. 08:16 ] @
Evo ovako, jucer sam napisao one chr$ za primjer, a evo i tocnih:
Code:

If led = "0" Then send$ = Chr$(3) + Chr$(0) + Chr$(0) + Chr$(3): GoTo prikaz
If led = "1" Then send$ = Chr$(3) + Chr$(1) + Chr$(1) + Chr$(3): GoTo prikaz
If led = "2" Then send$ = Chr$(3) + Chr$(1) + Chr$(2) + Chr$(0): GoTo prikaz
If led = "3" Then send$ = Chr$(3) + Chr$(1) + Chr$(4) + Chr$(6): GoTo prikaz
If led = "4" Then send$ = Chr$(3) + Chr$(1) + Chr$(8) + Chr$(10): GoTo prikaz
If led = "5" Then send$ = Chr$(3) + Chr$(1) + Chr$(16) + Chr$(18): GoTo prikaz
If led = "6" Then send$ = Chr$(3) + Chr$(1) + Chr$(32) + Chr$(34): GoTo prikaz
If led = "7" Then send$ = Chr$(3) + Chr$(1) + Chr$(64) + Chr$(66): GoTo prikaz
If led = "8" Then send$ = Chr$(3) + Chr$(1) + Chr$(128) + Chr$(130): GoTo prikaz
prikaz:
MSComm1.Output = send$


Znači, ukoliko je led = "0" onda su sve diode ugašene. Ako je 1 onda je 1. dioda upaljena i tako do 8.
Ja trebam dobit da se dvije zajedno upale (kao što sam i prije napomenuo).

U uputstvima (koje sada ne mogu naci) je ispisan ovaj program dolje i koliko znam, nista konkretno ne pise.

A ovo je program koji sam dobio sa uređajem, preko njega sam i dosao do tih chr$. Uglavnom, cini mi se da ovaj program u jednom slucaju upali nekoliko lampica zajedno (ne mogu ovo sa sigurnoscu reci jer ne mogu isprobati program - kao da je kompjuteru prebrz :) isprobao sam ga pred par godina na drugom kompjuteru):
Code:


CLS: CLEAR
DIM inbuf(800)
DIM outbuf(8)
OPEN "com2:19200,n,8,1,bin,cs,ds" FOR RANDOM AS #1

'----- INTERRUPT SERIAL INTERFACE ON -----
COM(2) ON
ON ERROR GOTO BADCOM
ON COM(2) GOSUB GETFRAME

'----- INITIALIZE RELAIS BOARD -----
PRINT "INITIALIZE BOARD"
outbuf(0) = 1: outbuf(1) = 1: outbuf(2) = 0: GOSUB sendframe
FOR delay = 1 TO 1000000: NEXT: CLS

'----- SWITCH RELAIS -----
teststart:
r = 1
rt:
outbuf(0) = 3: outbuf(1) = 1: outbuf(2) = r: GOSUB sendframe
FOR delay = 1 TO 1000000: NEXT: CLS
r = r * 2: IF r < 256 THEN GOTO rt
GOTO teststart

'||||| SERIAL COMMUNICATION |||||
'---------------------------------
'----- READ 4 BYTE DATAFRAME -----
'---------------------------------
GETFRAME:
inbuf(bz) = ASC(INPUT$(1,#1))
bz = bz + 1
IF bz = 4 THEN GOTO checkframe
RETURN
'----- CHECK VALIDITY -----
checkframe:
ERROR$ = "ERROR"
IF inbuf(0) XOR inbuf(1) XOR inbuf(2) = inbuf(3) THEN
ERROR$ = "OK"
bz = 0: PRINT "RECEIVED:"; "  "; inbuf(0); "  "; inbuf(1); "  "; inbuf(2); "  "; inbuf(3); "  "; ERROR$
PRINT "-----------------------------------------------------------------": RETURN
END IF
'---------------------------------
'----- SEND 4 BYTE DATAFRAME -----
'---------------------------------
sendframe:
outbuf(3) = outbuf(0) XOR outbuf(1) XOR outbuf(2)
send$ = CHR$(outbuf(0)) + CHR$(outbuf(1)) + CHR$(outbuf(2)) + CHR$(outbuf(3))
PRINT #1, send$
PRINT "TRANSMITTED: "; "  "; outbuf(0); "  "; outbuf(1); "  "; outbuf(2); "  "; outbuf(3)
RETURN

'***** ERROR HANDLER *****
BADCOM:
PRINT "----- DATA ERROR -----"
RESUME
RETURN

ende:
END



I još nešto:
Code:

send$ = Chr$(3) + Chr$(1) + Chr$(1) + Chr$(3) -----> pali 1. diodu
send1$ = Chr$(3) + Chr$(1) + Chr$(128) + Chr$(130) -----> pali 8. diodu
MSComm1.Output = send$
MSComm1.Output = send1$



- ovaj kod bi trebao upaliti prvu diodu i osmu diodu, međutim, upali samo 1. diodu... ali pokušao sam stavit jednostavnu petlju kojom mu napravim neki delay, recimo ovako:
Code:

send$ = Chr$(3) + Chr$(1) + Chr$(1) + Chr$(3)
MSComm1.Output = send$

For i = 1 To 100000000
Next i

send1$ = Chr$(3) + Chr$(1) + Chr$(128) + Chr$(130)
MSComm1.Output = send1$

- onda pali 1. diodu, ceka cirka 2 sekunde i upali 8. diodu (ali 1. diodu ugasi)

Došao sam do zaključka da on sa jednim chr$ gasi sve ostale diode (što ste i vi pretpostavili), tj. barem se nadam da je tako, sada još treba otkriti koji je to chr$, jer sam vec sve probao izmjeniti i ne mogu to dobiti. Hvala!



Skuzio sam nest, hmm...

Code:

send$ = Chr$(3) + Chr$(1)
MSComm1.Output = send$


Kada ucitam ovu funkciju dva puta, onda pali prve dvije diode. A dalje sad ne znam :)

A mogu i zadat ovako:
Code:

send$ = Chr$(3) + Chr$(1) + Chr$(3) + Chr$(1)

---------> moze biti i send$ = Chr$(3) + Chr$(0) + Chr$(3) + Chr$(0)


Onda pali prve dvije odmah :) Trazim dalje... ako tko ima prijedlog, neka napise!

[Ovu poruku je menjao Aleksandar Ružičić dana 08.04.2008. u 16:27 GMT+1]
[ djpero.84 @ 08.04.2008. 11:11 ] @
Probaj ovako:
Code:

send$ = "0"
MSComm1.Output = send$

sta si sad dobio?

[Ovu poruku je menjao Aleksandar Ružičić dana 08.04.2008. u 16:28 GMT+1]
[ Kiter @ 08.04.2008. 11:15 ] @
Na ovo ne trza uopce, ne pali ni jednu! A niti ne gasi nista.
[ djpero.84 @ 08.04.2008. 11:33 ] @
Samo mi reci koji port pokreces i koliko diodica imas pa cu ti dati drugaciji prijedlog.
[ Kiter @ 08.04.2008. 11:37 ] @
Com2, napisao sam vec gore da relej ima 8 diodica. Ja trebam dobit da se 2 istovremeno upale, ali one koje ja zadam (recimo 1. i 4., pa 5. i 8.).

Sa programom koji sam dobio sa uređajem mogu palit sve diodice, i odjednom vise njih (to nije program koji sam gore naveo, vec neki njihov .exe s kojim mozes jednostavno slozit skriptu kak ce se palit sta, ali meni bas treba u visual basicu jer imam neke dodatne funkcije).
[ djpero.84 @ 08.04.2008. 12:17 ] @
Nadji na internetu "port.dll" ili "port32.dll" ucitas ga, deklarises outport i inport funckije. Takodje imas i "inpout32.dll". Evo ti link

http://logix4u.net/Legacy_Port...for_Windows_98/2000/NT/XP.html

Sluzi i za Com port, samo upisi adresu Com porta
[ Kiter @ 08.04.2008. 12:33 ] @
Da li mi mozes malo konkretnije objasniti kako se s ovim radi? Ne kuzim bas :) Hvala! Sada isprobavam...

Nasao sam adresu com2 porta (valjda) i upisao i ispise mi 255. Hm:) Sto sad dalje?

[Ovu poruku je menjao Kiter dana 08.04.2008. u 13:44 GMT+1]
[ djpero.84 @ 08.04.2008. 13:42 ] @
Ako je 255, onda ti on vraca da su sve upaljene ali vjerovatno to nije tako.....

Standardna adresa tvog COM1 porta 3F8

- udji u BIOS i pogledaj konfiguraciju portova, i tamo ces naci na koji IRQ i Adresu ti je dodjeljen COM2, ako taj koristis.

onda upisi tu adresu (bez &H) u textbox1 i pritisni "IN" i dobices status. Tako ces skontati koji ti broj odgovara izlazu/ulazu na COM portu,
[ Kiter @ 08.04.2008. 14:31 ] @
Hm, u biosu sam samo nasao 2F8/IRQ3 --> za com2 port. I sad upisem taj 2F8 i pritisnem IN i dobijem '255'. A gdje si uzeo da bi uopce morao biti taj &H, tj. da upisem bez toga, jer ja nisam uopce niti naisao na to.
[ djpero.84 @ 08.04.2008. 14:42 ] @
Da, bez toga upisi, zavisno od ploce, jer se inace adresa tako pise ...... upisi samo "2F8". Skini te ledove sa Com porta, pa pokusaj ponovo, morao bi ti dati vrijednost 0
[ stefanpn @ 08.04.2008. 15:17 ] @
0 = 3, 0, 0, 3
1 = 3, 1, 1, 3
2 = 3, 1, 2, 0
3 = 3, 1, 4, 6
4 = 3, 1, 8, 10
5 = 3, 1, 16, 18
6 = 3, 1, 32, 34
7 = 3, 1, 64, 66
8 = 3, 1, 128, 130

Moja predpostavka je da je brvi bajt za promenu stanja, drugi za broj sijalica, treci pokazuje na sijalice, ali cetvrti mi i nije bas najjasniji za sta sluzi, ali je u vecini slucajeva to 3 bajt uvecan za 2.

Jedna od navedenih kombinacija bi trebala da upali prvu i osmu sijalicu:

3, 2, 129, 131

3, 1, 129, 131

Code:

128  64  32  16  8   4   2   1
 o   o   o   o   o   o   o   o

128  64  32  16  8   4   2   1
 x   o   o   o   o   o   o   x = 129

128  64  32  16  8   4   2   1
 x   x   x   x   x   x   x   x = 255


Treci bajt racunas tako sto sabiras vrednosti iznad sijalica koje zelis da upalis!

S tim da je vrednost 1 verovatno iznad prve sijalice s' desne strane, u suprotnom ti vrednosti idu od 1 do 128 umesto od 128 do 1.

Mislim da nema potrebe za citanje com porta, sve komande tom uredjaju mozes poslati i preko MSCOMM, koji je i mnogo jednostavniji za koriscenje od API f-ja.
[ Kiter @ 09.04.2008. 11:04 ] @
3, 1, 129, 131

Pali 1. i 8. diodu.

Veliko hvala!!
Sad moram racunat, ak mi nesto ne bude jasno se javim :)
[ Kiter @ 09.04.2008. 11:42 ] @
Ajd molim te, malo pojasni ovo racunanje, ne mogu sad izracunat recimo za 2. i 5. heh:))
Otkud 131 na kraju? Kuzim da je to treci bajt uvecan za 2, ali pogledaj:

3, 1, 130, 132
- ovo bi trebalo upaliti 2. i 8. diodu jel? Ali nista se ne desava. Hmm...

Ako zbrajam se desne strane, onda pali sve po redu, recimo:
3, 1, 240, 242
- pali 5,6,7,8 diodu

--------------------------------------------
Skuzio sam sad:
znaci
3, 1, 132, 134
- pali 3. i 8. diodu

3, 1, 130, 128 (jer je tamo kod 2. diode na kraju 2, 0 - pa sam ovaj 130 umanjio za 2 i radi)
- pali 2. i 8. diodu

[Ovu poruku je menjao Kiter dana 09.04.2008. u 13:14 GMT+1]

[Ovu poruku je menjao Kiter dana 09.04.2008. u 13:17 GMT+1]
[ Kiter @ 09.04.2008. 12:40 ] @
Nakon 'otkrića' kako se dvije diode pale istovremeno, naisao sam na novi problem:)

Imam datoteku sadrzaja:
01081214

Ovu datoteku ovako ucitavam u visual basic:
- prve dvije znamenke ucita u textbox1, znaci 01 (što predstavlja prvu diodu koja se mora upaliti)
- druge dvije znamenke ucita u textbox2, znaci 08 (što predstavlja drugu diodu koja se mora upaliti)
- sljedece dvije znamenke oznacavaju koliko sekundi mora biti upaljena prva dioda (ucitam u textbox3)
- i zadnje dvije znamenke oznacavaju koliko sekundi mora biti upaljena druga dioda (ucitam u textbox4)

Problem je, kako zadati sad funkciju da recimo, istovremeno se upale 1. i 8. dioda (u ovom slucaju), te da se nakon 12 sekundi ugasi prva dioda, a nakon 14 sekundi ugasi druga dioda bez prekidanja određene diode?




[ stefanpn @ 09.04.2008. 14:34 ] @
3, 1, 129, 132

Pa posle 12 sekundi:

3, 1, 128, 130

a zatim za gasenje:

3, 0, 0, 3

Znaci nema gasenja, nego uvek postavljas novo stanje...
[ stefanpn @ 09.04.2008. 20:17 ] @
Zaboravih da ti kazem da ako hoces da stopiras program na neko vreme nije pametno da stavis iteraciju koja ce ti napraviti zauzece procesora od 100% i biti zavisna od brzine masine na kojoj se izvrsava, vec probaj to da resis sa TIMER-om ili sa API f-jom Sleep ili SleepEx iz KERNEL32.DLL.

Znaci ne:
Code:

For i = 0 to 1000000
Next i


nego:
Code:

' U globalnim deklaracijama
Private Declare Function SleepEx Lib "kernel32" (ByVal dwMilliseconds As Long, ByVal bAlertable As Long) As Long
' i u programu
SleepEx 1000, False ' gde je 1000 = vreme za koje hoces da stopiras izvrsenje u milisekundama


[ Kiter @ 10.04.2008. 12:34 ] @
Ok, sve razumijem, i ubacio sam ovaj timer za pauzu i radi sve.

E sad jos samo moram to isprogramirat. Nemam bas ideje kako poceti, posto imam 4 textboxa (opisana u gornjem slucaju). Sada bih morao sa 'IF' naredbom ispitati sve moguce situacije ili postoji kakva bolja ideja? Jer ono if textbox1 = "01" and textbox2 = "02" then ukljuci_prvu_i_drugu_diodu mi se ne cini bas pametno:) a jos tu treba i sekunde ubaciti...
[ galahad @ 10.04.2008. 14:10 ] @
Ok, vidim nateraliste da to radi... Sorry shto nisam naleteo ranije...

Imam malo iskustva sa radom sa hardverom na COm portu, i koliko sam skontao, to je neki standard u komunikaciji...

Kada se neshto shalje, potrebno je da uredjaj zna odakle pochinje da chita, i dokle je jedna komanda... Postoje razlichite varijante, ali recimo, ono sa chim sam ja radio je bilo u obliku Chr$(3) [komanda] Chr$(2)

ASCII 3 oznachava pochetak transmisije, a ASCII 2 oznachava kraj... Sve izmedju je komandna kobasica (tako smo zbali to :))

E, sad, ovaj uredjaj prihvata komande duzhine 4 bajta, i bez ASCII 2... Ok... Uzmimo za primer sledetju liniju:
Code:
If led = "5" Then send$ = Chr$(3) + Chr$(1) + Chr$(16) + Chr$(18): GoTo prikaz


Chr$(3) oznachava pochetak komande
Chr$(1) verovatno oznachava komandu UPALI
Chr$(16) mu dodje LED 5
E sad, Chr$(18) je cheksum, koji se rachuna na klasichan nachin XOR-ovanjem prva 3 bajta komande... Tako kontroler diodica, zna da je komanda ispravna Dakle 3 XOR 1 XOR 16 = 18

E sad, kad hotjesh da palish neke diode, idesh po ovom obrascu:
LED1 = 1
LED2 = 2
LED3 = 4
LED4 = 8
LED5 = 16
LED6 = 32
LED7 = 64
LED8 = 128

E sad, recimo hotjesh diode 2, 3 i 7 upaljene... Nema neke teshke filozofije, to uradish tako shto postavljash 2, 3 i 7 bit na 1, ovako:
Code:

Dim upali as byte
upali = 2 Or 4 Or 64

Posle taj bajt dodash onoj kobasici, i voila, radi... Mozhesh da chuvash trenutno stanje, pa da palish i gasish diode po potrebi... Menjanje stanja bita radish sa XOR... Tako da bi:
Code:

upali = upali XOR 4

ugasilo LED3

Mislim da tje ovo da ti pomogne sa dilemom... Nema IF-ova, nema njackanja, samo prosta manipulacija bitovima... A uz to, i kratji i pregledniji kod :)

Vichi ako negde zapne...
[ stefanpn @ 10.04.2008. 14:25 ] @
@Galahad
Mislim da smo to vec utvrdili

BTW: Mozda si trebao da procitas thread do kraja...

[Ovu poruku je menjao stefanpn dana 10.04.2008. u 15:42 GMT+1]
[ galahad @ 10.04.2008. 15:48 ] @
@stefanpn
Prochitao sam do kraja celu temu, ali mi se chinilo da ste reshili to vishe na silu nego po logici... Izvinjavam se ako sam pogreshno protumachio... A mozhda tje josh nekom biti interesantno da vidi kako se manipulishe sa bitovima...

A i chovek je lepo pitao kako da reshi kad ima text boxove i vrednosti u njima, a ja sam napisao kako da to uradi bez iIF-ova, nego samo da te vrednosti prebaci u broj, i odradi u jednom redu kod...
[ Kiter @ 10.04.2008. 17:33 ] @
Ok, hvala svima:) Budem sada nesto isprobao, pa cu se javiti ako nest ne bude jasno. Pozdrav!
[ Kiter @ 11.04.2008. 09:12 ] @
Galahad, sad isprobavam ovo kako si ti opisao, ali ne znam gdje dodati sad taj byte 'upali'. Kojoj 'kobasici' to moram dodati?
[ stefanpn @ 11.04.2008. 14:01 ] @
1. Ne verujem da jednostavni uredjaj kao ovaj ima u sebi ASCII tabelu, tako da se CHR$(3) koristi zbog toga sto MSCOMM kontrola podrzava samo ANSI slanje podataka. Uredjaj to cita kao vrednost 3.

2. Nije 2 za prekid komunikacije, jer se uvek salje po 4 bajta. Kod fiksne duzine nema razloga da postoji vrednost za prekid prenosa.

Za checksum se slazem.

Citat:
E, sad, ovaj uredjaj prihvata komande duzhine 4 bajta, i bez ASCII 2... Ok... Uzmimo za primer sledetju liniju


Za ovo se ne slazem jer uredjaj prihvata i bajtove sa vrednoscu 2.

Sem toga koliko sam ja shvatio taj uredjaj ima samo komandu za gasenje i komandu za promenu stanja koja kao atribut ima stanje na koje se menja. Jebiga ipak je to 8 segmentni led display, vise od toga mu i ne treba.

Znaci vrednost koju saljes kao treci bajt je zbir vrednosti bitova, gde ti bitovi vrede:

Code:

128  64  32  16  8   4   2   1
 x   x   x   x   x   x   x   x


znaci saljes: 3, 1, treci_bajt, 3 xor 1 xor treci_bajt

A koliko sam ja shvatio, ovo je ta kobasica: "1, treci_bajt, 3 xor 1 xor treci_bajt"
[ rgdrajko @ 12.04.2008. 19:02 ] @
Preporucujem da pogledas http://www.bitwisemag.com/copy/vb/vb1.html. Tamo imas sve detaljno u vezi com porta.

Code:
Communicating - the basics 

Serial communication is a heart quite a simple idea. There are three pins that are important. Data is transmitted over one pin (Transmit Data or TXD for short) and received over another pin (Receive Data or RXD). The data is sent sequentially as a series of on-off pulses down the wire, so a byte will take eight bits or pulses to transmit. In fact, there are one or two other bits needed as well for synchronisation and error checking, but that’s the basics. The third wire that’s needed is the Ground wire (GND) – these are electrical signals and so need a return path. While you can get away with just three wires, it’s often useful to have other control signals to make things easier for the software. There are six other signals: Ring Indicator (RI) is set by a modem when it detects an incoming call. Carrier Detect (CD) is again set by the modem when it detects another modem as the originator of the incoming call. For a null-modem, RI and CD can are ignored.

This leaves four other signals which come in pairs. Request To Send (RTS) and Clear To Send (CTS) are used by the PC to signal that it is ready to write or read data respectively. Data Terminal Ready (DTR) and Data Set Ready (DSR) do a similar sort of job (there are actually finer details of what these signals should be used for – but that needn’t bother us here). So for our null-modem purposes there are three pairs of wires – and these need to be ‘crossed over’ for the two ports to communicate. That is, the RCD pin of one port must be connected to the TXD pin of the second and so on. This means that when COM1 transmits data (on TXD) COM2 will receive data on RCD. The complete wiring between the two connectors looks like:COM1     COM2
RCD     2     TXD     3 
TXD     3     RCD     2 
DTR     4     DSR     6 
GND     5     GND     5 
DSR     6     DTR     4 
RTS     7     CTS     8 
CTS     8     RTS     7 


If you’re confident with a soldering iron you can get the parts separately and wire them up or if you’d rather leave it to an expert, get a ready made cable – though check out the type of ports of the back of your PC first. Older PCs tend to have one 25 pin port and one 9 pin port – all of the above wiring refers to the more modern 9-pin varieties.

OK, so assuming you’re equipped with a suitable null-modem cable and you’ve plugged it into the two ports what next? One way to check that everything is working OK is to use two HyperTerminal sessions, one connected to COM1 the other to COM2 with exactly the same speed settings. You should be able to type from one screen to the other with no trouble. Another way (more interesting, of course!) is to use a Visual Basic program.

I’ve written a simple program using mostly the default settings of the two communication ports to illustrate how events are communicated back to Visual Basic. In the program COMMS.VBP, there are two text boxes that display the input received on the respective port and two sets of buttons that toggle DTR and RTS. There’s also an Initialize button that opens the ports and sets off a polling loop. The code initially sets COM1 and COM2 up in a similar manner with both RTS and DTR off:
With MSComm1
    .DTREnable = False
    .RTSEnable = False
    .CommPort = 1
    .PortOpen = True
End With

Once set up the program just polls for input:
Do While MSComm1.PortOpen And MSComm2.PortOpen
    s1 = MSComm1.Input
    s2 = MSComm2.Input
    If s1 <> "" Then
        Port2.Text = Port2.Text & s1
    ElseIf s2 <> "" Then
        Port1.Text = Port1.Text & s2
    Else
        DoEvents
    End If
Loop

There are two things to notice about this simple loop. First, the loop condition tests to see if the ports are still open. If you don’t do this, you will get an annoying error when you close the program. For some reason, Visual Basic seems to close the ports before unloading the form. Secondly, the DoEvents keyword ‘releases’ the program to look for other things – such as a button click or a communication event. 

In the DTR (and RTS) toggle code, you’ll see this:
With MSComm1
    .PortOpen = False
    If .DTREnable = False Then
        .DTREnable = True
    Else
        .DTREnable = False
    End If
    .PortOpen = True
End With 

These communication events (DSR corresponding to DTR and CTS corresponding to RTS) events are detected in the OnComm event code:
Private Sub MSComm1_OnComm()
   EventLog.Text = EventLog.Text & "Port1: " _
       & CommEventText(MSComm1.CommEvent) & vbCrLf
End Sub 

and just written to the EventLog window.

All this looks pretty neat and simple but there’s a ‘gotcha’: to set a control signal (say, RTS) you have to close the port, set RTS and then reopen it. This is disastrous if you are communicating with some hardware that isn’t really a modem – you can lose data in the small interval while the port is closed.

The problem is that the operating system uses these control wires to signal to the modem that your program is ready (that’s the main use of DTR) and it uses the RTS/CTS wires to implement hardware flow control. Normally, you’d be quite happy with this – but not if you want to control your patent dog-walker (or train set) directly. I’ll look at this next month.