Hi
nicht ganz - Modellflieger steuert man ja nicht mit dem PC...
Habe eine alte Fernsteuerung genommen, alles rausgeschmissen und eine neue Elektronik eingebaut, die die Steuerknüppel einliest und diese Werte an dem Prozessor im Modell sendet, der damit die Servos für die Ruder steuert...
Übertragung war auf 256 Schritte / Servoweg reduziert und wurde dann im Empfänger mit möglichen 1024 Schritten / Servoweg ausgegeben - so war Trimmung etc dann etwas feiner abgestuft.
Leider liegt der ganze Kram nun in der Ecke, da ich im vergangenen Sommer dort eine Fehlfunktion im Sender hatte, und noch keine Zeit da mal nach der Ursache zu suchen. Außerdem hab ich jetzt ja auch 1 gekaufte 2,4GHz Fernsteuerung, die ausgezeichnet funktioniert und auch diverse einstellbare Mischerfunktionen hat, an deren Programmierung in meiner eigenen Steuerung ich total gescheitert war...
Wie gesagt - eine PN und ich schick dir mal den Bascom-Code, mit dem du dann nur noch 1 Prozessor für die 18 Servos brauchst - wird nur 1 * 16 Bit Timer benötigt dafür.
Edith: für 18 Servos hab ich die Routine jetzt umgeschrieben - aber dafür wird dann der Mega 16 benötigt - Da du ja eh auf SMD gehen willst, ist das ja kein Problem, denn da ist er ja nur minimalst größer als der M8.
RS232 und I2C-Pins bleiben dabei auch noch frei benutzbar.
Für alle anderen hier der Code mit 5 Servos und 7 "Dummykanälen" als Word Variable:Code:$regfile = "m16def.dat" $crystal = 8000000 Config Porta = Output 'alle Pins voll belegt Config Portc = Output 'Pin 0 und 1 bleiben frei belegbar (I2C Bus) Config Portd = Output 'Pin 0 und 1 bleiben frei belegbar (RS232) ebenso Pin 6 und 7 sind noch frei Config Timer1 = Timer , Prescale = 8 Start Timer1 On Timer1 _timer1 Enable Timer1 Enable Interrupts Dim Aktservo As Byte 'Aktuelles Servo (ISR) Dim _aktservo As Byte 'Aktuelles Portpin für Servo (ISR) Dim Sk(18) As Word 'Servowertearray Dim Tempw(18) As Word 'temporären-Array mit den Werten für die 18 Servokanäle aus deinem Programm. Dim A As Byte '*init der Vars* Aktservo = 1 '***Hauptschleife*** Do For A = 1 To 18 'hier wird dem Servokanal (SK) der Wert übergeben Sk(a) = Tempw(a) 'mögliche Werte sind von 0 bis 1024; 512 ist Mitte Next Loop '*Interruptroutinen* _timer1: If Aktservo < 9 Then 'Servo 1-8 _aktservo = Aktservo - 1 'Pindefinition berechnen Porta._aktservo = 0 'dann Pin ausschalten Elseif Aktservo < 15 Then 'Servo 9-14 _aktservo = Aktservo - 7 'Pindefinition berechnen Portc._aktservo = 0 'dann Pin ausschalten Else 'Servo 15-18 _aktservo = Aktservo - 13 'Pindefinition berechnen Portd._aktservo = 0 'dann Pin ausschalten End If Incr Aktservo 'aktuelles Servo um 1 erhöhen If Aktservo = 19 Then 'Wenn alle 18 Servos durch sind Aktservo = 1 'aktuelles Servo auf 1 zurücksetzen End If If Aktservo < 9 Then 'Servo 1-8 _aktservo = Aktservo - 1 'neue Pindefinition berechnen Porta._aktservo = 1 'neues Pin anschalten Elseif Aktservo < 15 Then 'Servo 9-14 _aktservo = Aktservo - 7 'neue Pindefinition berechnen Portc._aktservo = 1 'neues Pin anschalten Else 'Servo 15-18 _aktservo = Aktservo - 13 'neue Pindefinition berechnen Portd._aktservo = 1 'neues Pin anschalten End If Timer1 = Sk(aktservo) + 63523 'Timer laden mit neuem Wert Return
Code:$regfile = "m8def.dat" $crystal = 8000000 Config Portb = Output Config Timer1 = Timer , Prescale = 8 Start Timer1 On Timer1 _timer1 Enable Timer1 Enable Interrupts Dim Aktservo As Byte 'Aktuelles Servo (ISR) Dim _aktservo As Byte 'Aktuelles Portpin für Servo (ISR) Dim Servo As Word 'Dummy für verarbeitung der 7 Dummyservokanäle für die Pausenzeit Dim Sk(12) As Word 'Servowertearray Dim Tempw(5) As Word 'temporären-Array mit den Werten für die 5 Servokanäle aus deinem Programm. Dim A As Byte '*init der Vars* Aktservo = 1 _aktservo = 0 For A = 6 To 12 'Dummykanäle der Pausenzeit auf 0 setzen Sk(a) = 0 Next '***Hauptschleife*** Do For A = 1 To 5 'hier wird dem Servokanal (SK) der Wert übergeben Sk(a) = Tempw(a) 'Werte sind von 0 bis 1024 wenn ich mich jetzt nicht total irre... Next 'ich glaube aber, daß ich nur bis 1020 übergeben habe Loop '*Interruptroutinen* _timer1: If Aktservo < 6 Then 'aktuelles Servo <6 ist noch der pin vom letzten einschalten... (wenn ausgaben an pins sollen) Portb._aktservo = 0 'dann Pin ausschalten Incr Aktservo 'aktuelles servo um 1 erhöhen Else 'wenn keine Pins mehr ( Pausenzeit ab servo 6) Servo._aktservo = 0 'Dann bit im Variable Servo ausschalten Incr Aktservo 'aktuelles servo um 1 erhöhen If Aktservo = 13 Then 'Wenn bei durchlauf 13 sind Aktservo = 1 'Aktuelles Servo Auf 1 Setzen End If End If _aktservo = Aktservo - 1 'da mit Portpin 0 anfangen - diese Variable eins niedriger If Aktservo < 6 Then 'Wenn im Bereich der Pins arbeiten Portb._aktservo = 1 'neues Pin anschalten Else 'ansonsten Servo._aktservo = 1 'Bit in Dummyvariable anschalten End If Timer1 = Sk(aktservo) + 63523 'Timer laden mit neuem Wert Return







Zitieren

Lesezeichen