1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176
|
/*
* Descent 3
* Copyright (C) 2024 Parallax Software
*
* 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 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
// StatusDlg.cpp : implementation file
//
#include "stdafx.h"
#include "editor.h"
#include "StatusDlg.h"
#include "pserror.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CStatusDlg dialog
CStatusDlg::CStatusDlg(CWnd *pParent /*=NULL*/) : CDialog(CStatusDlg::IDD, pParent) {
//{{AFX_DATA_INIT(CStatusDlg)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
}
void CStatusDlg::DoDataExchange(CDataExchange *pDX) {
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CStatusDlg)
// NOTE: the ClassWizard will add DDX and DDV calls here
//}}AFX_DATA_MAP
}
void CStatusDlg::Init(int min, int max, int delta) {
CProgressCtrl *progress;
progress = (CProgressCtrl *)GetDlgItem(IDC_STATUSPROGRESS);
progress->SetRange(min, max);
progress->SetPos(min);
progress->SetStep(delta);
mprintf(0, "Progress Control Create: Min= %d Max= %d Step= %d\n", min, max, delta);
}
int CStatusDlg::Step() {
CProgressCtrl *progress;
progress = (CProgressCtrl *)GetDlgItem(IDC_STATUSPROGRESS);
return progress->StepIt();
}
void CStatusDlg::Text(char *string) {
CWnd *text;
text = GetDlgItem(IDC_STATUSTEXT);
text->SetWindowText(string);
}
void CStatusDlg::SetTo(int set) {
CProgressCtrl *progress;
progress = (CProgressCtrl *)GetDlgItem(IDC_STATUSPROGRESS);
progress->SetPos(set);
}
BEGIN_MESSAGE_MAP(CStatusDlg, CDialog)
//{{AFX_MSG_MAP(CStatusDlg)
// NOTE: the ClassWizard will add message map macros here
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CStatusDlg message handlers
// Initializes the Progress Window. This MUST MUST MUST be called first, the parent parameter can be
// NULL to set the parent to the main window.
// min/max: these are the range of the progress indicator
// iterations: If you plan on using CProgress:IncreaseProgress() then this is how many times you plan on
// calling CProgress::IncreaseProgress(). If you are going to use
//CProgress::SetProgressPercentage() then you should call the version of InitProgress(CWnd *parent) below.
// Returns true if the progress dialog was created
bool CProgress::InitProgress(fix min, fix max, int32_t iterations, CWnd *parent) {
int nmin, nmax, Step;
nmin = FixToInt(min);
nmax = FixToInt(max);
float delta;
delta = (float)(((float)(nmax - nmin)) / ((float)iterations));
while (delta < 1.0) {
delta *= 10;
nmax *= 10;
}
Step = (int)delta;
m_Max = nmax;
m_Min = nmin;
if (!iterations)
return false;
m_StatusDlg = new CStatusDlg;
if (!m_StatusDlg)
return false;
m_StatusDlg->Create(IDD_STATUSDLG, parent);
m_StatusDlg->ShowWindow(SW_SHOW);
m_StatusDlg->Init(nmin, nmax, Step);
return true;
}
// This is a quick way of initializing the progress indicator, with a range 0-100 step size 1. This is what you
// should call if you plan on using CProgress::SetProgressPercentage(). Again, parent can be NULL if you want it to
// be the main application as the parent
bool CProgress::InitProgress(CWnd *parent) {
m_Max = 100;
m_Min = 0;
m_StatusDlg = new CStatusDlg;
if (!m_StatusDlg)
return false;
m_StatusDlg->Create(IDD_STATUSDLG, parent);
m_StatusDlg->ShowWindow(SW_SHOW);
m_StatusDlg->Init(0, 100, 1);
return true;
}
// YOU MUST call this after you are done with the progress indicator. This frees up some allocated memory
void CProgress::DestroyProgress() {
ASSERT(m_StatusDlg != NULL);
m_StatusDlg->DestroyWindow();
if (m_StatusDlg)
delete m_StatusDlg;
}
// By default the progress indicator says "Please wait...", here you can change that text...make sure you call
// this after InitProgress()
void CProgress::SetProgressText(char *string) {
ASSERT(m_StatusDlg != NULL);
m_StatusDlg->Text(string);
}
// This is the iterator function. Call this in your loop or whatever to increase the progress indicator. You can also
// use CProgress::SetProgressPercentage() instead
bool CProgress::IncreaseProgress() {
ASSERT(m_StatusDlg != NULL);
int ret;
ret = m_StatusDlg->Step();
if (ret >= m_Max)
return true;
else
return false;
}
// Sets the progress indicator to a certain percentage
void CProgress::SetProgressPercentage(int percent) {
ASSERT(m_StatusDlg != NULL);
float per;
per = ((float)percent) / ((float)100.0);
m_StatusDlg->SetTo(m_Min + ((int)(per * (m_Max - m_Min))));
}
void CProgress::SetProgressPercentage(float percent) {
ASSERT(m_StatusDlg != NULL);
m_StatusDlg->SetTo(m_Min + ((int)(percent * (m_Max - m_Min))));
}
|