Code für die Motoren eines Spirograph entwickeln

Ja, richtig,
Aber so mit dem Steperzeugen im loop wirst Du nicht zum Ziel kommen.
Ich habe deinen einfachen Sketch mal auf MobaTools umgeschrieben:

// einfache Motoransteuerung
#include <MobaTools.h>
const byte ENA = 38;
const byte STP = 54;
const byte DIR = 55;
const int stepPerRev = 3200;    // Zahl der Steps für eine Umdrehung ( abhängig von den Jumpern MS1..MS3 )

MoToStepper stepper1 ( stepPerRev, STEPDIR );  // Anlegen des 1. Steppers
void setup()
{
  stepper1.attach( STP, DIR );
  stepper1.setSpeed( 300 );             // 30 Umd/Min ( wenn stepPerRev richtig gesetzt ist )
  stepper1.setRampLen( stepPerRev / 2); // Rampenlänge ist 1/2 Umdrehung
  stepper1.attachEnable( ENA, 50, LOW );  // Verwaltung des enable-Pins durch die Lib
  stepper1.rotate(1);                   // Drehen starten
}

void loop()
{
}

Versuch den mal zu verstehen und in der Richtung solltest Du weitermachen.

Vielen Dank, dafür, werde heute Abend auch mal die PDF der Mobatools mir ausdrucken und lesen.
Jetzt gibt es aber erst einmal Essen.

Na dann guten Appetit :wink:

Applaus, Applaus!

Nimm die Seite von my-home-fab.

Das hängt nicht vom ramps-Board, sondern von den aufgesteckten Treiberboards ab. Der A4988 kann nur maximal 1/16 Microstepping, der DRV8825 kann bis zu 1/32 Microstepping.
Du musst aber auch bedenken, dass die maximale Drehzahl umso kleiner ist, je höher das Microstepping ist.

Ja ist schon mit 1/32 ziemlich langsam, das änder ich vielleicht noch einmal ganz am Schluss, wenn ich die Teile alle zusammen baue.

Vielen, vielen Dank das hat mir sehr geholfen.
Ja und der Code funktioniert. Habe nur 6400 als stepPerRev benutzt, da ich ja bisher 1/32 Microstepping benutze. Mit stepper1.setSpeed( 300 ); war scheinbar schon die Grenze der Umdrehungen erreicht. Hatte nicht den Eindruck das bei 500 oder 1000 ein Geschwindigkeitszuwachs war.

Habe inzwischen das Mobatool PDF gelesen, außer der Button-Teil, dass kommt die Tage.
Nun wollte ich natürlich gleich mal einen zweiten Motor ansteuern. Habe nach Beispielen gesucht, aber die haben alle nicht mit const byte gearbeitet.
Ich weiß das der Code den ich da geschrieben habe nicht wirklich funktionieren kann.
Denn wie man MoToStepper stepper1 und stepper2 vorher definiert, also unterscheidet ist mir nicht klar. Denn mir nutzt es ja nichts stepper2 im void setup() aufzurufen, wenn es vorher nicht definiert wurde.
Hier mal der unvollständige Code:

#include <MobaTools.h>
// PIN-Belegung des 1. Steppers
const byte ENA = 38;
const byte STP = 54;
const byte DIR = 55;

// PIN-Belegung des 2. Steppers
const byte ENA = 60;
const byte STP = 61;
const byte DIR = 56;

const int stepPerRev = 6400;    // Zahl der Steps für eine Umdrehung ( abhängig von den Jumpern MS1..MS3 )

MoToStepper stepper1 ( stepPerRev, STEPDIR );  // Anlegen des 1. Steppers
void setup()
{
  stepper1.attach( STP, DIR );
  stepper1.setSpeed( 300 );             // 30 Umd/Min ( wenn stepPerRev richtig gesetzt ist )
  stepper1.setRampLen( stepPerRev / 2); // Rampenlänge ist 1/2 Umdrehung
  stepper1.attachEnable( ENA, 50, LOW );  // Verwaltung des enable-Pins durch die Lib
  stepper1.rotate(1);                   // Drehen starten; 1=vorwärst, -1=rückwärts

  stepper2.attach( STP, DIR );
  stepper2.setSpeed( 300 );             
  stepper2.setRampLen( stepPerRev / 2); 
  stepper2.attachEnable( ENA, 50, LOW ); 
  stepper2.rotate(1);                   
}

