From 2f453fc47bcfe78082e36c29ac74d815e0fe2297 Mon Sep 17 00:00:00 2001 From: zueuk Date: Fri, 10 Oct 2008 13:25:39 +0000 Subject: [PATCH] thread priority control enabled. use at your own risk :) --- 2.10/Source/FormRender.dfm | 2 -- 2.10/Source/FormRender.pas | 37 ++++++++++++++++++++---------------- 2.10/Source/Global.pas | 4 +++- 2.10/Source/Options.dfm | 4 +++- 2.10/Source/Regstry.pas | 30 +++++++++++------------------ 2.10/Source/RenderMT.pas | 12 +++++++----- 2.10/Source/RenderThread.pas | 2 +- 7 files changed, 46 insertions(+), 45 deletions(-) diff --git a/2.10/Source/FormRender.dfm b/2.10/Source/FormRender.dfm index 50a54ae..641f7dd 100644 --- a/2.10/Source/FormRender.dfm +++ b/2.10/Source/FormRender.dfm @@ -568,9 +568,7 @@ object RenderForm: TRenderForm Width = 73 Height = 17 Caption = 'Low priority' - Enabled = False TabOrder = 10 - Visible = False OnClick = chkThreadPriorityClick end object SaveDialog: TSaveDialog diff --git a/2.10/Source/FormRender.pas b/2.10/Source/FormRender.pas index 8d18596..def2d12 100644 --- a/2.10/Source/FormRender.pas +++ b/2.10/Source/FormRender.pas @@ -1,6 +1,7 @@ { Apophysis Copyright (C) 2001-2004 Mark Townsend Apophysis Copyright (C) 2005-2006 Ronald Hordijk, Piotr Boris, Peter Sdobnov + Apophysis Copyright (C) 2007-2008 Piotr Borys, Peter Sdobnov 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 @@ -16,6 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. } + unit FormRender; interface @@ -511,12 +513,15 @@ begin Renderer := TRenderThread.Create; assert(Renderer <> nil); -{ - if chkThreadPriority.Checked then - Renderer.SetPriority(tpLower) - else - Renderer.SetPriority(tpNormal); -} + + if chkThreadPriority.Visible then + begin + if chkThreadPriority.Checked then + Renderer.SetPriority(tpLower) + else + Renderer.SetPriority(tpNormal); + end; + Renderer.BitsPerSample := BitsPerSample; if chkLimitMem.checked then Renderer.MaxMem := MaxMemory;//StrToInt(cbMaxMemory.text); @@ -584,12 +589,15 @@ begin Renderer := TRenderThread.Create; assert(Renderer <> nil); -{ - if chkThreadPriority.Checked then - Renderer.SetPriority(tpLower) - else - Renderer.SetPriority(tpNormal); -} + + if chkThreadPriority.Visible then + begin + if chkThreadPriority.Checked then + Renderer.SetPriority(tpLower) + else + Renderer.SetPriority(tpNormal); + end; + Renderer.BitsPerSample := BitsPerSample; if chkLimitMem.checked then Renderer.MaxMem := MaxMemory;//StrToInt(cbMaxMemory.text); @@ -653,7 +661,7 @@ begin ShowMemoryStatus; Ratio := ImageWidth / ImageHeight; chkSaveIncompleteRenders.Checked := SaveIncompleteRenders; -// chkThreadPriority.Checked := LowerRenderPriority; + chkThreadPriority.Checked := LowerRenderPriority; end; procedure TRenderForm.txtWidthChange(Sender: TObject); @@ -1054,16 +1062,13 @@ end; procedure TRenderForm.chkThreadPriorityClick(Sender: TObject); begin -{ LowerRenderPriority := chkThreadPriority.Checked; - if Assigned(Renderer) then begin if LowerRenderPriority then Renderer.SetPriority(tpLower) else Renderer.SetPriority(tpNormal); end; -} end; end. diff --git a/2.10/Source/Global.pas b/2.10/Source/Global.pas index 234d09a..55d7517 100644 --- a/2.10/Source/Global.pas +++ b/2.10/Source/Global.pas @@ -1,6 +1,7 @@ { Apophysis Copyright (C) 2001-2004 Mark Townsend Apophysis Copyright (C) 2005-2006 Ronald Hordijk, Piotr Borys, Peter Sdobnov + Apophysis Copyright (C) 2007-2008 Piotr Borys, Peter Sdobnov 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 @@ -16,6 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. } + unit Global; interface @@ -151,7 +153,7 @@ var SaveIncompleteRenders: boolean; ShowRenderStats: boolean; - //LowerRenderPriority: boolean; + LowerRenderPriority: boolean; SymmetryType: integer; SymmetryOrder: integer; diff --git a/2.10/Source/Options.dfm b/2.10/Source/Options.dfm index 206021d..ea712ba 100644 --- a/2.10/Source/Options.dfm +++ b/2.10/Source/Options.dfm @@ -1219,7 +1219,7 @@ object OptionsForm: TOptionsForm Height = 21 HelpContext = 1036 TabOrder = 6 - Text = '0' + Text = '1' OnChange = txtMinLumChange end object txtMaxLum: TEdit @@ -1303,6 +1303,8 @@ object OptionsForm: TOptionsForm Height = 21 HelpContext = 1036 Associate = txtMinLum + Min = 1 + Position = 1 TabOrder = 14 end object udMaxLum: TUpDown diff --git a/2.10/Source/Regstry.pas b/2.10/Source/Regstry.pas index 24c98e0..805ebd2 100644 --- a/2.10/Source/Regstry.pas +++ b/2.10/Source/Regstry.pas @@ -1,6 +1,7 @@ { Apophysis Copyright (C) 2001-2004 Mark Townsend Apophysis Copyright (C) 2005-2006 Ronald Hordijk, Piotr Borys, Peter Sdobnov + Apophysis Copyright (C) 2007-2008 Piotr Borys, Peter Sdobnov 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 @@ -16,6 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. } + unit Regstry; interface @@ -408,7 +410,7 @@ begin if Registry.ValueExists('MaxLum') then begin MaxLum := Registry.ReadInteger('MaxLum'); - if MaxLum < 0 then MaxLum := 0; + if MaxLum <= 0 then MaxLum := 100; end else begin @@ -541,15 +543,7 @@ begin begin SheepServer := 'http://v2d5.sheepserver.net/'; end; -{ if Registry.ValueExists('ResizeOnLoad') then - begin - ResizeOnLoad := Registry.ReadBool('ResizeOnLoad'); - end - else - begin - ResizeOnLoad := False; - end; -} if Registry.ValueExists('ShowProgress') then + if Registry.ValueExists('ShowProgress') then begin ShowProgress := Registry.ReadBool('ShowProgress'); end else begin @@ -567,11 +561,11 @@ begin end else begin ShowRenderStats := false; end; -// if Registry.ValueExists('LowerRenderPriority') then begin -// LowerRenderPriority := Registry.ReadBool('LowerRenderPriority'); -// end else begin -// LowerRenderPriority := false; -// end; + if Registry.ValueExists('LowerRenderPriority') then begin + LowerRenderPriority := Registry.ReadBool('LowerRenderPriority'); + end else begin + LowerRenderPriority := false; + end; if Registry.ValueExists('PNGTransparency') then begin PNGTransparency := Registry.ReadInteger('PNGTransparency'); @@ -678,10 +672,9 @@ begin SheepPW := ''; flam3Path := DefaultPath + 'flam3.exe'; SheepServer := 'http://v2d5.sheepserver.net/'; -// ResizeOnLoad := False; ShowProgress := true; SaveIncompleteRenders := false; -// LowerRenderPriority := false; + LowerRenderPriority := false; ShowRenderStats := false; PNGTransparency := 1; ShowTransparency := False; @@ -1130,7 +1123,6 @@ begin Registry.WriteString('Renderer', flam3Path); Registry.WriteString('Server', SheepServer); Registry.WriteString('Pass', SheepPW); -// Registry.WriteBool('ResizeOnLoad', ResizeOnLoad); Registry.WriteBool('ShowProgress', ShowProgress); Registry.WriteBool('KeepBackground', KeepBackground); Registry.WriteBool('PreserveQuality', PreserveQuality); @@ -1143,7 +1135,7 @@ begin Registry.WriteBool('SaveIncompleteRenders', SaveIncompleteRenders); Registry.WriteBool('ShowRenderStats', ShowRenderStats); -// Registry.WriteBool('LowerRenderPriority', LowerRenderPriority); + Registry.WriteBool('LowerRenderPriority', LowerRenderPriority); Registry.WriteInteger('NrTreads', NrTreads); Registry.WriteInteger('UseNrThreads', UseNrThreads); diff --git a/2.10/Source/RenderMT.pas b/2.10/Source/RenderMT.pas index 5d830b0..14ed2a2 100644 --- a/2.10/Source/RenderMT.pas +++ b/2.10/Source/RenderMT.pas @@ -169,13 +169,13 @@ begin end; procedure TBaseMTRenderer.SetThreadPriority(p: TThreadPriority); -//var -// i: integer; +var + i: integer; begin inherited; - //for i := 0 to High(WorkingThreads) do - // WorkingThreads[i].Priority := p; + for i := 0 to High(WorkingThreads) do + WorkingThreads[i].Priority := p; end; /////////////////////////////////////////////////////////////////////////////// @@ -183,7 +183,9 @@ function TBaseMTRenderer.NewThread: TBucketFillerThread; begin Result := TBucketFillerThread.Create(fcp); assert(Result<>nil); - Result.Priority := tpLower; //FThreadPriority; + + if FThreadPriority <> tpNormal then + Result.Priority := {tpLower;} FThreadPriority; if FCP.FAngle = 0 then Result.AddPointsProc := self.AddPointsToBuckets diff --git a/2.10/Source/RenderThread.pas b/2.10/Source/RenderThread.pas index 6536286..09baa21 100644 --- a/2.10/Source/RenderThread.pas +++ b/2.10/Source/RenderThread.pas @@ -279,7 +279,7 @@ end; procedure TRenderThread.SetPriority(p: TThreadPriority); begin - Priority := p; + //! Priority := p; if assigned(FRenderer) then FRenderer.SetThreadPriority(p);