change pins for pcb and optimize
This commit is contained in:
		
							parent
							
								
									a8c2813b74
								
							
						
					
					
						commit
						2c9913b9c2
					
				| @ -8,22 +8,11 @@ const int universeSize = 512; | ||||
| ArtnetReceiver artnet; | ||||
| uint32_t universe0 = 0; | ||||
| uint32_t universe1 = 1; | ||||
| byte artnetdata[512]; | ||||
| 
 | ||||
| // ethernet stuff
 | ||||
| const IPAddress ip(10, 255, 255, 255); | ||||
| uint8_t mac[] = {0xAA, 0xDD, 0xBB, 0xAA, 0xDD, 0xBB}; | ||||
| 
 | ||||
| //ArtNet universe0 callback
 | ||||
| void callback(byte* data, uint16_t size) { | ||||
|   for (size_t i = 0; i < 512; ++i) { | ||||
|     artnetdata[i] = data[i]; | ||||
|     //if (i == 0) analogWrite(30, data[i]);
 | ||||
|     //if (i == 1) analogWrite(8, data[i]);
 | ||||
|     //if (i == 2) analogWrite(9, data[i]);
 | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| //NRF stuff
 | ||||
| #include <SPI.h> | ||||
| #include <RF24.h> | ||||
| @ -34,13 +23,25 @@ RF24 radio (0, 1); | ||||
| const uint16_t address = 0xADB0; | ||||
| uint64_t datasend; | ||||
| 
 | ||||
| //RGB LED
 | ||||
| const int statusLED[] = {23,22, 21}; //RGB
 | ||||
| const int statusLEDlength = 3; | ||||
| int statusLEDstat[3]; | ||||
| 
 | ||||
| //define min interval to show error
 | ||||
| unsigned long currentTime = millis(); | ||||
| unsigned long previousTime = 0; | ||||
| const long waitTime = 100; | ||||
| const long errorTime = 5000; | ||||
| 
 | ||||
| //setup
 | ||||
| void setup() { | ||||
|   pinMode(12, OUTPUT); | ||||
|   pinMode(13, OUTPUT); | ||||
|   pinMode(14, OUTPUT); | ||||
| 
 | ||||
|   pinMode(15, OUTPUT); | ||||
|      for (int i=0; i < statusLEDlength; i++){ | ||||
|     pinMode(statusLED[i], OUTPUT); | ||||
|     digitalWrite(statusLED[i], LOW); | ||||
|   } | ||||
|   pinMode(10, OUTPUT); | ||||
|   digitalWrite(10, LOW); | ||||
| 
 | ||||
|   //start DMX
 | ||||
|   DMX.begin(universeSize); | ||||
| @ -62,26 +63,27 @@ void setup() { | ||||
|   radio.disableCRC(); | ||||
|   radio.stopListening(); | ||||
|    | ||||
|   analogWrite(12, 20); | ||||
|   delay(100); | ||||
|   setRGB(0,0,255); | ||||
|   delay(200); | ||||
| } | ||||
| 
 | ||||
| void loop() { | ||||
|   //int timebegin = millis();
 | ||||
| 
 | ||||
|   //get ArtNet package
 | ||||
|   while(!artnet.parse()); | ||||
|   digitalWrite(15, HIGH); | ||||
|   /*if (artnet.parse()) { // check if artnet packet has come and execute callback
 | ||||
|     digitalWrite(31, HIGH); | ||||
|   }*/ | ||||
| 
 | ||||
|   //uint64_t nrfpackage = artnetdata[0];
 | ||||
|   currentTime = millis(); | ||||
|   if (artnet.parse()) { // check if artnet packet has come and execute callback
 | ||||
|     previousTime = currentTime; | ||||
|     setRGB(0,255,0); | ||||
|   }else if(currentTime - previousTime >= errorTime){ | ||||
|     setRGB(255,0,0); | ||||
|   }else if(currentTime - previousTime >= waitTime){ | ||||
|     setRGB(0,0,255); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| //ArtNet universe0 callback
 | ||||
| void callback(byte* artnetdata, uint16_t size) { | ||||
|   digitalWrite(10, HIGH); | ||||
|   //RGB PWM
 | ||||
|   analogWrite(12, artnetdata[0]); | ||||
|   analogWrite(13, artnetdata[1]); | ||||
|   analogWrite(14, artnetdata[2]); | ||||
|   //setRGB(artnetdata[0], artnetdata[1], artnetdata[2]);
 | ||||
| 
 | ||||
|   //DMX output
 | ||||
|   DMX.beginTransmission(); | ||||
| @ -89,7 +91,7 @@ void loop() { | ||||
|     DMX.write(i, artnetdata[i]); | ||||
|   } | ||||
|   DMX.endTransmission(); | ||||
| 
 | ||||
|    | ||||
|   //send NRF
 | ||||
|   for (int i = 0; i < 20; i++) { | ||||
|     datasend = i; //package ID
 | ||||
| @ -99,11 +101,14 @@ void loop() { | ||||
|     } | ||||
|     radio.writeFast(&datasend, sizeof(datasend)); | ||||
|   } | ||||
| 
 | ||||
|   //int timeend = millis();
 | ||||
|   //int timeneeded = timeend - timebegin;
 | ||||
| 
 | ||||
|   //if (timeneeded < 20) delay(20 - timeneeded);
 | ||||
| 
 | ||||
|   digitalWrite(15, LOW); | ||||
|   digitalWrite(10, LOW); | ||||
| } | ||||
| 
 | ||||
| void setRGB(int r, int g, int b){ | ||||
|   if (r != statusLEDstat[0]) analogWrite(statusLED[0], r); | ||||
|   if (g != statusLEDstat[1]) analogWrite(statusLED[1], g); | ||||
|   if (b != statusLEDstat[2]) analogWrite(statusLED[2], b); | ||||
|   statusLEDstat[0] = r; | ||||
|   statusLEDstat[1] = g; | ||||
|   statusLEDstat[2] = b; | ||||
| } | ||||
|  | ||||
| @ -38,7 +38,7 @@ void setup() { | ||||
|   radio.begin(); | ||||
|   radio.openReadingPipe(0, address); | ||||
|   radio.setPALevel(RF24_PA_MAX); | ||||
|   radio.setDataRate(RF24_1MBPS); | ||||
|   radio.setDataRate(RF24_2MBPS); | ||||
|   radio.setAutoAck(false); | ||||
|   radio.disableCRC(); | ||||
|   radio.startListening(); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user