void loop()
{
}

Du musst halt deinen stepper2 genauso einrichten, wie deinen stepper1:

MoToStepper stepper1 ( stepPerRev, STEPDIR );  // Anlegen des 1. Steppers
MoToStepper stepper2 ( stepPerRev, STEPDIR );  // Anlegen des 2. Steppers

Ist so ähnlich wie eine 2. Variable anlegen :wink:

Und Du musst für deinen 2. Stepper die Namen für die Pins auch anders benennen, also z.B.

const byte ENA2 = 60;
const byte STP2 = 61;
const byte DIR2 = 56;

Sonst kann der Compiler das ja nicht auseinanderhalten.

1 Like

Hm, funktioniert derzeit immer noch nur für Stepper 1. Wenn ich void setup() 2 mal aufrufen meckert der Compiler.

#include <MobaTools.h>
// PIN-Belegung des 1. Steppers
const byte ENA = 38;
const byte STP = 54;
const byte DIR = 55;

// PIN-Belegung des 2. Steppers
const byte ENA2 = 60;
const byte STP2 = 61;
const byte DIR2 = 56;

const int stepPerRev = 6400;    // Zahl der Steps für eine Umdrehung ( abhängig von den Jumpern MS1..MS3 )

MoToStepper stepper1 ( stepPerRev, STEPDIR );  // Anlegen des 1. Steppers
MoToStepper stepper2 ( stepPerRev, STEPDIR );  // Anlegen des 2. Steppers
void setup()
{
  stepper1.attach( STP, DIR );
  stepper1.setSpeed( 300 );             // 30 Umd/Min ( wenn stepPerRev richtig gesetzt ist )
  stepper1.setRampLen( stepPerRev / 2); // Rampenlänge ist 1/2 Umdrehung
  stepper1.attachEnable( ENA, 50, LOW );  // Verwaltung des enable-Pins durch die Lib
  stepper1.rotate(1);                   // Drehen starten; 1=vorwärst, -1=rückwärts                    
  stepper2.attach( STP2, DIR2 );
  stepper2.setSpeed( 300 );             
  stepper2.setRampLen( stepPerRev / 2); 
  stepper2.attachEnable( ENA2, 50, LOW ); 
  stepper2.rotate(1);                   
}

void loop()
{
}

Bis Du sicher, dass der 2. Stepper richtig angeschlossen ist, und die Pins stimmen?
Bei mir funktioniert der Sketch ( habe nur die Pins angepasst )

Das sind die Vorgaben vom Board:

#define Y_STEP_PIN 60
#define Y_DIR_PIN 61
#define Y_ENABLE_PIN 56
#define Y_MIN_PIN 14
#define Y_MAX_PIN -1 // PIN 15 wird verwendet

Und auf dem Board habe ich bei Y gesteckt und der Schalter sitzt fest.
Wie gesagt bei mir funktioniert es nicht. :slightly_frowning_face:
Ich kann es mal bei der Z-Achse (mit entsprechenden Pins) probieren oder einen anderen Motor. Mehr fällt mir nicht ein.

Ach der 56 Pin ist es wohl
Ok es geht.
Super 2 Motoren. :trophy: :trophy:
Doppelte Feier heute.
So für heute reichts. Morgen geht es weiter.
Ich bräuchte noch die Infos, wie ich mein LCD 12864 zum laufen bringe oder wie ich Taster an das Shield anschließen kann. Danke und Gute Nacht

So habe alle vier Motoren zum laufen gebracht.

Ich bräuchte jetzt dringende Hilf für mein LCD. Ich bekomme es nicht installiert.
Also auf dem LCD steht 12864 - Full Graphic Smart Controller.
Denn einzigen Hinweis des Herstellers bekomme ich hier:
LCD12864 und von dieser Seite habe ich mir die u8glib - Bibliothek geladen.
Die Bibliothek habe ich geladen, ist also in meiner IDE vorhanden. Dann rufe ich aus der Bibliothek u8glib den Sketch "Hello World!" auf.
Hier muss ich etwas auskommentieren und ich habe divers probiert:

