summaryrefslogtreecommitdiffstats
path: root/krita/ui/kis_histogram_view.cc
diff options
context:
space:
mode:
Diffstat (limited to 'krita/ui/kis_histogram_view.cc')
-rw-r--r--krita/ui/kis_histogram_view.cc354
1 files changed, 0 insertions, 354 deletions
diff --git a/krita/ui/kis_histogram_view.cc b/krita/ui/kis_histogram_view.cc
deleted file mode 100644
index cc4fe59c..00000000
--- a/krita/ui/kis_histogram_view.cc
+++ /dev/null
@@ -1,354 +0,0 @@
-/*
- * Copyright (c) 2005 Bart Coppens <kde@bartcoppens.be>
- *
- * 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.
- *
- * 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, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-
-#include <math.h>
-
-#include <tqpainter.h>
-#include <tqpixmap.h>
-#include <tqlabel.h>
-#include <tqcombobox.h>
-#include <tqbuttongroup.h>
-#include <tqpushbutton.h>
-#include <tqscrollbar.h>
-
-#include <kdebug.h>
-
-#include "kis_channelinfo.h"
-#include "kis_histogram.h"
-#include "kis_global.h"
-#include "kis_types.h"
-#include "kis_layer.h"
-#include "kis_colorspace.h"
-#include "kis_histogram_view.h"
-#include "kis_basic_histogram_producers.h"
-#include "kis_paint_device.h"
-
-KisHistogramView::KisHistogramView(TQWidget *tqparent, const char *name, WFlags f)
- : TQLabel(tqparent, name, f)
-{
- // This is needed until we can computationally scale it well. Until then, this is needed
- // And when we have it, it won't hurt to have it around
- setScaledContents(true);
- setFrameShape(TQFrame::Box); // Draw a box around ourselves
-}
-
-KisHistogramView::~KisHistogramView()
-{
-}
-
-void KisHistogramView::setPaintDevice(KisPaintDeviceSP dev)
-{
- m_cs = dev->colorSpace();
-
- setChannels(); // Sets m_currentProducer to the first in the list
-
- if (!m_currentProducer)
- return;
-
- m_from = m_currentProducer->viewFrom();
- m_width = m_currentProducer->viewWidth();
-
- m_histogram = new KisHistogram(dev, m_currentProducer, LINEAR);
-
- updateHistogram();
-}
-
-void KisHistogramView::setHistogram(KisHistogramSP histogram)
-{
- m_cs = 0;
- m_histogram = histogram;
- m_currentProducer = m_histogram->producer();
- m_from = m_currentProducer->viewFrom();
- m_width = m_currentProducer->viewWidth();
-
- m_comboInfo.clear();
- m_channelStrings.clear();
- m_channels.clear();
- m_channelToOffset.clear();
-
- addProducerChannels(m_currentProducer);
-
- // Set the currently viewed channel:
- m_color = false;
- m_channels.append(m_comboInfo.at(1).channel);
- m_channelToOffset.append(0);
-
- updateHistogram();
-}
-
-void KisHistogramView::setView(double from, double size)
-{
- m_from = from;
- m_width = size;
- if (m_from + m_width > 1.0)
- m_from = 1.0 - m_width;
- m_histogram->producer()->setView(m_from, m_width);
-
- m_histogram->updateHistogram();
- updateHistogram();
-}
-
-KisHistogramProducerSP KisHistogramView::currentProducer()
-{
- return m_currentProducer;
-}
-
-TQStringList KisHistogramView::channelStrings()
-{
- return m_channelStrings;
-}
-
-KisIDList KisHistogramView::listProducers()
-{
- if (m_cs)
- return KisHistogramProducerFactoryRegistry::instance()->listKeysCompatibleWith(m_cs);
- return KisIDList();
-}
-
-void KisHistogramView::setCurrentChannels(const KisID& producerID, TQValueVector<KisChannelInfo *> channels)
-{
- setCurrentChannels(
- KisHistogramProducerFactoryRegistry::instance()->get(producerID)->generate(),
- channels);
-}
-
-void KisHistogramView::setCurrentChannels(KisHistogramProducerSP producer, TQValueVector<KisChannelInfo *> channels)
-{
- m_currentProducer = producer;
- m_currentProducer->setView(m_from, m_width);
- m_histogram->setProducer(m_currentProducer);
- m_histogram->updateHistogram();
- m_histogram->setChannel(0); // Set a default channel, just being nice
-
- m_channels.clear();
- m_channelToOffset.clear();
-
- if (channels.count() == 0) {
- updateHistogram();
- return;
- }
-
- TQValueVector<KisChannelInfo *> producerChannels = m_currentProducer->channels();
-
- for (uint i = 0; i < channels.count(); i++) {
- // Also makes sure the channel is actually in the producer's list
- for (uint j = 0; j < producerChannels.count(); j++) {
- if (channels.at(i)->name() == producerChannels.at(j)->name()) {
- m_channelToOffset.append(m_channels.count()); // The first we append maps to 0
- m_channels.append(channels.at(i));
- }
- }
- }
-
- updateHistogram();
-}
-
-bool KisHistogramView::hasColor()
-{
- return m_color;
-}
-
-void KisHistogramView::setColor(bool set)
-{
- if (set != m_color) {
- m_color = set;
- updateHistogram();
- }
-}
-
-void KisHistogramView::setActiveChannel(int channel)
-{
- ComboboxInfo info = m_comboInfo.at(channel);
- if (info.producer.data() != m_currentProducer.data()) {
- m_currentProducer = info.producer;
- m_currentProducer->setView(m_from, m_width);
- m_histogram->setProducer(m_currentProducer);
- m_histogram->updateHistogram();
- }
-
- m_channels.clear();
- m_channelToOffset.clear();
-
- if (!m_currentProducer) {
- updateHistogram();
- return;
- }
-
- if (info.isProducer) {
- m_color = true;
- m_channels = m_currentProducer->channels();
- for (uint i = 0; i < m_channels.count(); i++)
- m_channelToOffset.append(i);
- m_histogram->setChannel(0); // Set a default channel, just being nice
- } else {
- m_color = false;
- TQValueVector<KisChannelInfo *> channels = m_currentProducer->channels();
- for (uint i = 0; i < channels.count(); i++) {
- KisChannelInfo* channel = channels.at(i);
- if (channel->name() == info.channel->name()) {
- m_channels.append(channel);
- m_channelToOffset.append(i);
- break;
- }
- }
- }
-
- updateHistogram();
-}
-
-void KisHistogramView::setHistogramType(enumHistogramType type)
-{
- m_histogram->setHistogramType(type);
- updateHistogram();
-}
-
-void KisHistogramView::setChannels()
-{
- m_comboInfo.clear();
- m_channelStrings.clear();
- m_channels.clear();
- m_channelToOffset.clear();
-
- KisIDList list = KisHistogramProducerFactoryRegistry::instance()->listKeysCompatibleWith(m_cs);
-
- if (list.count() == 0) {
- // XXX: No native histogram for this colorspace. Using converted RGB. We should have a warning
- KisGenericRGBHistogramProducerFactory f;
- addProducerChannels(f.generate());
- } else {
- for (uint i = 0; i < list.count(); i++) {
- KisID id(*(list.at(i)));
- addProducerChannels( KisHistogramProducerFactoryRegistry::instance()->get(id)->generate() );
- }
- }
-
- m_currentProducer = m_comboInfo.at(0).producer;
- m_color = false;
- // The currently displayed channel and its offset
- m_channels.append(m_comboInfo.at(1).channel);
- m_channelToOffset.append(0);
-}
-
-void KisHistogramView::addProducerChannels(KisHistogramProducerSP producer) {
- ComboboxInfo info;
- info.isProducer = true;
- info.producer = producer;
- // channel not used for a producer
- TQValueVector<KisChannelInfo *> channels = info.producer->channels();
- int count = channels.count();
- m_comboInfo.append(info);
- m_channelStrings.append(producer->id() . name());
- for (int j = 0; j < count; j++) {
- info.isProducer = false;
- info.channel = channels.at(j);
- m_comboInfo.append(info);
- m_channelStrings.append(TQString(" ").append(info.channel->name()));
- }
-}
-
-void KisHistogramView::updateHistogram()
-{
- TQ_UINT32 height = this->height();
- int selFrom, selTo; // from - to in bins
-
- if (!m_currentProducer) { // Something's very wrong: no producer for this colorspace to update histogram with!
- return;
- }
-
- TQ_INT32 bins = m_histogram->producer()->numberOfBins();
- m_pix = TQPixmap(bins, height);
- m_pix.fill();
- TQPainter p(&m_pix);
- p.setBrush(TQt::black);
-
- // Draw the box of the selection, if any
- if (m_histogram->hasSelection()) {
- double width = m_histogram->selectionTo() - m_histogram->selectionFrom();
- double factor = static_cast<double>(bins) / m_histogram->producer()->viewWidth();
- selFrom = static_cast<int>(m_histogram->selectionFrom() * factor);
- selTo = selFrom + static_cast<int>(width * factor);
- p.drawRect(selFrom, 0, selTo - selFrom, height);
- } else {
- // We don't want the drawing to think we're in a selected area
- selFrom = -1;
- selTo = 2;
- }
-
- TQ_INT32 i = 0;
- double highest = 0;
- bool blackOnBlack = false;
-
- // First we iterate once, so that we have the overall maximum. This is a bit inefficient,
- // but not too much since the histogram caches the calculations
- for (uint chan = 0; chan < m_channels.count(); chan++) {
- m_histogram->setChannel(m_channelToOffset.at(chan));
- if ((double)m_histogram->calculations().getHighest() > highest)
- highest = (double)m_histogram->calculations().getHighest();
- }
-
- for (uint chan = 0; chan < m_channels.count(); chan++) {
- TQColor color;
- m_histogram->setChannel(m_channelToOffset.at(chan));
-
- if (m_color) {
- color = m_channels.at(chan)->color();
- p.setPen(color);
- } else {
- color = TQt::black;
- }
- blackOnBlack = (color == TQt::black);
-
- if (m_histogram->getHistogramType() == LINEAR) {
- double factor = (double)height / highest;
- for( i=0; i<bins; ++i ) {
- // So that we get a good view even with a selection box with
- // black colors on background of black selection
- if (i >= selFrom && i < selTo && blackOnBlack) {
- p.setPen(TQt::white);
- } else {
- p.setPen(color);
- }
- p.drawLine(i, height, i, height - int(m_histogram->getValue(i) * factor));
- }
- } else {
- double factor = (double)height / (double)log(highest);
- for( i = 0; i < bins; ++i ) {
- // Same as above
- if (i >= selFrom && i < selTo && blackOnBlack) {
- p.setPen(TQt::white);
- } else {
- p.setPen(color);
- }
- p.drawLine(i, height, i,
- height - int(log((double)m_histogram->getValue(i)) * factor));
- }
- }
- }
-
- setPixmap(m_pix);
-}
-
-void KisHistogramView::mousePressEvent(TQMouseEvent * e) {
- if (e->button() == Qt::RightButton)
- emit rightClicked(e->globalPos());
- else
- TQLabel::mousePressEvent(e);
-}
-
-
-#include "kis_histogram_view.moc"