Re: 7318
Если сигнал подавать не с генератора, а просто музыку, анализатор хотя бы примерно правильно реагирует на сигнал?
Вы не вошли. Пожалуйста, войдите или зарегистрируйтесь.
Чтобы отправить ответ, вы должны войти или зарегистрироваться
Если сигнал подавать не с генератора, а просто музыку, анализатор хотя бы примерно правильно реагирует на сигнал?
Попробуйте загрузить этот скетч - http://rcl-radio.ru/?p=42903 для проверки анализатора спектра
Вроде работает значить сама плата рабочая.Да в этом скетче нету плавности когда вкл.музыку слишком быстро бегает.Но мне это не надо мне нужно добить 7318.
https://cloud.mail.ru/public/1jo1/CNF4burxd
Завтра или после завтра займусь вашим вопросом.
Протестируйте этот скетч:
#define UP 0x33B8E01F
#define DOWN 0x33B810EF
#define MENU 0x33B820DF
#define MUTE 0x33B8946B
#define IN 0x33B8C03F
#define AUTO_GAIN 1 // автонастройка по громкости (экспериментальная функция)
#define VOL_THR 35 // порог тишины (ниже него отображения на матрице не будет)
#define LOW_PASS 30 // нижний порог чувствительности шумов (нет скачков при отсутствии звука)
#define DEF_GAIN 80 // максимальный порог по умолчанию (при GAIN_CONTROL игнорируется)
#define FHT_N 128 // ширина спектра х2
#define LOG_OUT 1
// вручную забитый массив тонов, сначала плавно, потом круче
byte posOffset[20] = {2, 3, 4, 6, 8, 10, 12, 14, 16, 20, 25, 30, 35, 40, 50, 65, 80, 95, 110, 120};
#include <Wire.h> // Входит в состав Arduino IDE
#include <MsTimer2.h> // http://rcl-radio.ru/wp-content/uploads/2018/11/MsTimer2.zip
#include <LiquidCrystal.h> // Входит в состав Arduino IDE
#include <Encoder.h> // http://rcl-radio.ru/wp-content/uploads/2019/05/Encoder.zip
#include <EEPROM.h> // Входит в состав Arduino IDE
#include <TDA7318.h> // http://rcl-radio.ru/wp-content/uploads/2021/08/TDA7318.zip
#include <FHT.h> // http://forum.rcl-radio.ru/misc.php?action=pan_download&item=297&download=1
#include <boarddefs.h> // Входит в состав библиотеки IRremote
#include <IRremote.h> // http://rcl-radio.ru/wp-content/uploads/2019/06/IRremote.zip
TDA7318 tda;
Encoder myEnc(9, 8);//CLK, DT подключение энкодера
decode_results ir;
IRrecv irrecv(12); // указываем вывод модуля IR приемника
LiquidCrystal lcd(2, 3, 4, 5, 6, 7);// RS,E,D4,D5,D6,D7 подключение LCD
#define cbi(sfr, bit) (_SFR_BYTE(sfr) &= ~_BV(bit))
#define sbi(sfr, bit) (_SFR_BYTE(sfr) |= _BV(bit))
byte menu_set=100,menu,w2=1,z,z0,z1,w,w1,www,spek,mute,gr1,gr2;
int vol=0,fun_d,in=0,bass,treb,gain1,gain2,gain3,gain4,gain0,lf,rf,lr,rr,lf_old,rf_old,lr_old,rr_old,graf;
unsigned long newPosition,time,time1,oldPosition = -999;
byte gain_sp = DEF_GAIN;
unsigned long gainTimer;
byte maxValue, maxValue_f;
float k = 0.05;
int ur[32],urr[32],i1;
void setup(){
irrecv.enableIRIn();Wire.begin();Serial.begin(9600);lcd.begin(20, 2);
sbi(ADCSRA, ADPS2);
cbi(ADCSRA, ADPS1);
sbi(ADCSRA, ADPS0);
lcd.setCursor(0,0);lcd.print(F(" TDA7318 "));delay(1000);cl();// ЗАСТАВКА
pinMode(10,INPUT); // КНОПКА ЭНКОДЕРA
pinMode(11,INPUT_PULLUP); // INPUT
pinMode(16,INPUT_PULLUP); // SET
pinMode(17,INPUT_PULLUP); // MUTE
analogReference(INTERNAL);
MsTimer2::set(3, to_Timer);MsTimer2::start();
if(EEPROM.read(100)!=0){for(int i=0;i<101;i++){EEPROM.update(i,0);}}// очистка памяти при первом включении
vol = EEPROM.read(0);bass = EEPROM.read(1)-7;treb = EEPROM.read(2)-7;
gain1 = EEPROM.read(3);gain2 = EEPROM.read(4);gain3 = EEPROM.read(5);gain4 = EEPROM.read(6);
lr = EEPROM.read(7);rr = EEPROM.read(8);lf = EEPROM.read(9);rf = EEPROM.read(10);graf = EEPROM.read(11);
switch(in){
case 0: gain0 = gain1;break;
case 1: gain0 = gain2;break;
case 2: gain0 = gain3;break;
case 3: gain0 = gain4;break;}
audio();
}
void loop(){
if ( irrecv.decode( &ir )) {Serial.print("0x");Serial.println( ir.value,HEX);irrecv.resume();time=millis();w=1;if(spek==1){cl();spek=0;menu=0;}delay(50);}// IR приемник - чтение, в мониторе порта отображаются коды кнопок
if(ir.value==0){gr1=0;gr2=0;}// запрет нажатий не активных кнопок пульта
if (newPosition != oldPosition) {
if(spek==1){cl();spek=0;menu=0;}}
if(spek==0){
byte a1[8]={0b00000,0b10101,0b10101,0b10101,0b10101,0b10101,0b10101,0b00000};
byte a2[8]={0b00000,0b10100,0b10100,0b10100,0b10100,0b10100,0b10100,0b00000};
byte a3[8]={0b00000,0b10000,0b10000,0b10000,0b10000,0b10000,0b10000,0b00000};
lcd.createChar(0,a1);lcd.createChar(1,a2);lcd.createChar(2,a3);
}
if(spek==1||menu_set==5){
if(graf==0){
byte v1[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11011};
byte v2[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11011, 0b11011};
byte v3[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11011, 0b11011, 0b11011};
byte v4[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b11011, 0b11011, 0b11011, 0b11011};
byte v5[8] = {0b00000, 0b00000, 0b00000, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011};
byte v6[8] = {0b00000, 0b00000, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011};
byte v7[8] = {0b00000, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011};
byte v8[8] = {0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011, 0b11011};
lcd.createChar(0, v1);lcd.createChar(1, v2);lcd.createChar(2, v3);lcd.createChar(3, v4);
lcd.createChar(4, v5);lcd.createChar(5, v6);lcd.createChar(6, v7);lcd.createChar(7, v8);
}
if(graf==1){
byte v1[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01110};
byte v2[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01110, 0b01110};
byte v3[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01110, 0b01110, 0b01110};
byte v4[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b01110, 0b01110, 0b01110, 0b01110};
byte v5[8] = {0b00000, 0b00000, 0b00000, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110};
byte v6[8] = {0b00000, 0b00000, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110};
byte v7[8] = {0b00000, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110};
byte v8[8] = {0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110, 0b01110};
lcd.createChar(0, v1);lcd.createChar(1, v2);lcd.createChar(2, v3);lcd.createChar(3, v4);
lcd.createChar(4, v5);lcd.createChar(5, v6);lcd.createChar(6, v7);lcd.createChar(7, v8);}
if(graf==2){
byte v1[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01010};
byte v2[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01010, 0b01010};
byte v3[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b01010, 0b01010, 0b01010};
byte v4[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b01010, 0b01010, 0b01010, 0b01010};
byte v5[8] = {0b00000, 0b00000, 0b00000, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010};
byte v6[8] = {0b00000, 0b00000, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010};
byte v7[8] = {0b00000, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010};
byte v8[8] = {0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010, 0b01010};
lcd.createChar(0, v1);lcd.createChar(1, v2);lcd.createChar(2, v3);lcd.createChar(3, v4);
lcd.createChar(4, v5);lcd.createChar(5, v6);lcd.createChar(6, v7);lcd.createChar(7, v8);}
if(graf==3){
byte v1[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b10101};
byte v2[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b10101, 0b10101};
byte v3[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b10101, 0b10101, 0b10101};
byte v4[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b10101, 0b10101, 0b10101, 0b10101};
byte v5[8] = {0b00000, 0b00000, 0b00000, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101};
byte v6[8] = {0b00000, 0b00000, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101};
byte v7[8] = {0b00000, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101};
byte v8[8] = {0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101, 0b10101};
lcd.createChar(0, v1);lcd.createChar(1, v2);lcd.createChar(2, v3);lcd.createChar(3, v4);
lcd.createChar(4, v5);lcd.createChar(5, v6);lcd.createChar(6, v7);lcd.createChar(7, v8);}
if(graf==4){
byte v1[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11111};
byte v2[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11111, 0b11111};
byte v3[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b00000, 0b11111, 0b11111, 0b11111};
byte v4[8] = {0b00000, 0b00000, 0b00000, 0b00000, 0b11111, 0b11111, 0b11111, 0b11111};
byte v5[8] = {0b00000, 0b00000, 0b00000, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111};
byte v6[8] = {0b00000, 0b00000, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111};
byte v7[8] = {0b00000, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111};
byte v8[8] = {0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111, 0b11111};
lcd.createChar(0, v1);lcd.createChar(1, v2);lcd.createChar(2, v3);lcd.createChar(3, v4);
lcd.createChar(4, v5);lcd.createChar(5, v6);lcd.createChar(6, v7);lcd.createChar(7, v8);}
}
if(mute==0){
if(((digitalRead(10)==LOW||ir.value==MENU)&&menu_set==100)){spek=0;menu++;cl();myEnc.write(0);time=millis();w=1;w1=1;if(menu>2){menu=0;}}// menu
if((digitalRead(10)==LOW&&menu==100)){spek=0;menu_set++;cl();myEnc.write(0);time=millis();w=1;w1=1;if(menu_set>5){menu_set=0;}}// menu
if(digitalRead(11)==LOW||ir.value==IN){in++;cl();myEnc.write(0);time=millis();w=1;w1=1;if(in>3){in=0;}lcd.setCursor(4,0);lcd.print("INPUT ");lcd.print(in+1);audio();delay(1500);cl();}// input
if(digitalRead(16)==LOW&&menu_set==100){menu_set=0;menu=100;spek=0;cl();myEnc.write(0);time=millis();w=1;w1=1;lcd.setCursor(4,0);lcd.print("SET MENU");delay(1500);cl();}// menu
if(digitalRead(16)==LOW&&menu_set<100){menu_set=100;menu=0;spek=0;cl();myEnc.write(0);time=millis();w=1;w1=1;lcd.setCursor(3,0);lcd.print("MAIN MENU");delay(1500);cl();}// menu
}
if((digitalRead(17)==LOW||ir.value==MUTE)&&mute==0){mute=1;spek=0;cl();lf_old=lf,rf_old=rf,lr_old=lr,rr_old=rr; lf=31,rf=31,lr=31,rr=31;menu=100;menu_set=100;myEnc.write(0);audio();lcd.setCursor(6,0);lcd.print("MUTE");}
if((digitalRead(17)==LOW||ir.value==MUTE)&&mute==1){mute=0;spek=0;cl();lf=lf_old,rf=rf_old,lr=lr_old,rr=rr_old;menu=0;w=1;myEnc.write(0);time=millis();audio();cl();}
//////// VOLUME ////////////////////////////////////////////////////////////////
if(menu==0){
if(ir.value==UP){vol++;gr1=1;gr2=0;cl1();time=millis();w=1;w1=1;if(vol>63){vol=63;}if(vol<0){vol=0;}audio();}// кнопка >
if(ir.value==0xFFFFFFFF and gr1==1){vol++;gr2=0;cl1();time=millis();w=1;w1=1;if(vol>63){vol=63;}if(vol<0){vol=0;}audio();}// кнопка >>>>>>
if(ir.value==DOWN){vol--;gr1=0;gr2=1;cl1();time=millis();w=1;w1=1;if(vol>63){vol=63;}if(vol<0){vol=0;}audio();}// кнопка <
if(ir.value==0xFFFFFFFF and gr2==1){vol--;gr1=0;cl1();time=millis();w=1;w1=1;if(vol>63){vol=63;}if(vol<0){vol=0;}audio();}// кнопка <<<<<<
if (newPosition != oldPosition){oldPosition = newPosition;
vol=vol+newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(vol>63){vol=63;}if(vol<0){vol=0;}audio();}
lcd.setCursor(0,0);lcd.print(F("VOLUME "));
lcd.setCursor(7,0);lcd.print(63-vol);lcd.print(" ");
lcd.setCursor(11,0);lcd.print("IN ");lcd.print(in+1);
fun_d = map(vol, 0, 63, 48,0);
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0,1);lcd.write((uint8_t)2);}w=0;}}
/////// BASS ///////////////////////////////////////////////////////////////////
if(menu==1){
if(ir.value==DOWN){bass++;gr1=1;gr2=0;cl1();time=millis();w=1;w1=1;if(bass>7){bass=7;}if(bass<-7){bass=-7;}audio();}// кнопка >
if(ir.value==0xFFFFFFFF and gr1==1){bass++;gr2=0;cl1();time=millis();w=1;w1=1;if(bass>7){bass=7;}if(bass<-7){bass=-7;}audio();}// кнопка >>>>>>
if(ir.value==UP){bass--;gr1=0;gr2=1;cl1();time=millis();w=1;w1=1;if(bass>7){bass=7;}if(bass<-7){bass=-7;}audio();}// кнопка <
if(ir.value==0xFFFFFFFF and gr2==1){bass--;gr1=0;cl1();time=millis();w=1;w1=1;if(bass>7){bass=7;}if(bass<-7){bass=-7;}audio();}// кнопка <<<<<<
if (newPosition != oldPosition){oldPosition = newPosition;
bass=bass-newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(bass>7){bass=7;}if(bass<-7){bass=-7;}audio();}
lcd.setCursor(0,0);lcd.print(F("BASS "));
lcd.setCursor(9,0);lcd.print(bass);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d=bass*2+15;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
/////// TREB ///////////////////////////////////////////////////////////////////
if(menu==2){
if(ir.value==DOWN){treb++;gr1=1;gr2=0;cl1();time=millis();w=1;w1=1;if(treb>7){treb=7;}if(treb<-7){treb=-7;}audio();}// кнопка >
if(ir.value==0xFFFFFFFF and gr1==1){treb++;gr2=0;cl1();time=millis();w=1;w1=1;if(treb>7){treb=7;}if(treb<-7){treb=-7;}audio();}// кнопка >>>>>>
if(ir.value==UP){treb--;gr1=0;gr2=1;cl1();time=millis();w=1;w1=1;if(treb>7){treb=7;}if(treb<-7){treb=-7;}audio();}// кнопка <
if(ir.value==0xFFFFFFFF and gr2==1){treb--;gr1=0;cl1();time=millis();w=1;w1=1;if(treb>7){treb=7;}if(treb<-7){treb=-7;}audio();}// кнопка <<<<<<
if (newPosition != oldPosition){oldPosition = newPosition;
treb=treb-newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(treb>7){treb=7;}if(treb<-7){treb=-7;}audio();}
lcd.setCursor(0,0);lcd.print(F("TREBLE "));
lcd.setCursor(9,0);lcd.print(treb);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d=treb*2+15;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
//////////////// IN + GAIN /////////////////////////////////////////////////////////////
if(menu_set==0){
switch(in){
case 0: gain0 = gain1;break;
case 1: gain0 = gain2;break;
case 2: gain0 = gain3;break;
case 3: gain0 = gain4;break;}
if (newPosition != oldPosition) {
oldPosition = newPosition;
gain0=gain0-newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(gain0>3){gain0=3;}if(gain0<0){gain0=0;}audio();}
switch(in){
case 0: gain1 = gain0;break;
case 1: gain2 = gain0;break;
case 2: gain3 = gain0;break;
case 3: gain4 = gain0;break;
}
if(www==1){audio();www=0;}
lcd.setCursor(0,0);lcd.print(F("Gain IN"));lcd.print(in+1);
lcd.setCursor(8,0);lcd.print(" ");lcd.print(gain0*6.25);lcd.print(" ");lcd.setCursor(14,0);lcd.print("dB");fun_d=(gain0+1)*3;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+6,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+6,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+6,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+6,1);lcd.write((uint8_t)2);}}w=0;}
//////// LF ////////////////////////////////////////////////////////////////
if(menu_set==1){
if (newPosition != oldPosition){oldPosition = newPosition;
lf=lf+newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(lf>31){lf=31;}if(lf<0){lf=0;}audio();}
lcd.setCursor(0,0);lcd.print(F("ATT LF "));
lcd.setCursor(9,0);lcd.print(lf);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d = 31-lf;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
//////// LF ////////////////////////////////////////////////////////////////
if(menu_set==2){
if (newPosition != oldPosition){oldPosition = newPosition;
rf=rf+newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(rf>31){rf=31;}if(rf<0){rf=0;}audio();}
lcd.setCursor(0,0);lcd.print(F("ATT RF "));
lcd.setCursor(9,0);lcd.print(rf);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d = 31-rf;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
//////// LR ////////////////////////////////////////////////////////////////
if(menu_set==3){
if (newPosition != oldPosition){oldPosition = newPosition;
lr=lr+newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(lr>31){lr=31;}if(lr<0){lr=0;}audio();}
lcd.setCursor(0,0);lcd.print(F("ATT LR "));
lcd.setCursor(9,0);lcd.print(lr);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d = 31-lr;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
//////// RR ////////////////////////////////////////////////////////////////
if(menu_set==4){
if (newPosition != oldPosition){oldPosition = newPosition;
rr=rr+newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(rr>31){rr=31;}if(rr<0){rr=0;}audio();}
lcd.setCursor(0,0);lcd.print(F("ATT RR "));
lcd.setCursor(9,0);lcd.print(rr);lcd.print(" ");lcd.setCursor(12,0);lcd.print("dB ");
fun_d = 31-rr;
if(w==1){
for(z=0,z0=0,z1=0;z<=fun_d;z++,z1++){if(z1>2){z1=0;z0++;}
if(z1==1){lcd.setCursor(z0+3,1);lcd.write((uint8_t)0);lcd.setCursor(z0+1+3,1);lcd.print(" ");}}
if(z1==3){lcd.setCursor(z0+3,1);lcd.write((uint8_t)1);}
if(z1==2){lcd.setCursor(z0+3,1);lcd.write((uint8_t)2);}w=0;}}
///// set graf /////////////////////////////
if(menu_set==5){
if (newPosition != oldPosition){oldPosition = newPosition;
graf=graf-newPosition;myEnc.write(0);newPosition=0;time=millis();w=1;w1=1;if(graf>4){graf=0;}if(graf<0){graf=4;}}
lcd.setCursor(0,0);lcd.print(F("Graphics "));
lcd.setCursor(9,0);lcd.print(graf);lcd.print(" ");
lcd.setCursor(5,1);lcd.write((uint8_t)7);lcd.write((uint8_t)7);lcd.write((uint8_t)7);lcd.write((uint8_t)7);lcd.write((uint8_t)7);lcd.write((uint8_t)7);
}
//////// EEPROM //////////////////////////////////////////////////
if(millis()-time>10000 && w1==1&&mute==0){
EEPROM.update(0,vol);EEPROM.update(1,bass+7);EEPROM.update(2,treb+7);EEPROM.update(3,gain1);
EEPROM.update(4,gain2);EEPROM.update(5,gain3);EEPROM.update(6,gain4);
EEPROM.update(7,lr);EEPROM.update(8,rr);EEPROM.update(9,lf);EEPROM.update(10,rf);EEPROM.update(11,graf);
menu_set=100;menu=100;lcd.clear();w=1;w1=0;spek=1;}
/////// SPECTR /////////////////////////////////////////////////////////
if(spek==1){
analyzeAudio();
for (int pos = 0; pos < 20; pos++) {
if (fht_log_out[posOffset[pos]] > maxValue) maxValue = fht_log_out[posOffset[pos]];
lcd.setCursor(pos, 0);
int posLevel = map(fht_log_out[posOffset[pos]], LOW_PASS, gain_sp, 0, 19);posLevel = constrain(posLevel, 0, 19);
urr[pos] = posLevel;
if(urr[pos]<ur[pos]){ur[pos]=ur[pos]-1;}
else{ur[pos] = posLevel;}
if (ur[pos] > 7){lcd.write((uint8_t)ur[pos] - 8);lcd.setCursor(pos, 1);lcd.write((uint8_t)7);}
else {lcd.print(" ");lcd.setCursor(pos, 1);lcd.write((uint8_t)ur[pos]);}
}
if (AUTO_GAIN) {
if (millis() - gainTimer > 1500) {
maxValue_f = maxValue * k + maxValue_f * (1 - k);
if(maxValue_f > VOL_THR) gain_sp = maxValue_f;else gain_sp = DEF_GAIN;gainTimer = millis();}}
}/// end spec
}// loop
void cl(){ir.value=0;delay(300);lcd.clear();}
void cl1(){ir.value=0;delay(200);}
void audio(){
tda.setVolume(vol); // громкость 0...63
tda.setAttLR(lr); // аттенюатор LR 0...31
tda.setAttRR(rr); // аттенюатор RR 0...31
tda.setAttLF(lf); // аттенюатор LF 0...31
tda.setAttRF(rf); // аттенюатор RF 0...31
tda.setSwitch(in,gain0); // вход 0...3, усиление 0...3
tda.setBass(bass); // тембр НЧ -7...+7
tda.setTreble(treb); // тембр ВЧ -7...+7
}
void to_Timer(){newPosition = myEnc.read()/4;}
void analyzeAudio() {
for (int i = 0 ; i < FHT_N ; i++) {
int sample = analogRead(A0);
fht_input[i] = sample; // put real data into bins
}
fht_window(); // window the data for better frequency response
fht_reorder(); // reorder the data before doing the fht
fht_run(); // process the data in the fht
fht_mag_log(); // take the output of the fht
}
Ошибку показывает
exit status 1
'cl' was not declared in this scope
Скетч использует 24730 байт (76%) памяти устройства. Всего доступно 32256 байт.
Глобальные переменные используют 1540 байт (75%) динамической памяти, оставляя 508 байт для локальных переменных. Максимум: 2048 байт.
У меня компиляция проходит нормально, возможно не все скопировали.
скетч загрузил 4-строки последние не реагируют,это тут --byte posOffset[20] = {2, 3, 4, 6, 8, 10, 12, 14, 16, 20, 25, 30, 35, 40, 50, 65, 80, 95, 110, 120};
Загрузите по новой, я внес правки в скетч
Выше 2-ой строчки не поднимается.С права там вообще тишина
Используйте эти параметры:
byte posOffset[20] = {2,3,4,6,8,9,11,13,15,17,19,21,23,25,27,29, 32,34,37,40};
Может проблема в библиотеки.Я вот где то находил на просторах инета.
Винрар папку не могу сюда скинуть
на звук анализатор спектра реагирует?
Подаю с генератора который на ослике сигнал 100-миливольт,относительно работает.Ну это вообще слабый сигнал.Где подправить в ардуино входной сигнал
Вам нужно увеличить чувствительность?
Вам нужно увеличить чувствительность?
-Нет,уменьшить. В какой строке можно можно прибавить или уменьшить входной сигнал-D0- на ардуино.
Если не трудно как будет свободное время,добавьте сюда Функцию STANDBY
замените
analogReference(INTERNAL);
на
analogReference(DEFAULT);
Чтобы отправить ответ, вы должны войти или зарегистрироваться
Форум работает на PunBB, при поддержке Informer Technologies, Inc
|