#include "U8glib.h"

// setup u8g object, please remove comment from one of the following constructor calls
// IMPORTANT NOTE: The following list is incomplete. The complete list of supported 
// devices with all constructor calls is here: https://github.com/olikraus/u8glib/wiki/device
//U8GLIB_NHD27OLED_BW u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD27OLED_2X_BW u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD27OLED_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD27OLED_2X_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD31OLED_BW u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD31OLED_2X_BW u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD31OLED_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_NHD31OLED_2X_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGS102 u8g(13, 11, 10, 9, 8);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGM132 u8g(13, 11, 10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGM128 u8g(13, 11, 10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGM128_2X u8g(13, 11, 10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_ST7920_128X64_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_128X64_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_128X64_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_128X64_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_192X32_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_192X32_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_1X u8g(13, 11, 10);	// SPI Com: SCK = en = 13, MOSI = rw = 11, CS = di = 10
//U8GLIB_ST7920_192X32_4X u8g(10);		// SPI Com: SCK = en = 13, MOSI = rw = 11, CS = di = 10, HW SPI
//U8GLIB_ST7920_202X32_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_202X32_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_202X32_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_202X32_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_LM6059 u8g(13, 11, 10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_LM6063 u8g(13, 11, 10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGXL160_BW u8g(10, 9);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGXL160_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGXL160_2X_BW u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_DOGXL160_2X_GR u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_PCD8544 u8g(13, 11, 10, 9, 8);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, Reset = 8
//U8GLIB_PCF8812 u8g(13, 11, 10, 9, 8);		// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, Reset = 8
//U8GLIB_KS0108_128 u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 14, 15, 17, 16); 		// 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs1=14, cs2=15,di=17,rw=16
//U8GLIB_LC7981_160X80 u8g(8, 9, 10, 11, 4, 5, 6, 7,  18, 14, 15, 17, 16); 	// 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs=14 ,di=15,rw=17, reset = 16
//U8GLIB_LC7981_240X64 u8g(8, 9, 10, 11, 4, 5, 6, 7,  18, 14, 15, 17, 16); 	// 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs=14 ,di=15,rw=17, reset = 16
//U8GLIB_LC7981_240X128 u8g(8, 9, 10, 11, 4, 5, 6, 7,  18, 14, 15, 17, 16); 	// 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs=14 ,di=15,rw=17, reset = 16
//U8GLIB_ILI9325D_320x240 u8g(18,17,19,U8G_PIN_NONE,16 );  			// 8Bit Com: D0..D7: 0,1,2,3,4,5,6,7 en=wr=18, cs=17, rs=19, rd=U8G_PIN_NONE, reset = 16
//U8GLIB_SBN1661_122X32 u8g(8,9,10,11,4,5,6,7,14,15, 17, U8G_PIN_NONE, 16); 	// 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 cs1=14, cs2=15,di=17,rw=16,reset = 16
//U8GLIB_SSD1306_128X64 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SSD1306_128X64 u8g(4, 5, 6, 7);	// SW SPI Com: SCK = 4, MOSI = 5, CS = 6, A0 = 7 (new white HalTec OLED)
//U8GLIB_SSD1306_128X64 u8g(10, 9);		// HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NONE|U8G_I2C_OPT_DEV_0);	// I2C / TWI 
//U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_DEV_0|U8G_I2C_OPT_NO_ACK|U8G_I2C_OPT_FAST);	// Fast I2C / TWI 
//U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NO_ACK);	// Display which does not send AC
//U8GLIB_SSD1306_ADAFRUIT_128X64 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SSD1306_ADAFRUIT_128X64 u8g(10, 9);		// HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_SSD1306_128X32 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SSD1306_128X32 u8g(10, 9);             // HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_SSD1306_128X32 u8g(U8G_I2C_OPT_NONE);	// I2C / TWI 
//U8GLIB_SSD1306_64X48 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SSD1306_64X48 u8g(10, 9);             // HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_SSD1306_64X48 u8g(U8G_I2C_OPT_NONE);	// I2C / TWI 
//U8GLIB_SH1106_128X64 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SH1106_128X64 u8g(4, 5, 6, 7);	// SW SPI Com: SCK = 4, MOSI = 5, CS = 6, A0 = 7 (new blue HalTec OLED)
//U8GLIB_SH1106_128X64 u8g(U8G_I2C_OPT_NONE);	// I2C / TWI 
//U8GLIB_SH1106_128X64 u8g(U8G_I2C_OPT_DEV_0|U8G_I2C_OPT_FAST);	// Dev 0, Fast I2C / TWI
//U8GLIB_SH1106_128X64 u8g(U8G_I2C_OPT_NO_ACK);	// Display which does not send ACK
//U8GLIB_SSD1309_128X64 u8g(13, 11, 10, 9);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_SSD1327_96X96_GR u8g(U8G_I2C_OPT_NONE);	// I2C
//U8GLIB_SSD1327_96X96_2X_GR u8g(U8G_I2C_OPT_NONE);	// I2C
//U8GLIB_UC1611_DOGM240 u8g(U8G_I2C_OPT_NONE);	// I2C
//U8GLIB_UC1611_DOGM240 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_UC1611_DOGM240 u8g(10, 9);		// HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_UC1611_DOGM240 u8g(10, 9);		// HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_UC1611_DOGM240 u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 3, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs=3, di/a0=17,rw=16
//U8GLIB_UC1611_DOGXL240 u8g(U8G_I2C_OPT_NONE);	// I2C
//U8GLIB_UC1611_DOGXL240 u8g(13, 11, 10, 9);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9
//U8GLIB_UC1611_DOGXL240 u8g(10, 9);		// HW SPI Com: CS = 10, A0 = 9 (Hardware Pins are  SCK = 13 and MOSI = 11)
//U8GLIB_UC1611_DOGXL240 u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 3, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, cs=3, di/a0=17,rw=16
//U8GLIB_NHD_C12864 u8g(13, 11, 10, 9, 8);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_NHD_C12832 u8g(13, 11, 10, 9, 8);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_LD7032_60x32 u8g(13, 11, 10, 9, 8);	// SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_LD7032_60x32 u8g(11, 12, 9, 10, 8);	// SPI Com: SCK = 11, MOSI = 12, CS = 9, A0 = 10, RST = 8  (SW SPI Nano Board)
//U8GLIB_UC1608_240X64 u8g(13, 11, 10, 9, 8);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64_2X u8g(13, 11, 10, 9, 8);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64 u8g(10, 9, 8);	// HW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64_2X u8g(10, 9, 8);	// HW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X u8g(13, 11, 10, 9, 8);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64_2X u8g(13, 11, 10, 9, 8);	// SW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64 u8g(10, 9, 8);	// HW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_UC1608_240X64_2X u8g(10, 9, 8);	// HW SPI Com: SCK = 13, MOSI = 11, CS = 10, A0 = 9, RST = 8
//U8GLIB_T6963_240X128 u8g(8, 9, 10, 11, 4, 5, 6, 7, 14, 15, 17, 18, 16); // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7, cs=14, a0=15, wr=17, rd=18, reset=16
//U8GLIB_T6963_128X128 u8g(8, 9, 10, 11, 4, 5, 6, 7, 14, 15, 17, 18, 16); // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7, cs=14, a0=15, wr=17, rd=18, reset=16
//U8GLIB_T6963_240X64 u8g(8, 9, 10, 11, 4, 5, 6, 7, 14, 15, 17, 18, 16); // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7, cs=14, a0=15, wr=17, rd=18, reset=16
//U8GLIB_T6963_128X64 u8g(8, 9, 10, 11, 4, 5, 6, 7, 14, 15, 17, 18, 16); // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7, cs=14, a0=15, wr=17, rd=18, reset=16
//U8GLIB_HT1632_24X16 u8g(3, 2, 4);		// WR = 3, DATA = 2, CS = 4
//U8GLIB_SSD1351_128X128_332 u8g(13, 11, 8, 9, 7); // Arduino UNO: SW SPI Com: SCK = 13, MOSI = 11, CS = 8, A0 = 9, RESET = 7 (http://electronics.ilsoft.co.uk/ArduinoShield.aspx)
//U8GLIB_SSD1351_128X128_332 u8g(76, 75, 8, 9, 7); // Arduino DUE: SW SPI Com: SCK = 13, MOSI = 11, CS = 8, A0 = 9, RESET = 7 (http://electronics.ilsoft.co.uk/ArduinoShield.aspx)
//U8GLIB_SSD1351_128X128_332 u8g(8, 9, 7); // Arduino: HW SPI Com: SCK = 13, MOSI = 11, CS = 8, A0 = 9, RESET = 7 (http://electronics.ilsoft.co.uk/ArduinoShield.aspx)
//U8GLIB_SSD1351_128X128_HICOLOR u8g(76, 75, 8, 9, 7); // Arduino DUE, SW SPI Com: SCK = 76, MOSI = 75, CS = 8, A0 = 9, RESET = 7 (http://electronics.ilsoft.co.uk/ArduinoShield.aspx)
//U8GLIB_SSD1351_128X128_HICOLOR u8g(8, 9, 7); // Arduino, HW SPI Com: SCK = 76, MOSI = 75, CS = 8, A0 = 9, RESET = 7 (http://electronics.ilsoft.co.uk/ArduinoShield.aspx)
//U8GLIB_SSD1351_128X128GH_332 u8g(8, 9, 7); // Arduino, HW SPI Com: SCK = 76, MOSI = 75, CS = 8, A0 = 9, RESET = 7 (Freetronics OLED)
//U8GLIB_SSD1351_128X128GH_HICOLOR u8g(8, 9, 7); // Arduino, HW SPI Com: SCK = 76, MOSI = 75, CS = 8, A0 = 9, RESET = 7 (Freetronics OLED)

