File browser thumbnails for raw images start with a minimally-processed images. These images are cached and image adjustments are applied on top. The black level is "baked-into" the cached image. Therefore, to reflect the black level adjustments in the thumbnail, one of two options are required: 1. Cache an image before the black level is applied and process the black level on top of this image. 2. Recreate the base image with the new black level and cache it. The first option yields better performance when the user changes the black level. However, it requires other base adjustments to be applied every time, such as the camera multipliers. The second option requires the base image to be recreated every time the black level is changed. This commit implements the second option. It minimizes code changes, and therefore possible bugs. It does add a performance penalty when the black level changes, but the black level adjustment is rarely used.
115 lines
2.8 KiB
C++
115 lines
2.8 KiB
C++
/*
|
|
* This file is part of RawTherapee.
|
|
*
|
|
* Copyright (c) 2004-2010 Gabor Horvath <hgabor@rawtherapee.com>
|
|
*
|
|
* RawTherapee 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.
|
|
*
|
|
* RawTherapee 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 RawTherapee. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
#pragma once
|
|
|
|
#include <glib.h>
|
|
|
|
|
|
#include "../rtengine/noncopyable.h"
|
|
|
|
namespace rtengine
|
|
{
|
|
class IImage8;
|
|
|
|
namespace procparams
|
|
{
|
|
|
|
struct CropParams;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
class ThumbBrowserEntryBase;
|
|
|
|
class ThumbImageUpdateListener
|
|
{
|
|
public:
|
|
virtual ~ThumbImageUpdateListener() = default;
|
|
|
|
/**
|
|
* @brief Called when thumbnail image is update
|
|
*
|
|
* @param img new thumbnail image
|
|
* @param scale scale (??)
|
|
* @param cropParams how it was cropped (??)
|
|
*
|
|
* @note no locks are held when called back
|
|
*/
|
|
virtual void updateImage(rtengine::IImage8* img, double scale, const rtengine::procparams::CropParams& cropParams) = 0;
|
|
};
|
|
|
|
class ThumbImageUpdater :
|
|
public rtengine::NonCopyable
|
|
{
|
|
public:
|
|
/**
|
|
* @brief Singleton entry point.
|
|
*
|
|
* @return Pointer to thumbnail image updater.
|
|
*/
|
|
static ThumbImageUpdater* getInstance(void);
|
|
|
|
/**
|
|
* @brief Add an thumbnail image update request.
|
|
*
|
|
* Code will add the request to the queue and, if needed, start a pool
|
|
* thread to process it.
|
|
*
|
|
* @param t thumbnail
|
|
* @param params processing params (?)
|
|
* @param height how big
|
|
* @param priority if \c true then run as soon as possible
|
|
* @param l listener waiting on update
|
|
*/
|
|
void add(ThumbBrowserEntryBase* tbe, bool* priority, bool upgrade, bool forceUpgrade, ThumbImageUpdateListener* l);
|
|
|
|
/**
|
|
* @brief Remove jobs associated with listener \c l.
|
|
*
|
|
* Jobs being processed will be finished. Will not return till all jobs for
|
|
* \c l have been completed.
|
|
*
|
|
* @param listener jobs associated with this will be stopped
|
|
*/
|
|
void removeJobs(ThumbImageUpdateListener* listener);
|
|
|
|
/**
|
|
* @brief Stop processing and remove all jobs.
|
|
*
|
|
* Will not return till all running jobs have completed.
|
|
*/
|
|
void removeAllJobs(void);
|
|
|
|
private:
|
|
|
|
ThumbImageUpdater();
|
|
~ThumbImageUpdater();
|
|
|
|
class Impl;
|
|
Impl* impl_;
|
|
};
|
|
|
|
/**
|
|
* @brief Singleton boiler plate.
|
|
*
|
|
* To use: \c thumbImageUpdater->start() ,
|
|
*/
|
|
#define thumbImageUpdater ThumbImageUpdater::getInstance()
|