Files
mapmap/Paint.cpp

215 lines
3.9 KiB
C++

/*
* Paint.cpp
*
* (c) 2013 Sofian Audry -- info(@)sofianaudry(.)com
* (c) 2013 Alexandre Quessy -- alexandre(@)quessy(.)net
*
* 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 3 of the License, or
* (at your option) any later version.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "Paint.h"
#include "VideoImpl.h"
#include <iostream>
UidAllocator Paint::allocator;
Paint::Paint(uid id) : Element(id, &allocator)
{
}
Paint::~Paint()
{
allocator.free(getId());
}
bool Image::setUri(const QString &uri)
{
this->uri = uri;
build();
return !image.isNull();
}
/* Implementation of the Video class */
Video::Video(int id) : Texture(id),
uri(""),
impl(NULL)
{
impl = new VideoImpl("", false);
setRate(1);
setVolume(1);
}
Video::Video(const QString uri_, bool live, double rate, uid id):
Texture(id),
uri(uri_),
impl(NULL)
{
impl = new VideoImpl("", live);
setRate(rate);
setVolume(1);
setUri(uri_);
}
// vertigo
Video::~Video()
{
delete impl;
}
void Video::build()
{
this->impl->build();
}
int Video::getWidth() const
{
while (!this->impl->videoIsConnected());
return this->impl->getWidth();
}
int Video::getHeight() const
{
while (!this->impl->videoIsConnected());
return this->impl->getHeight();
}
void Video::update() {
impl->update();
}
void Video::play()
{
impl->setPlayState(true);
}
void Video::pause()
{
impl->setPlayState(false);
}
void Video::rewind()
{
impl->resetMovie();
}
void Video::lockMutex() {
impl->lockMutex();
}
void Video::unlockMutex() {
impl->unlockMutex();
}
const uchar* Video::getBits()
{
return this->impl->getBits();
}
bool Video::bitsHaveChanged() const
{
return this->impl->bitsHaveChanged();
}
void Video::setRate(double rate)
{
impl->setRate(rate);
}
double Video::getRate() const
{
return impl->getRate();
}
void Video::setVolume(double rate)
{
impl->setVolume(rate);
}
double Video::getVolume() const
{
return impl->getVolume();
}
bool Video::hasVideoSupport()
{
return VideoImpl::hasVideoSupport();
}
bool Video::setUri(const QString &uri)
{
static QFileIconProvider provider;
// Try to load movie.
if (!impl->loadMovie(uri))
{
qDebug() << "Cannot load movie " << uri << "." << endl;
return false;
}
// Set uri.
this->uri = uri;
// Default (in case seeking and loading don't work).
icon = provider.icon(QFileInfo(uri));
// Try to get thumbnail.
// Wait for the first samples to be available to make sure we are ready.
if (!impl->waitForNextBits(1000))
{
return false;
}
// Try seeking to the middle of the movie.
if (!impl->seekTo(0.5))
{
impl->resetMovie();
return false;
}
// Try to get a sample from the current position.
// NOTE: There is no guarantee the sample has yet been acquired.
const uchar* bits;
if (!impl->waitForNextBits(ICON_TIMEOUT, &bits))
{
qDebug() << "Second waiting wrong..." << endl;
return false;
}
// Copy bits into thumbnail QImage.
QImage thumbnail(getWidth(), getHeight(), QImage::Format_ARGB32);
int i=0;
for (int y=0; y<getHeight(); y++)
for (int x=0; x<getWidth(); x++)
{
// Transfer RGBA to ARGB.
uint r = *bits++;
uint b = *bits++;
uint g = *bits++;
bits++; // skip alpha
thumbnail.setPixel(x, y, qRgb(r, g, b));
}
// Generate icon.
icon = QIcon(QPixmap::fromImage(thumbnail));
// Reset movie.
impl->resetMovie();
// Return success.
return true;
}