Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-10-2014, 12:26   #1
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Leggere resistenza tramite porta seriale

Ciao a tutti,

ho a disposizione due circuiti che possono avere i seguenti stati logici: aperto (resistenza infinita) e chiuso (resistenza che non supera i 300-400 ohm).

Ogni tot tempo devo controllare entrambi i circuiti e registrare sul pc lo stato di questi due circuiti. Secondo voi posso farlo direttamente tramite porta seriale utilizzando i giusti pin? ( Ho visto progetti che accendevano led applicati direttamente all'uscita della porta seriale, il programma nel mio caso dovrebbe fare qualcosa di molto simile, ma verificando che la corrente che transita superi un certo valore).

So che potrei comprare un arduino ma vorrei evitare, anche perchè dovrei finirlo più velocemente possibile.

Ringrazio tutti quelli che si interesseranno della questione!
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2014, 14:58   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
La tua idea e' quella di collegare i due circuiti a due segnali di handshake, tipo RI/CTS (e al pin 7, ovviamente)?
Non e' male, dovrebbe funzionare. Non so che ambiente usi ma normalmente hai a disposizione delle primitive per leggere lo stato di questi segnali.


Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Ciao a tutti,

ho a disposizione due circuiti che possono avere i seguenti stati logici: aperto (resistenza infinita) e chiuso (resistenza che non supera i 300-400 ohm).

Ogni tot tempo devo controllare entrambi i circuiti e registrare sul pc lo stato di questi due circuiti. Secondo voi posso farlo direttamente tramite porta seriale utilizzando i giusti pin? ( Ho visto progetti che accendevano led applicati direttamente all'uscita della porta seriale, il programma nel mio caso dovrebbe fare qualcosa di molto simile, ma verificando che la corrente che transita superi un certo valore).

So che potrei comprare un arduino ma vorrei evitare, anche perchè dovrei finirlo più velocemente possibile.

Ringrazio tutti quelli che si interesseranno della questione!
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 23-10-2014 alle 15:04.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2014, 17:45   #3
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da sottovento Guarda i messaggi
La tua idea e' quella di collegare i due circuiti a due segnali di handshake, tipo RI/CTS (e al pin 7, ovviamente)?
Non e' male, dovrebbe funzionare. Non so che ambiente usi ma normalmente hai a disposizione delle primitive per leggere lo stato di questi segnali.
Ciao, ho cercato in questi giorni ed ho trovato e testato proprio la soluzione da te suggerita, e funziona non bene, ma benissimo!

Riesco a gestire ben 5 entrate che possono essere gestite in modo passivo da dei semplici interruttori. Questi sono i rispettivi pin che si possono utilizzare a tal scopo:
  • CTS
  • DSR
  • CD
  • Ring
  • Break

In questo modo posso collegare un qualsiasi sensore elementare (anche il sensore di movimento di un allarme, immagino) direttamente alla porta seriale a costo zero (o meglio, al costo di un adattatore USB-seriale, ovvero 3-4 euro).

Per completezza e per chi leggesse segnalo che il framework .NET permette di ricevere gli eventi generati dal cambiamento dei pin sopra elencati scrivendo poche righe di codice.

Alla prossima
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2014, 19:57   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi

Per completezza e per chi leggesse segnalo che il framework .NET permette di ricevere gli eventi generati dal cambiamento dei pin sopra elencati scrivendo poche righe di codice.

Alla prossima
Complimenti!! Hai avuto davvero una bella idea.
Potresti scrivere un paio di righe sulla soluzione? Quali sono le primitive da chiamare in .NET per ottenere gli eventi?

ciao
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2014, 22:06   #5
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Complimenti!! Hai avuto davvero una bella idea.
Potresti scrivere un paio di righe sulla soluzione? Quali sono le primitive da chiamare in .NET per ottenere gli eventi?

ciao
Certo

L'evento PinChanged http://msdn.microsoft.com/it-it/libr...v=vs.110).aspx è il cardine del tutto. Dopo aver connesso l'oggetto SerialPort con .open(), ogni cambiamento di stato dei vari pin è notificato attraverso questo evento.

L'unica cosa in cui ho trovato "problemi" è che è possibile accedere sempre e comunque allo stato di ogni pin (Break, CDChanged, CtsChanged, DsrChanged) tranne il Ring, non so per qualche strano motivo. Lo stato di questo pin non è direttamente accessibile se non esclusivamente attraverso l'evento PinChanged.

L'oggetto che ho attaccato all'altro capo della porta seriale è un pluviometro basculante, e funziona che è una meraviglia
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2014, 07:43   #6
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Grande!!
Qui
http://stackoverflow.com/questions/1...lding-property
provano a dare una spiegazione della differenza di trattamento del Ring Indicator rispetto agli altri segnali. Onestamente non e' molto convincente...

A proposito: scusami se sono pedante, ma immagino che abbia settato la seriale prima di fare i tuoi test. Corretto?
La comunicazione seriale in generale non ha bisogno di questi segnali addizionali per poter comunicare, in teoria basterebbe un filo (e la massa).
Questi segnali addizionali vengono detti di hardware hanshake e permettono di informare la controparte se si e' pronti a spedire/ricevere e di controllare il modem.
Via software e' possibile abilitarli/disabilitarli. Potrei per esempio disabilitarli nel caso il DCE non e' in grado di gestirli (spesso pero' si fanno i cavallotti).
Tutta questa spataffiata per chiedere se sei sicuro di aver abilitato l'hardware handshake nel tuo software o se ti sei affidato ai valori di default, i quali potrebbero essere diversi da installazione a installazione...



Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Certo

L'evento PinChanged http://msdn.microsoft.com/it-it/libr...v=vs.110).aspx è il cardine del tutto. Dopo aver connesso l'oggetto SerialPort con .open(), ogni cambiamento di stato dei vari pin è notificato attraverso questo evento.

L'unica cosa in cui ho trovato "problemi" è che è possibile accedere sempre e comunque allo stato di ogni pin (Break, CDChanged, CtsChanged, DsrChanged) tranne il Ring, non so per qualche strano motivo. Lo stato di questo pin non è direttamente accessibile se non esclusivamente attraverso l'evento PinChanged.

L'oggetto che ho attaccato all'altro capo della porta seriale è un pluviometro basculante, e funziona che è una meraviglia
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2014, 14:33   #7
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Grande!!
Qui
http://stackoverflow.com/questions/1...lding-property
provano a dare una spiegazione della differenza di trattamento del Ring Indicator rispetto agli altri segnali. Onestamente non e' molto convincente...

A proposito: scusami se sono pedante, ma immagino che abbia settato la seriale prima di fare i tuoi test. Corretto?
La comunicazione seriale in generale non ha bisogno di questi segnali addizionali per poter comunicare, in teoria basterebbe un filo (e la massa).
Questi segnali addizionali vengono detti di hardware hanshake e permettono di informare la controparte se si e' pronti a spedire/ricevere e di controllare il modem.
Via software e' possibile abilitarli/disabilitarli. Potrei per esempio disabilitarli nel caso il DCE non e' in grado di gestirli (spesso pero' si fanno i cavallotti).
Tutta questa spataffiata per chiedere se sei sicuro di aver abilitato l'hardware handshake nel tuo software o se ti sei affidato ai valori di default, i quali potrebbero essere diversi da installazione a installazione...
Si, avevo già letto quella domanda di stackoverflow.

Il mio software è semplicissimo, tutto è relativo a valori di default dell'oggetto SerialPort e l'unica operazione che faccio prima di ricevere gli eventi è SerialPort.open(). Nient'altro, non ho abilitato niente! Mi sono meravigliato che fosse così semplice.

Probabilmente con altri cavi USB-serial e altri driver la situazione si potrebbe complicare.
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
La Cina lancia un servizio simile a Dire...
SpaceX: Elon Musk torna a parlare dei pr...
G.Skill risarcisce 2,4 milioni di dollar...
Test degli annunci su ChatGPT avviati: '...
TSMC approva investimenti record da quas...
L'IA agentica arriva anche sullo storage...
Euro digitale, il Parlamento UE cambia r...
Alphabet e la sua obbligazione centenari...
L'UE anticipa un intervento per bloccare...
Il Trump Phone esiste ma è molto ...
Frodi deepfake fuori controllo: perch&ea...
Consumano il 30% in meno: arrivano i nuo...
Tesla Semi svela i numeri definitivi: 80...
La Air Force statunitense vieta occhiali...
Wi-Fi Intel e Windows: le novità ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:16.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v