JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
juce_ThreadWithProgressWindow.h
Go to the documentation of this file.
1 /*
2 ==============================================================================
3
4 This file is part of the JUCE library.
5 Copyright (c) 2022 - Raw Material Software Limited
6
7 JUCE is an open source library subject to commercial or open-source
8 licensing.
9
10 By using JUCE, you agree to the terms of both the JUCE 7 End-User License
11 Agreement and JUCE Privacy Policy.
12
13 End User License Agreement: www.juce.com/juce-7-licence
14 Privacy Policy: www.juce.com/juce-privacy-policy
15
16 Or: You may also use this code under the terms of the GPL v3 (see
17 www.gnu.org/licenses).
18
19 JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
20 EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
21 DISCLAIMED.
22
23 ==============================================================================
24*/
25
26namespace juce
27{
28
29//==============================================================================
83class JUCE_API ThreadWithProgressWindow : public Thread,
84 private Timer
85{
86public:
87 //==============================================================================
105 ThreadWithProgressWindow (const String& windowTitle,
106 bool hasProgressBar,
107 bool hasCancelButton,
108 int timeOutMsWhenCancelling = 10000,
109 const String& cancelButtonText = String(),
110 Component* componentToCentreAround = nullptr);
111
113 ~ThreadWithProgressWindow() override;
114
115 //==============================================================================
116 #if JUCE_MODAL_LOOPS_PERMITTED
128 bool runThread (Priority priority = Priority::normal);
129 #endif
130
140 void launchThread (Priority priority = Priority::normal);
141
147 void setProgress (double newProgress);
148
150 void setStatusMessage (const String& newStatusMessage);
151
153 AlertWindow* getAlertWindow() const noexcept { return alertWindow.get(); }
154
155 //==============================================================================
159 virtual void threadComplete (bool userPressedCancel);
160
161private:
162 //==============================================================================
163 void timerCallback() override;
164
165 double progress;
167 String message;
168 CriticalSection messageLock;
169 const int timeOutMsWhenCancelling;
170 bool wasCancelledByUser;
171
173};
174
175} // namespace juce
A window that displays a message and has buttons for the user to react to it.
The base class for all JUCE user-interface objects.
The JUCE String class!
Definition juce_String.h:53
A thread that automatically pops up a modal dialog box with a progress bar and cancel button while it...
AlertWindow * getAlertWindow() const noexcept
Returns the AlertWindow that is being used.
Encapsulates a thread.
Definition juce_Thread.h:43
Priority
The different runtime priorities of non-realtime threads.
Definition juce_Thread.h:54
Makes repeated callbacks to a virtual method at a specified time interval.
Definition juce_Timer.h:52
#define JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(className)
This is a shorthand way of writing both a JUCE_DECLARE_NON_COPYABLE and JUCE_LEAK_DETECTOR macro for ...
JUCE Namespace.