贱客 发表于 2013-4-8 21:16:40

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


各位有遇到过吗??如何解决?

春泥蛋炒饭 发表于 2013-4-9 02:08:42

这个错误提示表面上是说在红外库里定义过的函数在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 10:08:31

的确有冲突问题。

贱客 发表于 2013-4-9 10:22:25

春泥蛋炒饭 发表于 2013-4-9 02:08 static/image/common/back.gif
这个错误提示表面上是说在红外库里定义过的函数在Tone里又重复定义了,实际原因是红外库和Tone都使用了相同 ...

谢谢,不过 tone() 是 ardino 自带的,如果有冲突,看来应该在IRremote里修改了。

春泥蛋炒饭 发表于 2013-4-9 14:06:35

贱客 发表于 2013-4-9 10:22 static/image/common/back.gif
谢谢,不过 tone() 是 ardino 自带的,如果有冲突,看来应该在IRremote里修改了。

我是说,不使用tone函数而改用这个新函数,不是说让你去修改tone函数。当然你要修改红外库也行,但改变它用的计时器和重新写一遍差不多,比较一下哪个更简单。

贱客 发表于 2013-4-9 15:04:34

春泥蛋炒饭 发表于 2013-4-9 14:06 static/image/common/back.gif
我是说,不使用tone函数而改用这个新函数,不是说让你去修改tone函数。当然你要修改红外库也行,但改变它 ...

嗯,有修改 IRremote 的打算:lol。。主要是命名习惯看着别扭

Pizzro 发表于 2013-7-19 13:27:17

mark..........
页: [1]
查看完整版本: tone() 和 IRremote 冲突??