PDA

Archiv verlassen und diese Seite im Standarddesign anzeigen : Bitmanipulation



m1cha
08.09.2013, 16:01
Hallo,

ich habe mehrere LED-Matrizen bekommen und habe sie mit Schieberegistern (Zeilen und Spalten) angesteuert. Zur Ansteuerung benutze ich erstmal die erweiterung M32 vom RP6. Dort benutze ich SPI und schreibe erst die Spalten-Bits und dann die Zeilen und ausgeben. Funktioniert super.

Jetzt meine Fragen, ich habe mir natürlich vorgenommen eine Laufschrift zu programmieren. Ja, ich weis das gibt es schon mehrfach.
Ich dacht mir ich erstelle Variablen für jede Zeile zwei Stück. Eine als Init-Variable (Inhalt z.B. 0b00000000...) und eine als Ausgangsvariable die dann auf die entsprechende Zeile geschrieben wird.
Die Buchstaben/Zahlen würde ich auch ein Variablen speichern. Nun dachte ich mir ich nehme die Init-Var. und "ver-oder" die Bits mit den der Buchstaben und schreibe das Ergebnis in die Ausgangs-Var.
z.B. Zeile1aus = Zeile1int | Zeile1buchstabe;
Aber wie mache ich das, wenn Zeile1int und Zeile1aus z.B. 32Bit lang sind, der Buchstabe 8Bit und ich den Buchstaben an eine ganz bestimmte Stelle schreiben will? (z.B. nur Bits 10-17 mit den 8Bits des Buchstaben überschreiben)
Und ist meine Überlegung für die Programmierung eines Lauflichts richtig? Ich habe nur bedenken wenn ich die großen Matrixen (16x96) ansprechen will. Denn ich denke das ein ATmega32 nicht mit eine Variable die 96Bitstellen hat umgehen kann.

Ich hoffe auf eure Hilfe, denn mit diesem "Projekt" will ich mich in µC und die C einarbeiten, da ich bis jetzt "nur" alle Scriptsprachen durch habe. Mit Spriptsprachen habe ich schon mal eine Punkt-Matrix auf dem Bildschirm gezaubert und hatte dort auch die von mir beschriebenen Variablen genutzt.

Gruß m1cha

shedepe
09.09.2013, 11:55
Du könntest z.b. deine 8Bit variable in eine 32 bit Variable casten. Also z.b. so:


uint8_t meineVar = 34;
uint32_t mein2Var = (uint32_t)meineVar;

und dann per bitshift an die passende Stelle verschieben. Z.b. so:


meine2Var = meine2Var << 8;

oberallgeier
09.09.2013, 12:46
Hi m1cha,

hoffentlich treffe ich Dein Problem.

... Zeile1aus z.B. 32Bit lang ... Buchstabe 8Bit und ... an eine ganz bestimmte Stelle schreiben ...Ich hatte das in meinen PingPong-Projekten gemacht - Bits abfragen, setzen und löschen. Ungefähr so:

// - - - - - - - - - - - - - - -
//#define SetL (xk,y) ( L[xk] |= ((uint16_t)1 << (y))
// Setzt Bit
volatile uint16_t L[20]; // LED-Reihe 1 bis 10, Rest ist Dummy
// ...
// - - - - - - - - - - - - - - -
// Jetzt altes Rack links löschen und neues setzen
cli(); //
lPr = RKL_POSa ; // Positioniere auf alten LED-Platz
L[lPr] &= ~((uint16_t)1<<15); // Lösche LEDBit lPr (rechtes Poti)
L[lPr-1] &= ~((uint16_t)1<<15); // Lösche LEDBit lPr-1
// - - - - - - - - - - - - - - -
lPr = RKL_POSn + 12; // Unterkante NEUES, rechtes Rack
L[lPr] |= ((uint16_t)1<<15); // Setze LEDBit lPr (rechtes Poti)
L[lPr-1] |= ((uint16_t)1<<15); // Setze LEDBit lPr-1
RKL_POSa = lPr; // Neuwert ist bereits alt
sei(); //// ...
// - - - - - - - - - - - - - - -
Sind nicht sooo lange LED-Bitmuster wie bei Dir, aber das System sollte passen.

Dazu könne man natürlich z.B. mit den Defines

#define SetBit(ADDR,BIT) ((ADDR) |= (1<<(BIT))) // Setzt Bit
#define ClrBit(ADDR,BIT) ((ADDR) &= ~(1<<(BIT))) // Löscht Bit
#define IsBitSet(ADDR,BIT) (((ADDR) & (1<<BIT))?1:0) // Fragt Bit = 1?
#define IsBitClr(ADDR,BIT) ((!(ADDR) & ~(1<<BIT))) // Fragt Bit = 0das "Schiebegeschäft" bequem und übersichtlich erledigen. ABER - meine Laufschrift ist wegen anderer Projekte in den Kinderschuhen stecken geblieben.