Wenn ich Strom ans Board gebe, leuchtet die LCD aber mehr auch nicht.
In der ersten Beschreibung:
erhält man diesen Hinweis:

Modify the Configuration.h
//#define REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER change into
#define REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER
Select the development board as Mega 2560 and the port

Aber soweit ich das verstanden habe gilt das nur für marlin oder gibt es eine allgemeine arduino Configuration.h in der ich das ändern muss?
Stehe gerade völlig auf dem Schlauch und bräuchte Hilfe.

Du musst auf jeden Fall die richtige Zeile aus der Liste aktivieren. Da wird der Lib mitgeteilt, welcher Chip auf dem LCD ist, und wie es angeschlossen ist. Meines Wissens ist da ein ST7920 drauf. Wie er angeschlossen ist, müsste über das Schaltbild rauszubekommen sein - da ist ja ein Adapterboard dabei.

Danke für die Antwort, das grenzt es etwas ein, denn ich habe mich jetzt schon dumm und dämlich gesucht, aber nichts außer jede Menge andere Leute gefunden, die das selbe Problem haben.
Also das ist die Liste und irgend einer ist es vielleicht.

U8GLIB_ST7920_128X64_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_128X64_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_128X64_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_128X64_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_192X32_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_192X32_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_192X32_1X u8g(13, 11, 10);	// SPI Com: SCK = en = 13, MOSI = rw = 11, CS = di = 10
//U8GLIB_ST7920_192X32_4X u8g(10);		// SPI Com: SCK = en = 13, MOSI = rw = 11, CS = di = 10, HW SPI
//U8GLIB_ST7920_202X32_1X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_202X32_4X u8g(8, 9, 10, 11, 4, 5, 6, 7, 18, 17, 16);   // 8Bit Com: D0..D7: 8,9,10,11,4,5,6,7 en=18, di=17,rw=16
//U8GLIB_ST7920_202X32_1X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17
//U8GLIB_ST7920_202X32_4X u8g(18, 16, 17);	// SPI Com: SCK = en = 18, MOSI = rw = 16, CS = di = 17

