tone() 和 IRremote 冲突??
core.a(Tone.cpp.o): In function `__vector_7':xxx\arduino-1.0.3\hardware\arduino\cores\arduino/Tone.cpp:535: multiple definition of `__vector_7'
IRremote\IRremote.cpp.o:xxx\Documents\Arduino\libraries\IRremote/IRremote.cpp:311: first defined here
各位有遇到过吗??如何解决? 这个错误提示表面上是说在红外库里定义过的函数在Tone里又重复定义了,实际原因是红外库和Tone都使用了相同的内部计时器TIMER2(在各自的ISR函数里),换名字是不解决根本问题的。如果你不熟悉avr的中断处理函数ISR,修改哪一方都不靠谱,考虑下面的Tone的替代办法:
arduino的几个延时函数都是用的timer 0。这里有个不用timer2而用延时函数的发声函数,用它替代Tone应该可以避开与红外库的计时器冲突:void newtone(byte tonePin, int frequency, int duration) {
int period = 1000000L / frequency;
int pulse = period / 2;
for (long i = 0; i < duration * 1000L; i += period) {
digitalWrite(tonePin, HIGH);
delayMicroseconds(pulse);
digitalWrite(tonePin, LOW);
delayMicroseconds(pulse);
}
} 的确有冲突问题。 春泥蛋炒饭 发表于 2013-4-9 02:08 static/image/common/back.gif
这个错误提示表面上是说在红外库里定义过的函数在Tone里又重复定义了,实际原因是红外库和Tone都使用了相同 ...
谢谢,不过 tone() 是 ardino 自带的,如果有冲突,看来应该在IRremote里修改了。
贱客 发表于 2013-4-9 10:22 static/image/common/back.gif
谢谢,不过 tone() 是 ardino 自带的,如果有冲突,看来应该在IRremote里修改了。
我是说,不使用tone函数而改用这个新函数,不是说让你去修改tone函数。当然你要修改红外库也行,但改变它用的计时器和重新写一遍差不多,比较一下哪个更简单。 春泥蛋炒饭 发表于 2013-4-9 14:06 static/image/common/back.gif
我是说,不使用tone函数而改用这个新函数,不是说让你去修改tone函数。当然你要修改红外库也行,但改变它 ...
嗯,有修改 IRremote 的打算:lol。。主要是命名习惯看着别扭 mark..........
页:
[1]