/* Copyright © 2015 Hasan Yavuz Özderya This file is part of serialplot. serialplot 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 3 of the License, or (at your option) any later version. serialplot is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with serialplot. If not, see . */ #include "framebuffer.h" FrameBuffer::FrameBuffer(size_t size) : data(size, 0.) { } void FrameBuffer::resize(size_t size) { size_t old_size = this->size(); size_t new_size = size; if (new_size < old_size) { data.remove(0, old_size - new_size); } else if (new_size > old_size) { // This is seriously inefficient! for (size_t i = old_size; i < new_size; i++) { data.prepend(0); } } } void FrameBuffer::addSamples(QVector samples) { int offset = size() - samples.size(); if (offset < 0) { // new samples exceed the size of frame buffer // excess part (from beginning) of the input will be ignored for (unsigned int i = 0; i < size(); i++) { data[i] = samples[i - offset]; } } else if (offset == 0) // input is the same size as the framebuffer { data = samples; } else // regular case; input is smaller than framebuffer { // shift old samples int shift = samples.size(); for (int i = 0; i < offset; i++) { data[i] = data[i + shift]; } // place new samples for (int i = 0; i < samples.size(); i++) { data[offset + i] = samples[i]; } } } void FrameBuffer::clear() { data.fill(0); } size_t FrameBuffer::size() const { return (size_t) data.size(); } QPointF FrameBuffer::sample(size_t i) const { return QPointF(i, data[i]); } QRectF FrameBuffer::boundingRect() const { return qwtBoundingRect(*this); }