Und das wird mir als Fehlermeldung ausgegeben, vielleicht kannst du damit etwas anfangen.

 System wide configuration file is "C:\Program Files (x86)\Arduino\hardware\tools\avr/etc/avrdude.conf"

         Using Port                    : COM3
         Using Programmer              : wiring
         Overriding Baud Rate          : 115200
         AVR Part                      : ATmega2560
         Chip Erase delay              : 9000 us
         PAGEL                         : PD7
         BS2                           : PA0
         RESET disposition             : dedicated
         RETRY pulse                   : SCK
         serial program mode           : yes
         parallel program mode         : yes
         Timeout                       : 200
         StabDelay                     : 100
         CmdexeDelay                   : 25
         SyncLoops                     : 32
         ByteDelay                     : 0
         PollIndex                     : 3
         PollValue                     : 0x53
         Memory Detail                 :

                                  Block Poll               Page                       Polled
           Memory Type Mode Delay Size  Indx Paged  Size   Size #Pages MinW  MaxW   ReadBack
           ----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------
           eeprom        65    10     8    0 no       4096    8      0  9000  9000 0x00 0x00
           flash         65    10   256    0 yes    262144  256   1024  4500  4500 0x00 0x00
           lfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           hfuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           efuse          0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           lock           0     0     0    0 no          1    0      0  9000  9000 0x00 0x00
           calibration    0     0     0    0 no          1    0      0     0     0 0x00 0x00
           signature      0     0     0    0 no          3    0      0     0     0 0x00 0x00

         Programmer Type : Wiring
         Description     : Wiring
         Programmer Model: AVRISP
         Hardware Version: 15
         Firmware Version Master : 2.10
         Vtarget         : 0.0 V
         SCK period      : 0.1 us

