Mercurial > hg > svgui
changeset 669:123ebecd12e6 tonioni
Merge from default branch
author | Chris Cannam |
---|---|
date | Tue, 16 Jul 2013 14:45:55 +0100 |
parents | 1a0fdad4af4d (current diff) 12e6efc8cdc0 (diff) |
children | 47735c9518e7 |
files | layer/FlexiNoteLayer.cpp layer/NoteLayer.cpp |
diffstat | 2 files changed, 43 insertions(+), 17 deletions(-) [+] |
line wrap: on
line diff
--- a/layer/NoteLayer.cpp Fri Jul 12 13:25:22 2013 +0100 +++ b/layer/NoteLayer.cpp Tue Jul 16 14:45:55 2013 +0100 @@ -38,6 +38,8 @@ #include <cmath> #include <utility> +//#define DEBUG_NOTE_LAYER 1 + NoteLayer::NoteLayer() : SingleColourLayer(), m_model(0), @@ -615,13 +617,17 @@ max = Pitch::getFrequencyForPitch(lrintf(max + 1)); } +#ifdef DEBUG_NOTE_LAYER std::cerr << "NoteLayer[" << this << "]::getScaleExtents: min = " << min << ", max = " << max << ", log = " << log << std::endl; +#endif } else if (log) { LogRange::mapRange(min, max); +#ifdef DEBUG_NOTE_LAYER std::cerr << "NoteLayer[" << this << "]::getScaleExtents: min = " << min << ", max = " << max << ", log = " << log << std::endl; +#endif } @@ -655,21 +661,29 @@ getScaleExtents(v, min, max, logarithmic); -// std::cerr << "NoteLayer[" << this << "]::getYForValue(" << val << "): min = " << min << ", max = " << max << ", log = " << logarithmic << std::endl; +#ifdef DEBUG_NOTE_LAYER + std::cerr << "NoteLayer[" << this << "]::getYForValue(" << val << "): min = " << min << ", max = " << max << ", log = " << logarithmic << std::endl; +#endif if (shouldConvertMIDIToHz()) { val = Pitch::getFrequencyForPitch(lrintf(val), lrintf((val - lrintf(val)) * 100)); -// std::cerr << "shouldConvertMIDIToHz true, val now = " << val << std::endl; +#ifdef DEBUG_NOTE_LAYER + std::cerr << "shouldConvertMIDIToHz true, val now = " << val << std::endl; +#endif } if (logarithmic) { val = LogRange::map(val); -// std::cerr << "logarithmic true, val now = " << val << std::endl; +#ifdef DEBUG_NOTE_LAYER + std::cerr << "logarithmic true, val now = " << val << std::endl; +#endif } int y = int(h - ((val - min) * h) / (max - min)) - 1; -// std::cerr << "y = " << y << std::endl; +#ifdef DEBUG_NOTE_LAYER + std::cerr << "y = " << y << std::endl; +#endif return y; }
--- a/layer/TimeValueLayer.cpp Fri Jul 12 13:25:22 2013 +0100 +++ b/layer/TimeValueLayer.cpp Tue Jul 16 14:45:55 2013 +0100 @@ -746,13 +746,18 @@ max = 0.0; log = false; + bool haveAutoAlignment = false; + if (shouldAutoAlign()) { if (!v->getValueExtents(m_model->getScaleUnits(), min, max, log)) { min = m_model->getValueMinimum(); max = m_model->getValueMaximum(); - } else if (log) { - LogRange::mapRange(min, max); + } else { + haveAutoAlignment = true; + if (log) { + LogRange::mapRange(min, max); + } } } else if (m_verticalScale == PlusMinusOneScale) { @@ -774,18 +779,21 @@ std::cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << std::endl; #endif - if (max == min) { - max = max + 0.5; - min = min - 0.5; - } else { - float margin = (max - min) / 10.0; - max = max + margin; - min = min - margin; - } + if (!haveAutoAlignment) { + + if (max == min) { + max = max + 0.5; + min = min - 0.5; + } else { + float margin = (max - min) / 10.0; + max = max + margin; + min = min - margin; + } #ifdef DEBUG_TIME_VALUE_LAYER - std::cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << " (after adjustment)" << std::endl; + std::cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << " (after adjustment)" << std::endl; #endif + } } int @@ -1255,7 +1263,7 @@ if (prec < 0) dp = -prec; round = powf(10.f, prec); #ifdef DEBUG_TIME_VALUE_LAYER - std::cerr << "inc = " << inc << ", round = " << round << std::endl; + std::cerr << "inc = " << inc << ", round = " << round << ", dp = " << dp << std::endl; #endif } @@ -1295,7 +1303,11 @@ } if (logarithmic) { - sprintf(buffer, "%.*g", dp < 2 ? 2 : dp, LogRange::unmap(dispval)); + double dv = LogRange::unmap(dispval); + int digits = trunc(log10f(dv)); + int sf = dp + (digits > 0 ? digits : 0); + if (sf < 2) sf = 2; + sprintf(buffer, "%.*g", sf, dv); } else { sprintf(buffer, "%.*f", dp, dispval); }