/* Copyright (C) 2013 * swift project Community / Contributors * * This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level * directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project, * including this file, may be copied, modified, propagated, or distributed except according to the terms * contained in the LICENSE file. */ #include "pixmap.h" #include #include namespace BlackMisc { CPixmap::CPixmap(const QPixmap &pixmap) : m_pixmap(pixmap), m_hasCachedPixmap(true) { this->fillByteArray(); } CPixmap::CPixmap(const CPixmap &other) : CValueObject(), m_pixmap(other.m_pixmap), m_hasCachedPixmap(other.m_hasCachedPixmap), m_array(other.m_array) {} CPixmap &CPixmap::operator =(const CPixmap &other) { std::tie(m_pixmap, m_hasCachedPixmap, m_array) = std::tie(other.m_pixmap, other.m_hasCachedPixmap, other.m_array); return (*this); } const QPixmap &CPixmap::pixmap() const { QWriteLocker(&this->m_lock); if (this->m_hasCachedPixmap) { return this->m_pixmap; } // this part here becomes relevant when marshalling via DBus is used // in this case only the array is transferred this->m_hasCachedPixmap = true; if (this->m_array.isEmpty()) { return this->m_pixmap; } bool s = this->m_pixmap.loadFromData(this->m_array, "PNG"); Q_ASSERT(s); Q_UNUSED(s); return this->m_pixmap; } bool CPixmap::isNull() const { QReadLocker(&this->m_lock); if (this->m_hasCachedPixmap) { return false; } return (this->m_array.isEmpty() || this->m_array.isNull()); } CPixmap::operator QPixmap() const { return pixmap(); } QString CPixmap::convertToQString(bool i18n) const { Q_UNUSED(i18n); return "Pixmap"; } QPixmap CPixmap::toPixmap() const { return this->pixmap(); } void CPixmap::fillByteArray() { QBuffer buffer(&this->m_array); buffer.open(QIODevice::WriteOnly); this->m_pixmap.save(&buffer, "PNG"); buffer.close(); } } // namespace