Mercurial > hg > orthanc-stone
view Framework/Widgets/WidgetBase.cpp @ 2160:66ce58986217 legacy
closing legacy
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 27 Sep 2024 22:33:15 +0200 |
parents | 4cff7b1ed31d |
children | fccffbf99ba1 |
line wrap: on
line source
/** * Stone of Orthanc * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2018 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #include "WidgetBase.h" #include "../../Resources/Orthanc/Core/OrthancException.h" #include "../../Resources/Orthanc/Core/Images/ImageProcessing.h" #include "../../Resources/Orthanc/Core/Logging.h" namespace OrthancStone { void WidgetBase::ClearBackgroundOrthanc(Orthanc::ImageAccessor& target) const { // Clear the background using Orthanc if (backgroundCleared_) { Orthanc::ImageProcessing::Set(target, backgroundColor_[0], backgroundColor_[1], backgroundColor_[2], 255 /* alpha */); } } void WidgetBase::ClearBackgroundCairo(CairoContext& context) const { // Clear the background using Cairo if (IsBackgroundCleared()) { uint8_t red, green, blue; GetBackgroundColor(red, green, blue); context.SetSourceColor(red, green, blue); cairo_paint(context.GetObject()); } } void WidgetBase::ClearBackgroundCairo(Orthanc::ImageAccessor& target) const { CairoSurface surface(target); CairoContext context(surface); ClearBackgroundCairo(context); } void WidgetBase::NotifyChange() { observers_.NotifyChange(this); } void WidgetBase::UpdateStatusBar(const std::string& message) { if (statusBar_ != NULL) { statusBar_->SetMessage(message); } } void WidgetBase::WorkerThread(WidgetBase* that) { while (that->started_) { that->UpdateStep(); } } WidgetBase::WidgetBase() : statusBar_(NULL), started_(false), backgroundCleared_(false) { backgroundColor_[0] = 0; backgroundColor_[1] = 0; backgroundColor_[2] = 0; } void WidgetBase::SetBackgroundColor(uint8_t red, uint8_t green, uint8_t blue) { backgroundColor_[0] = red; backgroundColor_[1] = green; backgroundColor_[2] = blue; } void WidgetBase::GetBackgroundColor(uint8_t& red, uint8_t& green, uint8_t& blue) const { red = backgroundColor_[0]; green = backgroundColor_[1]; blue = backgroundColor_[2]; } void WidgetBase::Register(IChangeObserver& observer) { observers_.Register(observer); } void WidgetBase::Unregister(IChangeObserver& observer) { observers_.Unregister(observer); } void WidgetBase::Start() { if (started_) { LOG(ERROR) << "Cannot Start() twice"; throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls); } started_ = true; if (HasUpdateThread()) { thread_ = boost::thread(WorkerThread, this); } } void WidgetBase::Stop() { if (!started_) { LOG(ERROR) << "Cannot Stop() if Start() has not been invoked"; throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls); } started_ = false; if (HasUpdateThread() && thread_.joinable()) { thread_.join(); } } bool WidgetBase::Render(Orthanc::ImageAccessor& surface) { #if 0 ClearBackgroundOrthanc(surface); #else ClearBackgroundCairo(surface); // Faster than Orthanc #endif return true; } }