aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CHANGELOG.txt2
-rwxr-xr-xFramestein.exebin970240 -> 972288 bytes
-rw-r--r--Patches/fs.main.pd4
-rw-r--r--Source/Framestein.cfg8
-rw-r--r--Source/Framestein.dof16
-rw-r--r--Source/pluginunit.pas2
-rw-r--r--Source/toolbarunit.dfm178
-rw-r--r--Source/toolbarunit.pas65
8 files changed, 166 insertions, 109 deletions
diff --git a/CHANGELOG.txt b/CHANGELOG.txt
index c737d7e..0ad9af7 100644
--- a/CHANGELOG.txt
+++ b/CHANGELOG.txt
@@ -18,7 +18,7 @@
- added line width setting to fs.draw
- fix: border_0 no longer alters frame dimensions
-- preventing lockups-feature to fs.main.pd
+- poor lockup-preventing feature to fs.main.pd
0.31
- added plugins by Olaf Matthes: PeRColate and PixelPack. Thanks, Olaf!
diff --git a/Framestein.exe b/Framestein.exe
index a288d08..fd0f60c 100755
--- a/Framestein.exe
+++ b/Framestein.exe
Binary files differ
diff --git a/Patches/fs.main.pd b/Patches/fs.main.pd
index 4ce265d..5bfbfe2 100644
--- a/Patches/fs.main.pd
+++ b/Patches/fs.main.pd
@@ -1,10 +1,10 @@
-#N canvas 278 0 720 628 12;
+#N canvas 278 0 736 644 12;
#X floatatom 27 322 4 0 0;
#X obj 207 160 loadbang;
#X msg 206 254 disconnect;
#X msg 27 253 send \$1;
#X obj 27 203 r fs_main;
-#X obj 127 128 inlet;
+#X obj 127 126 inlet;
#X text 175 126 port;
#X obj 127 170 t f b;
#X text 9 30 only one fs.main at a time \,;
diff --git a/Source/Framestein.cfg b/Source/Framestein.cfg
index d487870..42e96f3 100644
--- a/Source/Framestein.cfg
+++ b/Source/Framestein.cfg
@@ -34,7 +34,7 @@
-E"e:\fs\Framestein"
-LE"c:\program files\borland\delphi5\Projects\Bpl"
-LN"c:\program files\borland\delphi5\Projects\Bpl"
--U"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32"
--O"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32"
--I"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32"
--R"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32"
+-U"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;E:\fs\Framestein\Source"
+-O"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;E:\fs\Framestein\Source"
+-I"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;E:\fs\Framestein\Source"
+-R"E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;E:\fs\Framestein\Source"
diff --git a/Source/Framestein.dof b/Source/Framestein.dof
index 26929b1..ef8795e 100644
--- a/Source/Framestein.dof
+++ b/Source/Framestein.dof
@@ -43,7 +43,7 @@ OutputDir=e:\fs\Framestein
UnitOutputDir=
PackageDLLOutputDir=
PackageDCPOutputDir=
-SearchPath=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32
+SearchPath=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;E:\fs\Framestein\Source
Packages=Vcl50;Vclx50;VclSmp50;Qrpt50;Vcldb50;Vclbde50;ibevnt50;vcldbx50;TeeUI50;TeeDB50;Tee50;TeeQR50;VCLIB50;vclie50;Inetdb50;Inet50;NMFast50;dclocx50;dclaxserver50;DelphiX_for5;fspak
Conditionals=
DebugSourceDirs=
@@ -84,12 +84,14 @@ Comments=
Count=1
Item0=WinTypes=Windows;WinProcs=Windows;DbiTypes=BDE;DbiProcs=BDE;DbiErrs=BDE;
[HistoryLists\hlSearchPath]
-Count=5
-Item0=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32
-Item1=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32\Packages
-Item2=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost
-Item3=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib
-Item4=E:\lab\common\DelphiX2000_0717-2\Source
+Count=7
+Item0=e:\lab\common\fastlib;e:\lab\common\pshost;e:\lab\common\G32;e:\fs\framestein\source
+Item1=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\common\pshost;E:\lab\common\G32;e:\fs\framestein\source
+Item2=e:\lab\common\fastlib;e:\lab\common\pshost;e:\lab\common\G32
+Item3=g:\lab\common\fastlib;G:\lab\common\pshost;G:\lab\common\G32
+Item4=g:\lab\common\fastlib;G:\lab\common\pshost
+Item5=g:\lab\common\fastlib
+Item6=g:\lab\common;g:\lab\common\DelphiX2000_0717-2\Source;g:\lab\common\fastlib;g:\lab\common\pshost;g:\lab\common\G32;g:\lab\common\fastlib
[HistoryLists\hlOutputDirectorry]
Count=1
Item0=e:\fs\Framestein
diff --git a/Source/pluginunit.pas b/Source/pluginunit.pas
index f331ed8..12d7465 100644
--- a/Source/pluginunit.pas
+++ b/Source/pluginunit.pas
@@ -159,7 +159,7 @@ begin
if s<>'' then s:=s+' ';
s:=s+Names[i];
end;
- main.Post('Plugins ('+IntToStr(Names.Count)+' loaded): '+s);
+// main.Post('Plugins ('+IntToStr(Names.Count)+' loaded): '+s);
end;
end;
diff --git a/Source/toolbarunit.dfm b/Source/toolbarunit.dfm
index 5cd6673..aa778f0 100644
--- a/Source/toolbarunit.dfm
+++ b/Source/toolbarunit.dfm
@@ -1,10 +1,9 @@
object toolbar: Ttoolbar
Left = 264
- Top = 454
- Width = 567
- Height = 282
+ Top = 234
+ Width = 325
+ Height = 493
BorderStyle = bsSizeToolWin
- Caption = 'Toolbar'
Color = clBtnFace
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
@@ -15,90 +14,113 @@ object toolbar: Ttoolbar
OnCreate = FormCreate
PixelsPerInch = 96
TextHeight = 13
- object Splitter1: TSplitter
- Left = 0
- Top = 97
- Width = 559
- Height = 6
- Cursor = crVSplit
- Align = alTop
- Beveled = True
- end
- object Panel1: TPanel
+ object bar: TStatusBar
Left = 0
- Top = 103
- Width = 559
- Height = 133
- Align = alClient
- BevelOuter = bvNone
- Caption = 'Panel1'
- TabOrder = 0
- object LVFilters: TListView
- Left = 0
- Top = 0
- Width = 559
- Height = 133
- Align = alClient
- BorderStyle = bsNone
- Color = clBtnFace
- Columns = <
- item
- AutoSize = True
- Caption = 'Name'
- end
- item
- AutoSize = True
- Caption = 'Info'
- end>
- ReadOnly = True
- TabOrder = 0
- ViewStyle = vsList
- OnChange = LVFiltersChange
- OnCustomDrawItem = LVFiltersCustomDrawItem
- OnSelectItem = LVFiltersSelectItem
- end
+ Top = 447
+ Width = 317
+ Height = 19
+ Panels = <>
+ SimplePanel = False
end
- object Panel2: TPanel
+ object Panel3: TPanel
Left = 0
Top = 0
- Width = 559
- Height = 97
- Align = alTop
+ Width = 317
+ Height = 447
+ Align = alClient
BevelOuter = bvNone
- Caption = 'Panel2'
+ Caption = 'Panel3'
TabOrder = 1
- object LVTools: TListView
+ object PageControl1: TPageControl
Left = 0
Top = 0
- Width = 559
- Height = 97
- Align = alClient
- BorderStyle = bsNone
- Color = clBtnFace
- Columns = <>
- ReadOnly = True
+ Width = 318
+ Height = 448
+ ActivePage = TabSheet1
+ Anchors = [akLeft, akTop, akRight, akBottom]
TabOrder = 0
- ViewStyle = vsList
- OnChange = LVFiltersChange
- OnCustomDrawItem = LVFiltersCustomDrawItem
- OnSelectItem = LVToolsSelectItem
- end
- object m1: TMemo
- Left = 144
- Top = 8
- Width = 129
- Height = 33
- TabOrder = 1
- Visible = False
- WordWrap = False
+ object TabSheet1: TTabSheet
+ Caption = 'Tools'
+ object Panel2: TPanel
+ Left = 0
+ Top = 0
+ Width = 310
+ Height = 420
+ Align = alClient
+ BevelOuter = bvNone
+ Caption = 'Panel2'
+ TabOrder = 0
+ object LVTools: TListView
+ Left = 0
+ Top = 0
+ Width = 310
+ Height = 420
+ Align = alClient
+ BorderStyle = bsNone
+ Color = clBtnFace
+ Columns = <>
+ ReadOnly = True
+ TabOrder = 0
+ ViewStyle = vsList
+ OnChange = LVFiltersChange
+ OnCustomDrawItem = LVFiltersCustomDrawItem
+ OnSelectItem = LVToolsSelectItem
+ end
+ object m1: TMemo
+ Left = 16
+ Top = 8
+ Width = 129
+ Height = 33
+ TabOrder = 1
+ Visible = False
+ WordWrap = False
+ end
+ end
+ end
+ object TabSheet2: TTabSheet
+ Caption = 'Filters'
+ ImageIndex = 1
+ object Panel1: TPanel
+ Left = 0
+ Top = 0
+ Width = 310
+ Height = 420
+ Align = alClient
+ BevelOuter = bvNone
+ Caption = 'Panel1'
+ TabOrder = 0
+ object LVFilters: TListView
+ Left = 0
+ Top = 0
+ Width = 310
+ Height = 420
+ Align = alClient
+ BorderStyle = bsNone
+ Color = clBtnFace
+ Columns = <
+ item
+ AutoSize = True
+ Caption = 'Name'
+ end
+ item
+ AutoSize = True
+ Caption = 'Info'
+ end>
+ ReadOnly = True
+ SortType = stText
+ TabOrder = 0
+ ViewStyle = vsList
+ OnChange = LVFiltersChange
+ OnCustomDrawItem = LVFiltersCustomDrawItem
+ OnSelectItem = LVFiltersSelectItem
+ end
+ end
+ end
end
end
- object bar: TStatusBar
- Left = 0
- Top = 236
- Width = 559
- Height = 19
- Panels = <>
- SimplePanel = False
+ object sd: TScanDir
+ OnHandleFile = sdHandleFile
+ Left = 104
+ Top = 7
end
end
diff --git a/Source/toolbarunit.pas b/Source/toolbarunit.pas
index 5449b53..c479260 100644
--- a/Source/toolbarunit.pas
+++ b/Source/toolbarunit.pas
@@ -4,17 +4,22 @@ interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
- ComCtrls, ToolWin, Buttons, ExtCtrls, StdCtrls, ImgList;
+ ComCtrls, ToolWin, Buttons, ExtCtrls, StdCtrls, ImgList,
+ SendKeys, Filez;
type
Ttoolbar = class(TForm)
- Panel1: TPanel;
- LVFilters: TListView;
+ bar: TStatusBar;
+ sd: TScanDir;
+ Panel3: TPanel;
+ PageControl1: TPageControl;
+ TabSheet1: TTabSheet;
+ TabSheet2: TTabSheet;
Panel2: TPanel;
LVTools: TListView;
- Splitter1: TSplitter;
- bar: TStatusBar;
m1: TMemo;
+ Panel1: TPanel;
+ LVFilters: TListView;
procedure FormCreate(Sender: TObject);
procedure LVFiltersCustomDrawItem(Sender: TCustomListView;
Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
@@ -24,8 +29,11 @@ type
Selected: Boolean);
procedure LVToolsSelectItem(Sender: TObject; Item: TListItem;
Selected: Boolean);
+ procedure sdHandleFile(const SearchRec: TSearchRec;
+ const FullPath: String);
private
{ Private declarations }
+ SendKey: TSendKey;
public
{ Public declarations }
end;
@@ -40,6 +48,18 @@ uses
{$R *.DFM}
+procedure Ttoolbar.sdHandleFile(const SearchRec: TSearchRec;
+ const FullPath: String);
+begin
+ if ExtractFileExt(UpperCase(FullPath))<>'.8BF' then Exit;
+
+ with LVFilters.Items.Add do begin
+ Caption := ExtractFileName(FullPath);
+ Caption := Copy(Caption, 1, Length(Caption)-4);
+ Data := Pointer(-1);
+ end;
+end;
+
procedure Ttoolbar.FormCreate(Sender: TObject);
var
i: Integer;
@@ -56,7 +76,7 @@ begin
end;
end;
- // Load filters
+ // Load plugins
if main.Plugins.Names.Count>0 then
for i:=0 to main.Plugins.Names.Count-1 do begin
with LVFilters.Items.Add do begin
@@ -65,6 +85,11 @@ begin
Data := Pointer(i);
end;
end;
+
+ // Load photoshop-filters
+ sd.Scan(main.FSFolder+'\Filters');
+
+ SendKey := TSendKey.Create(Self);
Show;
end;
@@ -83,7 +108,7 @@ procedure Ttoolbar.LVFiltersCustomDrawItem(Sender: TCustomListView;
Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
var
Title: array[0..255] of Char;
- s, cmd: String;
+ s: String;
h: THandle;
begin
if (it=nil) or (Item.Caption='') then Exit;
@@ -97,10 +122,13 @@ begin
if Pos('*', S)>0 then Delete(S, Pos('*', S), 255);
// main.Post(Item.Caption+' -> '+S);
if Item.ListView=LVFilters then
- cmd := 'msg'
- else
- cmd := 'obj';
- main.SendReturnValues('obj pd-'+S+'='+cmd+' 10 10 '+Item.Caption+';');
+ main.SendReturnValues('obj pd-'+S+'=msg 10 10 '+Item.Caption+';')
+ else begin
+ SendKey.Delay := 100;
+ SendKey.TitleText := S;
+ SendKey.Keys := '{^1}'+Item.Caption;
+ SendKey.execute;
+ end;
Item.ListView.Selected := nil;
end;
end;
@@ -110,13 +138,18 @@ end;
procedure Ttoolbar.LVFiltersSelectItem(Sender: TObject; Item: TListItem;
Selected: Boolean);
var
+ i: Longint;
S: String;
begin
- S := main.Plugins.Info(Integer(Item.Data));
- if S='' then
- bar.SimpleText := '<no info available>'
- else
- bar.SimpleText := Item.Caption+': '+S;
+ i := Longint(Item.Data);
+ if i=-1 then bar.SimpleText := Item.Caption+': Photoshop-filter'
+ else begin
+ S := main.Plugins.Info(i);
+ if S='' then
+ bar.SimpleText := Item.Caption+': <no info available>'
+ else
+ bar.SimpleText := Item.Caption+': '+S;
+ end;
end;
procedure Ttoolbar.LVToolsSelectItem(Sender: TObject; Item: TListItem;