Índice:
- Etapa 1: Materiais e Ferramentas
- Etapa 2: montagem do circuito
- Etapa 3: Atualizando o MCU
- Etapa 4: Montagem do revestimento do circuito
- Etapa 5: Conectando os condutores da plataforma ao controlador
- Etapa 6: Testando o controlador
- Etapa 7: configuração via I2C usando entrada do console
- Etapa 8: Próximas etapas
2025 Autor: John Day | [email protected]. Última modificação: 2025-01-23 15:03
Esta é uma extensão do Instructable
IOT123 - SOLAR TRACKER - TILT / PAN, PAINEL FRAME, LDR MOUNTS RIG. Aqui nos concentramos no controlador dos servos e nos sensores da posição do sol. É importante ressaltar que este projeto presume que 2 MCUs serão empregados: um (3,3V 8mHz Arduino Pro Mini) para o rastreador solar e um MCU independente para seus sensores / atores.
Esta é a versão 0.3
Em vez de publicar todos os projetos após a satisfação total, praticarei a integração contínua e entregarei algo com mais frequência, modificando o que entreguei conforme preciso. Escreverei outra instrução para o carregador de bateria, _quando_ a otimização do software / hardware do controlador for concluída. Vou apontar onde as otimizações são necessárias à medida que avançamos nesse processo.
Parte do motivo dessa abordagem é o feedback do cliente. Se vocês virem uma necessidade ou tiverem uma abordagem melhor, por favor, comente, mas lembre-se de que não posso entregar tudo e possivelmente não dentro de um prazo adequado para vocês. Como essas explicações parecem menos relevantes, elas serão excluídas deste artigo.
O que isso inclui:
- Use os LDRs do Instructable original para detectar a localização aproximada do sol.
- Mova os servos para enfrentar o sol.
- Opções para a sensibilidade dos movimentos.
- Opções para o tamanho do passo ao mover para o sol.
- Opções para as restrições angulares usadas nos servos.
- Opções para os atrasos dos movimentos.
- Interface I2C para definir / obter valores entre MCUs.
- Sono profundo entre os movimentos.
O que isso não inclui (e será tratado conforme o tempo permitir):
- Usando energia apenas durante o dia.
- Lembrando da posição do amanhecer e indo para lá ao anoitecer.
- Removendo o regulador do MCU.
- Desativando o (s) LED (s) no MCU.
- Redirecionando a energia por meio de VCC em vez de RAW.
- Fornecendo soluções alternativas para piscar sem alimentação regulada do conversor USB para TTL Serial.
- Monitor de tensão da bateria.
HISTÓRIA
20 de dezembro de 2017 CÓDIGO V0.1
A versão inicial rastreia a fonte de luz, sempre ligada, sem carregamento
7 de janeiro de 2018 V0.2 CODE
-
ALTERAÇÕES DE HARDWARE
- Adicionar pinos I2C
- Adicionar interruptor para GNDs servo
- Etiqueta impressa no painel frontal da caixa do controlador
-
ALTERAÇÕES DE SOFTWARE
- Leia a configuração da EEPROM
- Suporte de barramento I2C como escravo de outro MCU (3,3V)
- Definir configuração via I2C
- Definir habilitado via I2C
- Obter configuração via I2C
- Obtenha propriedades de tempo de execução via I2C (atualmente ativado e intensidade de luz atual)
- Remova o registro serial (afetou os valores I2C)
19 de janeiro de 2018 V0.3 CODE
-
HARDWARE
Etiqueta atualizada. A chave agora é usada para escolher o modo CONFIG ou TRACK
-
PROGRAMAS
- I2C usado apenas para configuração
- O controlador espera 5 segundos antes de inicializar o rastreamento, permite mover as mãos
- Para usar a configuração I2C, o SPDT deve estar em CONFIG enquanto a unidade é inicializada
- Entre o movimento de rastreamento, a unidade está no modo de hibernação para o valor de configuração SLEEP MINUTES (padrão 20 minutos).
Etapa 1: Materiais e Ferramentas
Agora existe uma lista completa de Bill of Materials and Sources.
- Peças impressas em 3D.
- Arduino Pro Mini 3.3V 8mHz
- Placa de circuito impresso universal 1 de 4x6cm protótipo de duplo lado PCB (para ser cortado ao meio)
- 1 cabeçote macho 40P (para ser cortado no tamanho certo).
- 1 cabeçote fêmea 40P (para ser cortado no tamanho).
- 4 restistores de 10K 1 / 4W.
- Fio de conexão.
- Solda e Ferro.
- Parafusos auto-roscantes de cabeça panela de aço inoxidável 20 off 4G x 6mm.
- 4 parafusos auto-roscantes escareados de inox 4G x 6mm.
- 1 bateria LiPo de 3,7 V desligada e suporte (terminando em conectores dupont 2P).
- 1 cabeçote macho em ângulo reto 2P
- 1 interruptor SPDT desligado 3 pinos 2,54 mm pitch
- Cola forte de cianoacrilato
- Conectores Dupont conector fêmea 1P (1 azul, 1 verde).
Etapa 2: montagem do circuito
O circuito atualmente não possui o Circuito Divisor de Tensão (voltímetro).
- Corte a placa de circuito impresso universal de PCB protótipo de lado duplo de 4x6 cm pela metade no eixo longo.
-
Corte o cabeçalho 40P macho em pedaços:
- 2 off 12P
- 3 off 3P
- 6 desligado 2P.
-
Corte o cabeçalho 40P fêmea em pedaços:
- 2 off 12P
- 1 off 6P
- Solda 2 fora do cabeçalho 12Pfemale conforme mostrado.
- Cole o espaçador removido de um cabeçalho macho 3P (adicional) na parte inferior do interruptor SPDT com cola de cianoacrilato
- Do outro lado, solde 6 off 2P, 2 off 3Pmale header e a chave SPDT como mostrado.
- Solde 4 resistores de 10K (A, B, C, D preto) via cabo para o conector do pino GND (# 2 preto) e para A0 - pinos do cabeçalho A3 (# 5, # 6, # 7, # 8) e então através do orifício (amarelo) conforme mostrado (3 fotos + 1 diagrama).
- Rastreie 3,3 V dos PINOS de solda dos PINS LDR # 4, # 6, # 8, # 10 e rosqueie através do orifício até o pino VCC do cabeçalho feminino (verde).
- Rastreie 3,3 V no lado do coletor fêmea conforme mostrado (vermelho) soldando aos PINOS # 1, # 12, # 15.
- 3,3 V através do orifício do pino # 1 do cabeçote RAW soldado sobre o lado (vermelho).
- Trace a conexão laranja do PIN # 11 através do orifício para soldar o pino fêmea do outro lado, conforme mostrado.
- Trace e solde o fio de conexão azul de # 20 a # 30 e de # 31 a # 13 e # 16.
- Solde o pino da plataforma fêmea nº 11 ao pino da plataforma macho nº 11 através do orifício.
- Prepare 2 conectores duplos de 30 mm de comprimento com cabeçote 1P fêmea (1 azul, 1 verde). Retire e estanhe a outra extremidade.
- Solde o fio Dupont azul em # 28; soldar o fio Dupont verde a # 29.
- Na parte superior do Arduino, fixe o conector fêmea 6P e depois solde.
- Na parte superior do Arduino, fixe o cabeçote fêmea de ângulo reto 2P int # 29 e # 30 e depois solde.
- No lado inferior do Arduino, fixe os 2 pinos 12P e 1 dos 3P machos e, em seguida, solde.
- Insira os pinos 12P machos do Arduino nos conectores fêmeas do PCB 12P.
Etapa 3: Atualizando o MCU
O Arduino Pro Mini é convenientemente flasheado usando um conversor FTDI232 USB para TTL usando o conector fêmea 6P. Veja a foto acima para o alinhamento das 2 placas.
Certifique-se de que a configuração de 3,3 V seja escolhida em seu FTDI232. Siga as instruções aqui usando o código abaixo (use o link para GIST).
A biblioteca de baixa potência (anexada e https://github.com/rocketscream/Low-Power) precisa ser instalada.
Uma vez que o Arduino Pro Mini + PCB é instalado na caixa, ele ainda pode ser piscado quando os pinos do cabeçalho são expostos. Basta desconectar a unidade do controlador do quadro do painel, expondo o cabeçalho.
Rastreador solar de inclinação panorâmica com configuração I2C / EEPROM e ciclo de sono entre movimentos. A precisão da duração do ciclo do sono diminui à medida que a duração aumenta, mas é suficiente para esse propósito
/* |
* modificado a partir do código |
* por Mathias Leroy |
* |
* MODIFICAÇÕES V0.2 |
** I2C SET GET |
** EEPROM SET GET |
** REMOVER A SAÍDA SERIAL - I2C AFETADA |
** ATIVAR / DESATIVAR RASTREAMENTO |
** MOVER SERVOS PARA LIMITES VIA I2C |
** LEIA A INTENSIDADE MÉDIA ATUAL VIA I2C |
* MODIFICAÇÕES V0.3 |
** TROCAR PARA 2 MODOS - TRACK (NO I2C) e CONFIGURAR (USOS I2C) |
** DORMIR NO MODO DE PISTA (PRECISÃO MUITO BAIXA DEVIDO A 8 SEGUNDOS CHUNKS) |
** RETIRAR / ANEXAR SERVOS AO DORMIR / ACORDAR (TRANSISTOR USADO EVENTUALMENTE) |
** REMOVER A POSIÇÃO INICIAL CONFIGURÁVEL (REDUNDANTE) |
** REMOVER CONFIGURABLE WAKE SECONDS (REDUNDANT) |
** REMOVER ATIVAR / DESATIVAR CONFIGURÁVEL (REDUNDANTE) |
** REMOVER O TRACKER CONFIGURÁVEL ATIVADO (USE O INTERRUPTOR DE HARDWARE) |
** REMOVER GETTER DE TENSÃO - USARÁ COMPONENTE I2C SEPARADO |
** ADICIONE REGISTRO SERIAL QUANDO NÃO USAR I2C |
*/ |
#incluir |
#incluir |
#incluir |
#incluir |
#incluir |
# defineEEPROM_VERSION1 |
# defineI2C_MSG_IN_SIZE3 |
#definePIN_LDR_TL A0 |
#definePIN_LDR_TR A1 |
#definePIN_LDR_BR A3 |
#definePIN_LDR_BL A2 |
# definePIN_SERVO_V11 |
# definePIN_SERVO_H5 |
# defineIDX_I2C_ADDR0 |
# defineIDX_V_ANGLE_MIN1 |
# defineIDX_V_ANGLE_MAX2 |
# defineIDX_V_SENSITIVITY3 |
# defineIDX_V_STEP4 |
# defineIDX_H_ANGLE_MIN5 |
# defineIDX_H_ANGLE_MAX6 |
# defineIDX_H_SENSITIVITY7 |
# defineIDX_H_STEP8 |
# defineIDX_SLEEP_MINUTES9 |
# defineIDX_V_DAWN_ANGLE10 |
# defineIDX_H_DAWN_ANGLE11 |
# defineIDX_DAWN_INTENSITY12 // média de todos os LDRS |
# defineIDX_DUSK_INTENSITY13 // média de todos os LDRS |
# defineIDX_END_EEPROM_SET14 |
# defineIDX_CURRENT_INTENSITY15 // média de todos os LDRS - usado para calcular a luz não direta ambiante IDX_DAWN_INTENSITY |
# defineIDX_END_VALUES_GET16 |
# defineIDX_SIGN_117 |
# defineIDX_SIGN_218 |
# defineIDX_SIGN_319 |
Servo _servoH; |
Servo _servoV; |
byte _i2cVals [20] = {10, 10, 170, 20, 5, 10, 170, 20, 5, 20, 40, 10, 30, 40, 0, 0, 0, 0, 0, 0}; |
int _servoLoopDelay = 10; |
int _slowingDelay = 0; |
int _angleH = 90; |
int _angleV = 90; |
int _averageTop = 0; |
int _averageRight = 0; |
int _averageBottom = 0; |
int _averageLeft = 0; |
byte _i2cResponse = 0; |
bool _inConfigMode = false; |
voidsetup () |
{ |
Serial.begin (115200); |
getFromEeprom (); |
if (inConfigMode ()) { |
Serial.println ("Modo de configuração"); |
Serial.print ("Endereço I2C:"); |
Serial.println (_i2cVals [IDX_I2C_ADDR]); |
Wire.begin (_i2cVals [IDX_I2C_ADDR]); |
Wire.onReceive (receiveEvent); |
Wire.onRequest (requestEvent); |
}outro{ |
Serial.println ("Modo de rastreamento"); |
delay (5000); // tempo para tirar as mãos do caminho ao conectar a bateria etc. |
} |
} |
voidloop () |
{ |
getLightValues (); |
if (! _inConfigMode) { |
// ToDo: LIGUE O INTERRUPTOR DO TRANSISTOR |
_servoH.attach (PIN_SERVO_H); |
_servoV.attach (PIN_SERVO_V); |
para (int i = 0; i <20; i ++) { |
if (i! = 0) { |
getLightValues (); |
} |
moveServos (); |
} |
atraso (500); |
_servoH.detach (); |
_servoV.detach (); |
// ToDo: DESLIGUE O INTERRUPTOR DO TRANSISTOR |
atraso (500); |
asleepFor ((_ i2cVals [IDX_SLEEP_MINUTES] * 60) / 8); |
} |
} |
//---------------------------------MODO ATUAL |
boolinConfigMode () { |
pinMode (PIN_SERVO_H, INPUT); |
_inConfigMode = digitalRead (PIN_SERVO_H) == 1; |
return _inConfigMode; |
} |
// --------------------------------- EEPROM |
voidgetFromEeprom () { |
E se( |
EEPROM.read (IDX_SIGN_1)! = 'S' || |
EEPROM.read (IDX_SIGN_2)! = 'T' || |
EEPROM.read (IDX_SIGN_3)! = EEPROM_VERSION |
) EEPROM_write_default_configuration (); |
EEPROM_read_configuration (); |
} |
voidEEPROM_write_default_configuration () { |
Serial.println ("EEPROM_write_default_configuration"); |
para (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
EEPROM.update (i, _i2cVals ); |
} |
EEPROM.update (IDX_SIGN_1, 'S'); |
EEPROM.update (IDX_SIGN_2, 'T'); |
EEPROM.update (IDX_SIGN_3, EEPROM_VERSION); |
} |
voidEEPROM_read_configuration () { |
Serial.println ("EEPROM_read_configuration"); |
para (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
_i2cVals = EEPROM.read (i); |
//Serial.println(String(i) + "=" + _i2cVals ); |
} |
} |
// --------------------------------- I2C |
voidreceiveEvent (contagem interna) { |
if (contagem == I2C_MSG_IN_SIZE) |
{ |
char cmd = Wire.read (); |
índice de bytes = Wire.read (); |
valor do byte = Wire.read (); |
switch (cmd) { |
case'G ': |
if (índice <IDX_END_VALUES_GET) { |
_i2cResponse = _i2cVals [índice]; |
} |
pausa; |
case'S ': |
if (índice <IDX_END_EEPROM_SET) { |
_i2cVals [índice] = valor; |
EEPROM.update (índice, _i2cVals [índice]); |
} |
pausa; |
predefinição: |
Retorna; |
} |
} |
} |
voidrequestEvent () |
{ |
Wire.write (_i2cResponse); |
} |
// --------------------------------- LDRs |
voidgetLightValues () { |
int valueTopLeft = analogRead (PIN_LDR_TL); |
int valueTopRight = analogRead (PIN_LDR_TR); |
valor internoBottomRight = analogRead (PIN_LDR_BR); |
valor intBottomLeft = analogRead (PIN_LDR_BL); |
_averageTop = (valueTopLeft + valueTopRight) / 2; |
_averageRight = (valueTopRight + valueBottomRight) / 2; |
_averageBottom = (valueBottomRight + valueBottomLeft) / 2; |
_averageLeft = (valueBottomLeft + valueTopLeft) / 2; |
int avgIntensity = (valueTopLeft + valueTopRight + valueBottomRight + valueBottomLeft) / 4; |
_i2cVals [IDX_CURRENT_INTENSITY] = mapa (avgIntensity, 0, 1024, 0, 255); |
} |
// --------------------------------- SERVOS |
voidmoveServos () { |
Serial.println ("moveServos"); |
if ((_averageLeft-_averageRight)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH-_i2cVals [IDX_H_STEP])> _ i2cVals [IDX_H_ANGLE_MIN]) { |
// indo para a esquerda |
Serial.println ("moveServos indo para a esquerda"); |
atraso (_slowingDelay); |
para (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH--); |
atraso (_servoLoopDelay); |
} |
} |
elseif ((_averageRight-_averageLeft)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH + _i2cVals [IDX_H_STEP]) <_ i2cVals [IDX_H_ANGLE_MAX]) { |
// indo para a direita |
Serial.println ("moveServos indo para a esquerda"); |
atraso (_slowingDelay); |
para (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH ++); |
atraso (_servoLoopDelay); |
} |
} |
outro { |
// fazendo nada |
Serial.println ("moveServos sem fazer nada"); |
atraso (_slowingDelay); |
} |
if ((_averageTop-_averageBottom)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV + _i2cVals [IDX_V_STEP]) <_ i2cVals [IDX_V_ANGLE_MAX]) { |
// subindo |
Serial.println ("moveServos subindo"); |
atraso (_slowingDelay); |
para (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV ++); |
atraso (_servoLoopDelay); |
} |
} |
elseif ((_averageBottom-_averageTop)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV-_i2cVals [IDX_V_STEP])> _ i2cVals [IDX_V_ANGLE_MIN]) { |
// indo para baixo |
Serial.println ("moveServos indo para baixo"); |
atraso (_slowingDelay); |
para (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV--); |
atraso (_servoLoopDelay); |
} |
} |
outro { |
Serial.println ("moveServos sem fazer nada"); |
atraso (_slowingDelay); |
} |
} |
//---------------------------------DORMIR |
voidasleepFor (unsignedint eightSecondSegments) { |
Serial.println ("asleepFor"); |
for (unsignedint sleepCounter = eightSecondSegments; sleepCounter> 0; sleepCounter--) |
{ |
LowPower.powerDown (SLEEP_8S, ADC_OFF, BOD_OFF); |
} |
} |
visualizar rawtilt_pan_tracker_0.3.ino hospedado com ❤ por GitHub
Etapa 4: Montagem do revestimento do circuito
- Certifique-se de que o Ardiuno Pro Mini seja inserido nos cabeçalhos do PCB.
- Insira a base da caixa do controlador SOLAR TRACKER nas paredes da caixa do controlador SOLAR TRACKER e fixe com 2 parafusos auto-roscantes escareados de inox 4G x 6mm.
- Insira Ardiuno Pro Mini + PCB com 6P Header encaixando no vazio na base da caixa do controlador SOLAR TRACKER.
- Insira a tampa da caixa do controlador SOLAR TRACKER nas paredes da caixa do controlador SOLAR TRACKER e fixe com 2 parafusos auto-roscantes escareados de inox 4G x 6mm.
- Fixe o conjunto acima à base da estrutura do painel com 4 parafusos auto-roscantes escareados de inox 4G x 6mm.
Etapa 5: Conectando os condutores da plataforma ao controlador
As conexões pertinentes prontas do Instructable anterior são 4 conexões LDR 2P desligadas e 2 conexões 3P desligadas dos servos. O que é temporário até que a recarga esteja pronta é a bateria. Use um LiPo de 3,7 V que termina em uma conexão DuPont 2P por enquanto.
-
Insira as conexões LDR (sem polaridade) de cima:
- Canto superior direito
- Cima Esquerda
- Canto inferior direito
- Inferior esquerdo
-
Insira as conexões Servo (com o fio de sinal à esquerda) de cima:
- Horizontal
- Vertical
- ESPERE ATÉ PRONTO PARA O TESTE, ENTÃO: Insira o cabo de alimentação de 3,7 Vcc + ve para cima e -ve para baixo.
Etapa 6: Testando o controlador
Conforme declarado antes, o software não foi otimizado para o fluxo de trabalho de carregamento solar. Ele pode ser testado e ajustado usando fontes de luz naturais (sol) e não naturais.
Para testar o rastreamento em um ambiente controlado, pode ser conveniente definir SLEEP MINUTES para um valor inferior (consulte a próxima etapa).
Etapa 7: configuração via I2C usando entrada do console
Isso explica a configuração do controlador por meio de um segundo MCU, inserindo as configurações em uma janela do console.
- Carregue o seguinte script em um D1M WIFI BLOCK (ou Wemos D1 Mini).
- Desconecte o USB do PC
-
CONEXÕES DE PINOS: -ve (Controlador) => GND (D1M) + ve (Controlador) => 3V3 (D1M) SCL (Controlador) => D1 (D1M)
SDA (controlador) => D2 (D1M)
- Gire a chave SPDT para CONFIG
- Conecte o USB ao PC
- No IDE do Arduino, inicie uma janela de console com a porta COM correta
- Certifique-se de que "Nova linha" e "9600 baud" estão selecionados
- Os comandos são inseridos na caixa de texto de envio seguidos da tecla Enter
- Os comandos estão no formato Character byte byte
- Se o segundo byte (terceiro segmento) não for incluído 0 (zero) é enviado pelo script
- Tenha cuidado ao usar a entrada serial; reveja o que você digitou antes de apertar a tecla "Enter". Se você estiver bloqueado (por exemplo, alterando o endereço I2C para um valor que você esqueceu), você precisará atualizar o firmware do controlador novamente.
As variações suportadas no primeiro caractere do comando são:
- E (Ativar rastreamento de servo) útil para parar o movimento durante a configuração. Esta é a entrada usando: E 0
- D (Desativar rastreamento de servo) útil para iniciar o rastreamento automático se não for reinicializar o dispositivo. Esta é a entrada usando: D 0
- G (obter valor de configuração) lê valores de EEPROM e IN-MEMORY: Esta é a entrada usando: G (o índice é valores de byte válidos 0 - 13 e 15)
- S (Definir valor EEPROM) define valores para EEPROM que estão disponíveis após as reinicializações. Esta é a entrada usando: S (índice é valores de bytes válidos de 0 a 13, valor é valores de bytes válidos e variam por propriedade)
O código é a verdade para os índices, mas o seguinte é usado como um guia para valores / comentários válidos:
- I2C ADDRESS 0 - endereço escravo do controlador, o mestre precisa disso para se comunicar com o controlador (padrão 10)
- ÂNGULO VERTICAL MÍNIMO 1 - limite inferior do servo vertical de ângulo (padrão 10, faixa 0 - 180)
- ÂNGULO VERTICAL MÁXIMO 2 - limite superior do servo vertical de ângulo (padrão 170, faixa 0 - 180)
- SENSIBILIDADE LDR VERTICAL 3 - Margem de leitura LDR vertical (padrão 20, intervalo 0 - 1024)
- PASSO 4 DO ÂNGULO VERTICAL - passos do servo vertical do ângulo em cada ajuste (padrão 5, intervalo 1 - 20)
- ÂNGULO HORIZONTAL MÍNIMO - limite inferior do servo horizontal de 5 ângulos (padrão 10, intervalo 0 - 180)
- ÂNGULO MÁXIMO HORIZONTAL 6 - limite superior do servo horizontal de ângulo (padrão 170, intervalo 0 - 180)
- SENSIBILIDADE HORIZONTAL LDR 7 - Margem de leitura horizontal do LDR (padrão 20, intervalo 0 - 1024)
- ANGULO HORIZONTAL PASSO 8 - passos servo horizontais em cada ajuste (padrão 5, intervalo 1 - 20)
- SLEEP MINUTES 9 - o período de sono aproximado entre o rastreamento (padrão 20, intervalo 1 - 255)
- ÂNGULO VERTICAL DE AMANHECER 10 - USO FUTURO - o ângulo vertical para retornar quando o sol se põe
- ÂNGULO DE AMANHECER HORIZONTAL 11 - USO FUTURO - o ângulo horizontal para retornar quando o sol se põe
- INTENSIDADE DAWN 12 - USO FUTURO - a média mínima de todos os LDRs que aciona o início do rastreamento diário do sol
- DUSK INTENSITY 13 - FUTURE USE - a média mínima de todos os LDRs que aciona o fim do rastreio solar diário
- MARCADOR DE VALORES DE FIM DE EEPROM 14 - VALOR NÃO UTILIZADO
- INTENSIDADE DE CORRENTE 15 - a porcentagem média atual da intensidade de luz
- MARCADOR DE FIM DE VALORES IN-MEMORY 16 - VALOR NÃO UTILIZADO.
Captura a entrada serial (entrada do teclado na janela do console) e a encaminha para um escravo I2C no formato char, byte, byte
#incluir |
# defineI2C_MSG_IN_SIZE2 |
# defineI2C_MSG_OUT_SIZE3 |
# defineI2C_SLAVE_ADDRESS10 |
boolean _newData = false; |
const byte _numChars = 32; |
char _receivedChars [_numChars]; // um array para armazenar os dados recebidos |
voidsetup () { |
Serial.begin (9600); |
Wire.begin (D2, D1); |
atraso (5000); |
} |
voidloop () { |
recvWithEndMarker (); |
parseSendCommands (); |
} |
voidrecvWithEndMarker () { |
byte estático ndx = 0; |
char endMarker = '\ n'; |
char rc; |
while (Serial.available ()> 0 && _newData == false) { |
rc = Serial.read (); |
if (rc! = endMarker) { |
_receivedChars [ndx] = rc; |
ndx ++; |
if (ndx> = _numChars) { |
ndx = _numChars - 1; |
} |
} outro { |
_receivedChars [ndx] = '\ 0'; // termina a string |
ndx = 0; |
_newData = true; |
} |
} |
} |
voidparseSendCommands () { |
if (_newData == true) { |
constchar delim [2] = ""; |
char * token; |
token = strtok (_receivedChars, delim); |
char cmd = _receivedChars [0]; |
índice de bytes = 0; |
valor do byte = 0; |
int i = 0; |
while (token! = NULL) { |
//Serial.println(token); |
i ++; |
switch (i) { |
caso 1: |
token = strtok (NULL, delim); |
índice = atoi (token); |
pausa; |
case2: |
token = strtok (NULL, delim); |
if (token! = NULL) { |
valor = atoi (token); |
} |
pausa; |
predefinição: |
token = NULL; |
} |
} |
sendCmd (cmd, índice, valor); |
_newData = false; |
} |
} |
voidsendCmd (char cmd, índice de byte, valor de byte) { |
Serial.println ("-----"); |
Serial.println ("Enviando comando:"); |
Serial.println ("\ t" + String (cmd) + "" + String (índice) + "" + String (valor)); |
Serial.println ("-----"); |
Wire.beginTransmission (I2C_SLAVE_ADDRESS); // transmitir para o dispositivo |
Wire.write (cmd); // envia um char |
Wire.write (índice); // envia um byte |
Wire.write (valor); // envia um byte |
Wire.endTransmission (); |
resposta de byte = 0; |
bool hadResponse = false; |
if (cmd == 'G') { |
Wire.requestFrom (I2C_SLAVE_ADDRESS, 1); |
while (Wire.available ()) // escravo pode enviar menos do que o solicitado |
{ |
hadResponse = true; |
resposta = Wire.read (); |
} |
if (hadResponse == true) { |
Serial.println ("Obtendo resposta:"); |
Serial.println (resposta); |
}outro{ |
Serial.println ("Sem resposta, verifique o endereço / conexão"); |
} |
} |
} |
ver rawd1m_serial_input_i2c_char_byte_byte_v0.1.ino hospedado com ❤ por GitHub
Etapa 8: Próximas etapas
Verifique periodicamente para verificar se há alterações no software / hardware.
Modifique o software / hardware de acordo com seus requisitos.
Comente sobre quaisquer solicitações / otimizações.
Recomendado:
Tutorial do LoRa GPS Tracker - LoRaWAN com Dragino e TTN: 7 etapas
Tutorial do LoRa GPS Tracker | LoRaWAN com Dragino e TTN: Ei, e aí, pessoal! Akarsh aqui da CETech. Alguns projetos atrás, demos uma olhada no LoRaWAN Gateway de Dragino. Conectamos nós diferentes ao Gateway e transmitimos dados dos nós para o Gateway usando TheThingsNetwork como o s
DIY GPS Tracker --- Aplicativo Python: 5 etapas (com imagens)
DIY GPS Tracker --- Aplicativo Python: Participei de um evento de ciclismo há duas semanas. Depois de terminar, quis verificar o percurso e a velocidade que rodei naquele momento. Infelizmente, isso não foi alcançado. Agora eu uso o ESP32 para fazer um rastreador GPS, e vou usá-lo para registrar minha rota de ciclismo
DIY Fitness Tracker relógio inteligente com oxímetro e frequência cardíaca - Módulos eletrônicos modulares da TinyCircuits - Menor arcada: 6 etapas
DIY Fitness Tracker relógio inteligente com oxímetro e frequência cardíaca | Módulos eletrônicos modulares da TinyCircuits | Smallest Arcade: Ei, e aí, pessoal! Akarsh aqui da CETech. Hoje temos conosco alguns dos módulos sensores que são muito úteis no nosso dia a dia, mas em uma versão minúscula de si mesmos. Os sensores que temos hoje são muito pequenos em tamanho em comparação com o tra
Rastreador COVID19 de mesa com relógio! Raspberry Pi Powered Tracker: 6 etapas
Rastreador COVID19 de mesa com relógio! Raspberry Pi Powered Tracker: Sabemos que podemos morrer a qualquer momento, até eu posso morrer enquanto escrevo este post, afinal, eu eu, você, todos somos mortais. O mundo inteiro tremeu por causa da pandemia COVID19. Nós sabemos como prevenir isso, mas hey! sabemos como orar e por que orar, sabemos
Luvas Etextile VR para Vive Tracker: 13 etapas (com fotos)
Luvas ETextile VR para Vive Tracker: Este tutorial mostra como fazer luvas etextile para uso em VR com o Vive Tracker. Elas substituem os joysticks projetados para o Vive, tornando as interações de RV mais táteis e humanas. Elas são chamadas de luvas 'mudra' porque você aperta o índice e f