Loading...
  Show Posts
Pages: 1 ... 73 74 [75] 76 77 ... 87
1111  International / Deutsch / Re: Ich blicke nicht mehr durch on: February 25, 2012, 12:46:33 pm
Code:
if (millis() - startzeit >20000){// nach 20 sec wird ausgeschaltet
   // merker zeigt letzte PIR- Auslösung an, unten true, oben false
   if(merker) down_off(); else up_off();
 }
Da ist der Aufruf von "down_off()" bei dem vorher kein "Jetzt" kommt.
Dein Automat (http://de.wikipedia.org/wiki/Endlicher_Automat), hat den Zustand "last_unten == 1" oder  "status_unten == 0", daher ist die Bedingung
Code:
  if(last_unten == 0 && status_unten == 1 ){ // IR unten regisitriert jemanden
    Serial.println("Jetzt");
    ...
nicht erfüllt und das "Jetzt" wird nicht ausgegeben. Das passiert in Deiner loop immer wieder. Irgendwann sind dann die 20 Sekunden rum, und der Code für die Zeitregelung greift. Da aber vorher irgendwann "merker=true" gesetzt wurde, wird halt "down_off()" aufgerufen. Das sollte dann genau der beobachtete Effekt sein.
1112  International / Deutsch / Re: Ermitteln, wann die Waschmaschine fertig ist? on: February 25, 2012, 12:32:40 pm
Poste doch mal ein Foto vom Drehschalter, vielleicht kommt uns dann die zündende Idee.
Evtl. kannst Du ja einen kleinen Magneten an das Drehknopf packen und an den diversen Endpunkten einfach Reedkontakte oder Hallsensoren den Stand messen.
Vorteil wäre, das Du berührungslos messen kannst. Ist der Magnet stark genug, muss der Abstand auch nicht so super klein sein.
1113  International / Deutsch / Re: Ich blicke nicht mehr durch on: February 25, 2012, 08:38:05 am
Hmm, kann man so erstmal nicht erkennen. Poste mal das ganze Programm.
1114  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [GELÖST] on: February 24, 2012, 10:27:24 am
Prima, dann war meine Vermutung also doch richtig. Und das Verbinden den beiden GNDs war genau das, was ich mit "Masse verbinden" in einem der oberen Posts meinte. Die Masse muss nur dann nicht verbunden werden, wenn Du eine komplette galvanische Trennung wie z.b. bei einem Relais oder einem Optokoppler hast.
Schön das wir helfen konnten und das auch noch zwischen 11 AM und 4 PM  smiley-lol
1115  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [GELÖST] on: February 24, 2012, 09:53:50 am
Sagst Du uns auch noch wo der Fehler lag und wie Du ihn behoben hast? Das wäre toll, dann können alle was daraus lernen.
1116  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 08:57:24 am
Das Dein LED-Beispiel funktioniert, liegt wohl einfach daran, das Dein MOSFET eine integrierte Freilauf-Diode besitzt (laut Datenblatt) und daher ein Strom von Source in Richtung Drain fliessen kann. Ich vermute das Beispiel war ein PWM Beispiel, daher ist die LED dabei nicht gestorben, denn sie hat immer nur kurze Impulse bekommen.
1117  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 08:29:48 am
Und wo hast Du diese Schaltung her? Du treibst sowohl die LED als auch das Gate des MOSFET ohne Vorwiderstand. Das ist auf Dauer eigentlich nicht gut.
Laut Datenblatt ist außerdem Pin1 des MOSFET das Gate. Gezählt werden die Pins von rechts nach links, wenn der MOSFET vor Dir liegt, mit dem Pins nach unten und der metallenen Rückseite nach unten.
Wenn das Bild nicht gerade spiegelverkehrt aufgenommen wurde, ist bei Dir das Arduino Pin an "Source" , "Drain" mit der LED in Reihe an Masse und das "Gate" an +5V des Arduino angeschlossen.
Normalerweise kommt das Arduino-Pin an den GATE Anschluss des MOSFET, die Last kommt an die Drain-Seite und Masse an Source.
In deinem Fall wäre die Last das Masse-Kabel das von der LED-Leiste kommt und "Masse" wäre dann die Kabelseite die zum LED-Controller führt.

ACHTUNG!! Das basiert auf der Annahme, das dein weisses Kabel tatsächlich die gemeinsame Masse der LEDs ist. Es kann auch die gemeinsame Spannungsquelle sein und die einzelnen LED-Adern die jeweilige Masse der LEDs. Dann wäre die Beschaltung anders herum.
 
1118  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 07:50:25 am
Wie kommst du auf die Beschaltung des MOSFET? Einfach nur irgendwie angeschlossen, oder hast Du ein Datenblatt?
1119  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 07:21:45 am
Quote
Warte einen moment für die Zeichnung
*rofl*  smiley-grin (der war gut)
Ja, das sollte funktionieren. Damit Du mit dem MOSFET schalten kannst, müssen am Ende Arduino-Masse und Controller-Masse verbunden sein.
Poste mal die Typenbezeichnung des FET.
1120  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 07:06:05 am
Ich habe nochmal einen Blick auf das Bild geworfen. Stimmt es, das Du  das Kabel zwischen LED-Controller und LED-Leiste durchtrennt hast, dann die einzelnen Adern der 3 Farben wieder miteinander verbunden hast und nur das "vermutlich" gemeinsame Masse-Kabel aller 3 Farben steuern (unterbrechen) willst?
Der Controller ist also weiterhin für die Farben zuständig, nur das Du durch unterbrechen der Masseverbindung die LED-Leiste blinken lassen willst?
1121  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 07:01:42 am
Sorry für die Zeiten, das AM und PM hab ich tatsächlich nicht gesehen. Es waren also mehr al 1,5 Stunden, davon die meiste Zeit aber mitten in der Nacht  smiley
Kannst Du bitte mal aufmalen wie die Schaltung mit dem MOSFET und dem Transistor ausgesehen hat? Aus Deiner Beschreibung werde ich leider nicht ganz schlau.
Mario.
1122  International / Deutsch / Re: Stroboskop (12 V) simpel Ansteuern [Problem] on: February 24, 2012, 06:35:13 am
Quote
So, da immer noch keiner geantwortet hat hab ich mir mal die Mühe gemacht und ein Foto geschossen.
Hmm, sehr geduldig bist Du nicht, oder? Schon nach 1,5h mosern, das keiner geantwortet hat.
Egal, auf Deinem Foto kann man leider nicht sehen, was für ein Gerät Du da schalten willst. Du sprichst einmal von einer RGB-Led-Leiste, dann aber wieder von  "Leuchtröhre mit R-G-B und 12V Kabel"?
Was ich auch nicht verstehe ist, warum Du die 3 Farben zusammenschliesst? Oder sollen die Farben nicht getrennt geschaltet werden?
Mario.
1123  International / Deutsch / Re: Suche hilfe für LCD 32x8 mit m50530 on: February 24, 2012, 04:58:24 am
Laut Lib sollten die Datenleitungen die Pins 8 bis 11 Verwendung finden.
Gibt's für das Display irgendwo ein Datasheet?
1124  International / Deutsch / Re: Suche hilfe für LCD 32x8 mit m50530 on: February 23, 2012, 11:25:59 pm

Als Beispielsketch liess sich folgendes dann compilieren
Code:
#include <m50530.h>

void setup()
{
 
  Serial.begin(9600);
 
// wait for power up
delay(250);
// LCD initialisieren
LCDInit();
  // Modus des LCDs ändern
LCDSetEntryMode( 80 | 64 );
// Cursor einschalten
LCDSetDisplayMode(dmDisplayOn | dmCursorOn | dmCursorBlink | dmCharacterBlink);
}

void loop()
{
  //Konfiguration vor jedem Loop
  LCDSend( 0, LCD_CMD_SETFUNCTIONMODE | sfIO4BIT | sfFont5x8 | 8 );
  LCDSend( 0, LCD_CMD_SETENTRYMODE | emCursorIncWrite | emDisplayNoChange );
  LCDSetDisplayMode(dmDisplayOn | dmCursorOn | dmCursorBlink | dmCharacterBlink);
 
  //Text bei jedem Loop
        LCDSetCursorPos(0,0);
        LCDWrite((const char*)"LCD - 24x8 characters");
LCDSetCursorPos(5,0);
LCDWrite((const char*)"Samsung 2138a");
  LCDSetCursorPos(4, 0);
LCDWrite((const char*)"test successful");
        LCDSetCursorPos(7, 21);
LCDWrite((const char*)":-)");
  delay(2);
  digitalWrite(13, HIGH);
}
Den Code kann ich natürlich nicht testen, da ich kein Display habe.
Wie hast Du das Display denn angeschlossen?
1125  International / Deutsch / Re: Suche hilfe für LCD 32x8 mit m50530 on: February 23, 2012, 11:25:46 pm
Ein schneller Test mit IDE 1.0 ergab folgendes:
Datei "m50530.h"
Code:
#ifndef M50530_H
#define M50530_H
#include <avr/io.h>

  // Data and Control signals can be connected to different ports!

  // data port, LCD signals DB4-DB7 have to be connected to P0-P3
#define LCDDATAPORT PORTB
#define LCDDATADIR  DDRB
#define LCDDATAPIN  PINB

  // control port, LCD signals RW, EX, I/OC1, I/OC2
#define LCDCTRLPORT PORTD
#define LCDCTRLDIR  DDRD


//#define LCDCTRLPIN  PIND
#define LCDPIN_RW   4
#define LCDPIN_IOC1 7  
#define LCDPIN_IOC2 5
#define LCDPIN_EX   6


  // display commands
#define LCD_CMD_SETFUNCTIONMODE          0xc0  // SF
#define LCD_CMD_SETENTRYMODE             0x40  // SE
#define LCD_CMD_SETDISPLAYMODE           0x20  // SD
#define LCD_CMD_SHIFTCURDISPADDRESS      0x10  // MA
#define LCD_CMD_SETUNDERLINEMODE         0x0C  // SU
#define LCD_CMD_WRITERAMUNDERLINEBIT     0x08  // WU
#define LCD_CMD_SETBLINKINGFREQUENCY     0x04  // SB
#define LCD_CMD_CURSORHOMESTARTADDR      0x03  // MH
#define LCD_CMD_CLEARCURSORDATAADDRHOME  0x01  // CH
#define LCD_CMD_NOOPERATION              0x00  // NOP


  // SF - Set Function Mode constants
#define sfIO8BIT         0x20  // bit 5
#define sfIO4BIT         0x00
#define sfFont5x8        0x10  // bit 4
#define sfFont5x12       0x00
  
  // SD - Set Display Mode constants
#define dmDisplayOn      0x10
//#define dmDisplayOn      16
#define dmCursorOn       0x08
#define dmUnderline      0x04
#define dmCursorBlink    0x02
#define dmCharacterBlink 0x01

  // SU - Set Underline Mode constants
#define suSetUnderline   0x03
#define suResetUnderline 0x02
#define suNoUnderline    0x00

  // SB - Set Blinking Frequency constants
#define sbSlow           0x00
#define sbNormal         0x01
#define sbFast           0x02
#define sbFastest        0x03

  // SE - Set Entry Mode constants

  // base definitions cursor
#define LCD_EM_CursorRead 0x08
#define LCD_EM_CursorWrite 0x10
#define LCD_EM_CursorIncrement 0x00
#define LCD_EM_CursorDecrement 0x20

  // base definitions display
#define LCD_EM_DisplayRead 0x01
#define LCD_EM_DisplayWrite 0x02
#define LCD_EM_DisplayIncrement 0x00
#define LCD_EM_DisplayDecrement 0x04

  // constants for cursor
#define emCursorNoChange       0x00
#define emCursorIncRead        LCD_EM_CursorIncrement | LCD_EM_CursorRead
#define emCursorIncWrite       LCD_EM_CursorIncrement | LCD_EM_CursorWrite
#define emCursorIncReadWrite   LCD_EM_CursorIncrement | LCD_EM_CursorRead | LCD_EM_CursorWrite
#define emCursorDecRead        LCD_EM_CursorDecrement | LCD_EM_CursorRead
#define emCursorDecWrite       LCD_EM_CursorDecrement | LCD_EM_CursorWrite
#define emCursorDecReadWrite   LCD_EM_CursorDecrement | LCD_EM_CursorRead | LCD_EM_CursorWrite

  // constants for display start address                                                
#define emDisplayNoChange      0x00
#define emDisplayIncRead       LCD_EM_DisplayIncrement | LCD_EM_DisplayRead
#define emDisplayIncWrite      LCD_EM_DisplayIncrement | LCD_EM_DisplayWrite
#define emDisplayIncReadWrite  LCD_EM_DisplayIncrement | LCD_EM_DisplayRead | LCD_EM_DisplayWrite
#define emDisplayDecRead       LCD_EM_DisplayDecrement | LCD_EM_DisplayRead
#define emDisplayDecWrite      LCD_EM_DisplayDecrement | LCD_EM_DisplayWrite
#define emDisplayDecReadWrite  LCD_EM_DisplayDecrement | LCD_EM_DisplayRead | LCD_EM_DisplayWrite


extern int LCDIsBusy(void);
extern void LCDSend(unsigned char AControl, unsigned char AData);
extern char LCDInit(void);
extern void LCDSetCursorPos(const unsigned char y, const unsigned char x);
extern const char LCDWrite(const char * c);
extern void LCDWritePGM(const char * c);

  // schreibt das übergebene Zeichen an die aktuelle Cursor-Position
#define LCDWriteChar(c)           LCDSend(_BV(LCDPIN_IOC2), c)

  // setzt den Display-Modus
  // man verwende die oben deklarierten Konstanten ;)
#define LCDSetDisplayMode(mode)    LCDSend(0, mode | 32)

#define LCDSetEntryMode(mode)   LCDSend(0, mode)

  // setzt den Cursor an die angegebene Adresse
//#define LCDSetCursorAddress(address)   LCDSend((1<<LCDPIN_IOC1) | (1<<LCDPIN_IOC2), address)

#define cls(void)      LCDSend(0, LCD_CMD_CLEARCURSORDATAADDRHOME);
#endif
Datei "m50530.cpp"
Code:
#include "m50530.h"
#include <util/delay.h>
#include <avr/pgmspace.h>

void LCDToggleEX(void)
{
  //_delay_us(5);

  LCDCTRLPORT |= (_BV(LCDPIN_EX));
  
  _delay_us(2);  // 10 2

  LCDCTRLPORT &= ~(_BV(LCDPIN_EX));

  //_delay_us(5);
}

int LCDIsBusy(void)
{
  unsigned char lInpData = 0;
  int lBusyFlag = 0;
  int l4BitFlag = 0;

    // data port set up to input
  LCDDATADIR &= 0xf0;
  
    // set RW signal
  LCDCTRLPORT |= _BV(LCDPIN_RW);

    // delay?
  //_delay_us(5);  

    // set EX signal
  LCDCTRLPORT |= _BV(LCDPIN_EX);

    // delay?
  //_delay_us(2); // 10

    // read 1st nibble
  lInpData = LCDDATAPIN;

    // clear EX signal
  LCDCTRLPORT &= ~_BV(LCDPIN_EX);

  lBusyFlag =  ( lInpData & (1 << 3) );
  l4BitFlag = !( lInpData & (1 << 2) );

    // delay?
  //_delay_us(5);  

    // read 2nd nibble
  if ( l4BitFlag )
  {
      // set EX signal
    LCDCTRLPORT |= _BV(LCDPIN_EX);

      // delay?
    //_delay_us(2);  // 10

      // read 2nd nibble
    LCDDATAPIN;

      // clear EX signal
    LCDCTRLPORT &= ~_BV(LCDPIN_EX);
  }

  //_delay_us(10);

    // clear RW signal
  LCDCTRLPORT &= ~_BV(LCDPIN_RW);

    // set data port back to output
  LCDDATADIR |= 0x0f;
    // clear data outputs
  LCDDATAPORT &= 0xf0;

  return lBusyFlag;
}

void LCDSend(unsigned char AControl, unsigned char AData)
{
//Serial.println(AControl);
  unsigned char lHN = ( AData & 0xf0 ) >> 4;
  unsigned char lLN = ( AData & 0x0f );
  
  while ( LCDIsBusy() )
    ;

  LCDCTRLPORT &= ~(_BV(LCDPIN_RW) | _BV(LCDPIN_IOC1) | _BV(LCDPIN_IOC2) | _BV(LCDPIN_EX));
  LCDCTRLPORT |= AControl;

  LCDDATAPORT &= 0xf0;
  LCDDATAPORT |= lHN;

  LCDToggleEX();

  LCDDATAPORT &= 0xf0;
  LCDDATAPORT |= lLN;
  
  LCDToggleEX();

  LCDDATAPORT &= 0xf0;
  LCDCTRLPORT &= ~AControl;

  _delay_us(20);
  //return LCDDATAPORT;
}

char LCDInit(void)
{
    // port setup
  LCDDATADIR |= 0x0F;
  LCDCTRLDIR |= _BV(LCDPIN_RW) | _BV(LCDPIN_IOC1) | _BV(LCDPIN_IOC2) | _BV(LCDPIN_EX);
  
  // SF - Set Function Mode
//  >> 4 Bit I/O, 5x8 Font, 1/32 duty
// >> 4 lines x 40 words, 96 words CG RAM
  LCDSend( 0, LCD_CMD_SETFUNCTIONMODE | sfIO4BIT | sfFont5x8 | 8 ); //geändert von 0x0b zu 8
  
    // SE - Set Entry Mode
  LCDSend( 0, LCD_CMD_SETENTRYMODE | emCursorIncWrite | emDisplayNoChange );

    // SU - Set Underline Mode
  LCDSend( 0, LCD_CMD_SETUNDERLINEMODE | suNoUnderline );

    // SB - Set Blinking Frequency
  LCDSend( 0, LCD_CMD_SETBLINKINGFREQUENCY | sbNormal );

    // SD - Set Display Mode
  LCDSend( 0, LCD_CMD_SETDISPLAYMODE | dmDisplayOn | dmCursorOn | dmCursorBlink);

    // CH - Clear Cursor of DD RAM display data home & display start address home
  LCDSend( 0, LCD_CMD_CLEARCURSORDATAADDRHOME );

  _delay_ms(2);
  return 't';
}

  // setzt den Cursor an die angegebene Position (y = Zeile, x = Spalte)
void LCDSetCursorPos(const unsigned char y, const unsigned char x)
{
    // Adresse aus x und y berechnen
    // Adressen sind wie folgt: Zeile 0 = 0; Zeile 1 = 40; Zeile 2 = 80; Zeile 3 = 120; Zeile 4 = 160; Zeile 5 = 64+24; Zeile 6 = 128+24; Zeile 7 = 192+24
  //unsigned char address = x + (y*40);
unsigned char address = x + ((y % 4) << 6);
if (y > 3)
address += 24;

  LCDSend(_BV(LCDPIN_IOC1)|_BV(LCDPIN_IOC2), address);
}

  // schreibt die übergebene Zeichenkette an die aktuelle Cursor-Position
const char LCDWrite(const char * c)
{
const char* bla = c;
  while (*c)
    LCDWriteChar(*c++);
  return *bla;
}

  // schreibt die übergebene Zeichenkette aus dem Programmspeicher
  // an die aktuelle Cursor-Position
void LCDWritePGM(const char * c)
{
  uint8_t b;

  while ( (b = pgm_read_byte(c++)) )
 LCDWriteChar(b);
}
Beide Dateien müssen in ein Verzeichnis "m50530" in Deinem Verzeichnis "Arduino/libraries". Auf dem Mac ist es im Homeordner im Verzeichnis "Documents" zu finden. Bei Windows vermute ich mal bei "Eigene Dateien", mußt Du aber selbst mal schauen. Wichtig ist, das das Verzeichnis und die cpp und h Dateien genau gleich heissen.
Pages: 1 ... 73 74 [75] 76 77 ... 87