Mercurial > hg > svcore
view data/model/DenseThreeDimensionalModel.cpp @ 147:3a13b0d4934e
* Reorganising code base. This revision will not compile.
author | Chris Cannam |
---|---|
date | Mon, 31 Jul 2006 11:44:37 +0000 |
parents | |
children |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2006 Chris Cannam. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #include "DenseThreeDimensionalModel.h" #include <QTextStream> DenseThreeDimensionalModel::DenseThreeDimensionalModel(size_t sampleRate, size_t windowSize, size_t yBinCount, bool notifyOnAdd) : m_sampleRate(sampleRate), m_windowSize(windowSize), m_yBinCount(yBinCount), m_minimum(0.0), m_maximum(0.0), m_notifyOnAdd(notifyOnAdd), m_sinceLastNotifyMin(-1), m_sinceLastNotifyMax(-1), m_completion(100) { } bool DenseThreeDimensionalModel::isOK() const { return true; } size_t DenseThreeDimensionalModel::getSampleRate() const { return m_sampleRate; } size_t DenseThreeDimensionalModel::getStartFrame() const { return 0; } size_t DenseThreeDimensionalModel::getEndFrame() const { return m_windowSize * m_data.size() + (m_windowSize - 1); } Model * DenseThreeDimensionalModel::clone() const { DenseThreeDimensionalModel *model = new DenseThreeDimensionalModel (m_sampleRate, m_windowSize, m_yBinCount); model->m_minimum = m_minimum; model->m_maximum = m_maximum; for (size_t i = 0; i < m_data.size(); ++i) { model->setBinValues(i * m_windowSize, m_data[i]); } return model; } size_t DenseThreeDimensionalModel::getWindowSize() const { return m_windowSize; } void DenseThreeDimensionalModel::setWindowSize(size_t sz) { m_windowSize = sz; } size_t DenseThreeDimensionalModel::getYBinCount() const { return m_yBinCount; } void DenseThreeDimensionalModel::setYBinCount(size_t sz) { m_yBinCount = sz; } float DenseThreeDimensionalModel::getMinimumLevel() const { return m_minimum; } void DenseThreeDimensionalModel::setMinimumLevel(float level) { m_minimum = level; } float DenseThreeDimensionalModel::getMaximumLevel() const { return m_maximum; } void DenseThreeDimensionalModel::setMaximumLevel(float level) { m_maximum = level; } void DenseThreeDimensionalModel::getBinValues(long windowStart, BinValueSet &result) const { QMutexLocker locker(&m_mutex); long index = windowStart / m_windowSize; if (index >= 0 && index < long(m_data.size())) { result = m_data[index]; } else { result.clear(); } while (result.size() < m_yBinCount) result.push_back(m_minimum); } float DenseThreeDimensionalModel::getBinValue(long windowStart, size_t n) const { QMutexLocker locker(&m_mutex); long index = windowStart / m_windowSize; if (index >= 0 && index < long(m_data.size())) { const BinValueSet &s = m_data[index]; if (n < s.size()) return s[n]; } return m_minimum; } void DenseThreeDimensionalModel::setBinValues(long windowStart, const BinValueSet &values) { QMutexLocker locker(&m_mutex); long index = windowStart / m_windowSize; while (index >= long(m_data.size())) { m_data.push_back(BinValueSet()); } bool newExtents = (m_data.empty() && (m_minimum == m_maximum)); bool allChange = false; for (size_t i = 0; i < values.size(); ++i) { if (newExtents || values[i] < m_minimum) { m_minimum = values[i]; allChange = true; } if (newExtents || values[i] > m_maximum) { m_maximum = values[i]; allChange = true; } } m_data[index] = values; if (m_notifyOnAdd) { if (allChange) { emit modelChanged(); } else { emit modelChanged(windowStart, windowStart + m_windowSize); } } else { if (allChange) { m_sinceLastNotifyMin = -1; m_sinceLastNotifyMax = -1; emit modelChanged(); } else { if (m_sinceLastNotifyMin == -1 || windowStart < m_sinceLastNotifyMin) { m_sinceLastNotifyMin = windowStart; } if (m_sinceLastNotifyMax == -1 || windowStart > m_sinceLastNotifyMax) { m_sinceLastNotifyMax = windowStart; } } } } QString DenseThreeDimensionalModel::getBinName(size_t n) const { if (m_binNames.size() > n) return m_binNames[n]; else return ""; } void DenseThreeDimensionalModel::setBinName(size_t n, QString name) { while (m_binNames.size() <= n) m_binNames.push_back(""); m_binNames[n] = name; emit modelChanged(); } void DenseThreeDimensionalModel::setBinNames(std::vector<QString> names) { m_binNames = names; emit modelChanged(); } void DenseThreeDimensionalModel::setCompletion(int completion) { if (m_completion != completion) { m_completion = completion; if (completion == 100) { m_notifyOnAdd = true; // henceforth emit modelChanged(); } else if (!m_notifyOnAdd) { if (m_sinceLastNotifyMin >= 0 && m_sinceLastNotifyMax >= 0) { emit modelChanged(m_sinceLastNotifyMin, m_sinceLastNotifyMax + m_windowSize); m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; } else { emit completionChanged(); } } else { emit completionChanged(); } } } void DenseThreeDimensionalModel::toXml(QTextStream &out, QString indent, QString extraAttributes) const { out << Model::toXmlString (indent, QString("type=\"dense\" dimensions=\"3\" windowSize=\"%1\" yBinCount=\"%2\" minimum=\"%3\" maximum=\"%4\" dataset=\"%5\" %6") .arg(m_windowSize) .arg(m_yBinCount) .arg(m_minimum) .arg(m_maximum) .arg(getObjectExportId(&m_data)) .arg(extraAttributes)); out << indent; out << QString("<dataset id=\"%1\" dimensions=\"3\" separator=\" \">\n") .arg(getObjectExportId(&m_data)); for (size_t i = 0; i < m_binNames.size(); ++i) { if (m_binNames[i] != "") { out << indent + " "; out << QString("<bin number=\"%1\" name=\"%2\"/>\n") .arg(i).arg(m_binNames[i]); } } for (size_t i = 0; i < m_data.size(); ++i) { out << indent + " "; out << QString("<row n=\"%1\">").arg(i); for (size_t j = 0; j < m_data[i].size(); ++j) { if (j > 0) out << " "; out << m_data[i][j]; } out << QString("</row>\n"); } out << indent + "</dataset>\n"; } QString DenseThreeDimensionalModel::toXmlString(QString indent, QString extraAttributes) const { QString s; { QTextStream out(&s); toXml(out, indent, extraAttributes); } return s; } #ifdef INCLUDE_MOCFILES #include "DenseThreeDimensionalModel.moc.cpp" #endif