avrdude: AVR device initialized and ready to accept instructions

Reading | ################################################## | 100% 0.01s

avrdude: Device signature = 0x1e9801 (probably m2560)
avrdude: reading input file "C:\Users\Demo\AppData\Local\Temp\arduino_build_321432/HelloWorld.ino.hex"
avrdude: writing flash (10838 bytes):

Writing | ################################################## | 100% 1.68s

avrdude: 10838 bytes of flash written
avrdude: verifying flash memory against C:\Users\Demo\AppData\Local\Temp\arduino_build_321432/HelloWorld.ino.hex:
avrdude: load data flash data from input file C:\Users\Demo\AppData\Local\Temp\arduino_build_321432/HelloWorld.ino.hex:
avrdude: input file C:\Users\Demo\AppData\Local\Temp\arduino_build_321432/HelloWorld.ino.hex contains 10838 bytes
avrdude: reading on-chip flash data:

Reading | ################################################## | 100% 1.32s

avrdude: verifying ...
avrdude: 10838 bytes of flash verified

avrdude done.  Thank you.

Würde ich gern, wenn ich wüsste wie?

Sitzen tut es auf der hinteren Reihe die mit D16 anfängt und bis D32 usw. geht.
Aber D32 ist in der oberen Liste zum auskommentieren gar nicht aufgeführt.
Ich hoffe ich habe jetzt nicht zu sehr verwirrt.

Gratulation!

Bei Oli lese ich: " Note: There will be no more development for U8glib. Please use u8g2."

Bei U8g2 dann eventuell U8G2_ST7920_128X64_F_HW_SPI.

Aber ich habe das Display nicht, daher ohne Gewähr!

Könnte aber schon sein; der Displayadapter greift ja unten auf den Stecker AUX3/SPI zu.

Danke für Eure Antworten aber U8g2 hatte ich auch schon heruntergeladen und getestet.
Bin alle U8G2_ST7920 durchgegangen, nichts passiert, nur das Display ist hell, mehr aber auch nicht.
Ich weiß ehrlich gesagt, nicht weiter.
Hab nur das hier gefunden... oder das hier ... aber damit kann ich nicht wirklich was anfangen.

Das sind (zum Glück) keine Fehlermedungen.
Der Sketch wird ganz schick hochgeladen.
Der wichtige Teil fehlt.
Unter - DATEI - VOREINSTELLUNGEN
grafik
Dann nochmal kompilieren und hochladen.
Die Ausgaben ggfls. nochmal hier rein.

Ich sehe auch keinerlei Infos zur Herkunft Deiner Bauteile.
Den externen Link kann ich nicht und in ein paar Tagen weiss keiner mehr, was da stand. Klink Deine Doku hier rein, sonst macht das keinen Sinn.

Ansonsten auch von mir: Glückwunsch, das Du die Motoren am laufen hast....

1 Like

Wie getestet?

Nimm U8g2\examples\full_buffer\HelloWorld\HelloWorld.ino, Kommentierung in der richtigen Zeile, siehe #36, entfernen, probieren und berichten.

1 Like