aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CHANGELOG.txt2
-rwxr-xr-xFramestein.exebin912384 -> 970240 bytes
-rw-r--r--Patches/05.example-plugins.pd5
-rw-r--r--Patches/fs.grid.pd30
-rw-r--r--Patches/fs.main.pd22
-rw-r--r--Patches/xop.pd13
-rw-r--r--Plugins/2colors.cpp2
-rw-r--r--Plugins/2colors.dllbin28672 -> 36864 bytes
-rw-r--r--Plugins/argument-passing.cpp8
-rw-r--r--Plugins/argument-passing.dllbin40960 -> 40960 bytes
-rw-r--r--Plugins/black.c3
-rw-r--r--Plugins/black.dllbin28672 -> 36864 bytes
-rw-r--r--Plugins/gol.c2
-rw-r--r--Plugins/gol.dllbin36864 -> 36864 bytes
-rw-r--r--Plugins/green.cpp2
-rw-r--r--Plugins/green.dllbin28672 -> 36864 bytes
-rw-r--r--Plugins/hist.cpp2
-rw-r--r--Plugins/hist.dllbin45056 -> 45056 bytes
-rw-r--r--Plugins/makefile7
-rw-r--r--Plugins/plugin.h4
-rw-r--r--Plugins/rgb.c2
-rw-r--r--Plugins/rgb.dllbin36864 -> 36864 bytes
-rw-r--r--Plugins/shuffle.c2
-rw-r--r--Plugins/shuffle.dllbin28672 -> 36864 bytes
-rw-r--r--Plugins/sonogram.cpp3
-rw-r--r--Plugins/sonogram.dllbin45056 -> 49152 bytes
-rw-r--r--Plugins/subtract.cpp2
-rw-r--r--Plugins/subtract.dllbin40960 -> 40960 bytes
-rw-r--r--Plugins/tile.cpp2
-rw-r--r--Plugins/tile.dllbin28672 -> 36864 bytes
-rw-r--r--README.txt6
-rw-r--r--Source/Framestein.cfg1
-rw-r--r--Source/Framestein.dof5
-rw-r--r--Source/Framestein.dpr4
-rw-r--r--Source/mainunit.dfm6
-rw-r--r--Source/mainunit.pas10
-rw-r--r--Source/pluginunit.pas29
-rw-r--r--Source/toolbarunit.dfm104
-rw-r--r--Source/toolbarunit.pas136
39 files changed, 394 insertions, 20 deletions
diff --git a/CHANGELOG.txt b/CHANGELOG.txt
index f74fe8c..c737d7e 100644
--- a/CHANGELOG.txt
+++ b/CHANGELOG.txt
@@ -1,4 +1,5 @@
0.32
+- added toolbar, paste objects to patches
- new plugin: lightspeed
- fs.frame: |title this is the main window( and |undock( commands
- fs.copy: transcolor <r> <g> <b> to set the transparent color
@@ -17,6 +18,7 @@
- added line width setting to fs.draw
- fix: border_0 no longer alters frame dimensions
+- preventing lockups-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 a7622fb..a288d08 100755
--- a/Framestein.exe
+++ b/Framestein.exe
Binary files differ
diff --git a/Patches/05.example-plugins.pd b/Patches/05.example-plugins.pd
index 630514e..4a46af1 100644
--- a/Patches/05.example-plugins.pd
+++ b/Patches/05.example-plugins.pd
@@ -1,8 +1,8 @@
-#N canvas 106 10 880 659 12;
+#N canvas 106 10 882 661 12;
#X obj 11 41 fs.main;
#X msg 11 11 6001;
#X msg 62 12 reset;
-#X text 157 37 Using Plugins;
+#X text 159 40 Using Plugins;
#X obj 65 224 fs.framed plugins;
#X msg 209 225 76 + 446;
#X msg 34 95 noize;
@@ -23,6 +23,7 @@ operation.;
#X msg 209 289 xbend 40 140;
#X obj 321 359 init;
#X obj 284 225 init;
+#X text 160 591 See the Plugins-dir for more.;
#X connect 1 0 0 0;
#X connect 1 0 2 0;
#X connect 2 0 0 1;
diff --git a/Patches/fs.grid.pd b/Patches/fs.grid.pd
new file mode 100644
index 0000000..2819a1e
--- /dev/null
+++ b/Patches/fs.grid.pd
@@ -0,0 +1,30 @@
+#N canvas 290 97 559 504 12;
+#X obj 167 176 init;
+#X obj 111 267 unpack f f f f;
+#X obj 190 303 / 176;
+#X obj 237 303 / 144;
+#X obj 237 328 xop - 1;
+#X text 18 44 args: <x-max> <y-max> <window to dock to>;
+#X msg 167 203 mousetrack_1 \, mouserect_1;
+#X obj 190 437 outlet;
+#X obj 247 437 outlet;
+#X obj 325 437 outlet;
+#X obj 190 328 * \$1;
+#X obj 237 353 * \$2;
+#X obj 66 237 fs.framed \$3;
+#X obj 66 179 inlet;
+#X text 18 72 inlets: to fs.frame;
+#X text 18 88 outlets: x \, y \, fs.frame 3rd outlet;
+#X text 18 14 fs.grid -- grid control module;
+#X connect 0 0 6 0;
+#X connect 1 2 2 0;
+#X connect 1 3 3 0;
+#X connect 2 0 10 0;
+#X connect 3 0 4 0;
+#X connect 4 0 11 0;
+#X connect 6 0 12 0;
+#X connect 10 0 7 0;
+#X connect 11 0 8 0;
+#X connect 12 1 1 0;
+#X connect 12 2 9 0;
+#X connect 13 0 12 0;
diff --git a/Patches/fs.main.pd b/Patches/fs.main.pd
index a86c338..4ce265d 100644
--- a/Patches/fs.main.pd
+++ b/Patches/fs.main.pd
@@ -1,4 +1,4 @@
-#N canvas 278 0 710 499 12;
+#N canvas 278 0 720 628 12;
#X floatatom 27 322 4 0 0;
#X obj 207 160 loadbang;
#X msg 206 254 disconnect;
@@ -13,10 +13,10 @@
#X text 439 42 reset;
#X obj 393 132 t b b;
#X msg 428 158 send reset;
-#X obj 157 382 pack s f;
+#X obj 280 409 pack s f;
#X floatatom 272 378 4 0 0;
#X text 10 7 fs.main - handles communication with Framestein.;
-#X msg 157 411 \; \$1 \$2;
+#X msg 280 433 \; \$1 \$2;
#X text 149 291 you can run framestein and the control-patches on separate
machines by changing "localhost" to "your.windows.slave" above and
configuring fs likewise (right-click fs).;
@@ -32,6 +32,15 @@ configuring fs likewise (right-click fs).;
#X obj 530 207 r fs_reset;
#X msg 207 185 6001;
#X obj 27 293 netsend;
+#X msg 159 551 ping;
+#X obj 159 576 print fs.main;
+#X text 152 484 this can be used to resolve lockups: mark an area in
+pd console \, after a while pd will stop sending commands to fs.;
+#X msg 137 439 \; \$1 \$2 \$3 \$4 \$5;
+#X obj 137 416 pack s s f f s;
+#X obj 157 382 route obj;
+#X obj 159 526 fps 0;
+#X text 209 525 change to 0.1 to turn it on;
#X connect 1 0 29 0;
#X connect 2 0 30 0;
#X connect 3 0 30 0;
@@ -46,8 +55,13 @@ configuring fs likewise (right-click fs).;
#X connect 14 0 17 0;
#X connect 20 0 12 0;
#X connect 20 1 21 0;
-#X connect 22 0 14 0;
+#X connect 22 0 36 0;
#X connect 22 1 15 0;
#X connect 23 0 30 0;
#X connect 29 0 23 0;
#X connect 30 0 0 0;
+#X connect 31 0 32 0;
+#X connect 35 0 34 0;
+#X connect 36 0 35 0;
+#X connect 36 1 14 0;
+#X connect 37 0 31 0;
diff --git a/Patches/xop.pd b/Patches/xop.pd
new file mode 100644
index 0000000..b02df33
--- /dev/null
+++ b/Patches/xop.pd
@@ -0,0 +1,13 @@
+#N canvas 142 281 462 312 12;
+#X obj 207 56 inlet;
+#X obj 207 99 t b f;
+#X obj 223 223 outlet;
+#X obj 223 179 \$1;
+#X obj 207 136 f \$2;
+#X obj 301 56 inlet;
+#X connect 0 0 1 0;
+#X connect 1 0 4 0;
+#X connect 1 1 3 1;
+#X connect 3 0 2 0;
+#X connect 4 0 3 0;
+#X connect 5 0 4 1;
diff --git a/Plugins/2colors.cpp b/Plugins/2colors.cpp
index b76be62..e594c2b 100644
--- a/Plugins/2colors.cpp
+++ b/Plugins/2colors.cpp
@@ -19,3 +19,5 @@ void perform_effect(_frame f, _args a)
p.next();
}
}
+
+INFO("go black and white")
diff --git a/Plugins/2colors.dll b/Plugins/2colors.dll
index ba62b0f..fbb0e4d 100644
--- a/Plugins/2colors.dll
+++ b/Plugins/2colors.dll
Binary files differ
diff --git a/Plugins/argument-passing.cpp b/Plugins/argument-passing.cpp
index d89e8c1..0247b5f 100644
--- a/Plugins/argument-passing.cpp
+++ b/Plugins/argument-passing.cpp
@@ -1,9 +1,11 @@
+#include "plugin.h"
+#include "pixels.h"
+
//
-// example of parsing arguments in a plugin using the arguments-class (defined in pixels.h)
+INFO("example of parsing arguments in a plugin using the arguments-class")
+// (defined in pixels.h)
//
-#include "pixels.h"
-
void perform_effect(_frame f, _args a)
{
arguments ar(a.s);
diff --git a/Plugins/argument-passing.dll b/Plugins/argument-passing.dll
index dfa112e..d77a64b 100644
--- a/Plugins/argument-passing.dll
+++ b/Plugins/argument-passing.dll
Binary files differ
diff --git a/Plugins/black.c b/Plugins/black.c
index 3716767..dbb672f 100644
--- a/Plugins/black.c
+++ b/Plugins/black.c
@@ -1,6 +1,8 @@
#include <stdlib.h>
#include "plugin.h"
+INFO("total blackness")
+
void perform_effect(_frame f, _args a)
{
memset(f.bits, 0, f.height*f.lpitch);
@@ -11,3 +13,4 @@ void perform_copy(_frame f1, _frame f2, _args a)
memset(f1.bits, 0, f1.height*f1.lpitch);
memset(f2.bits, 0, f2.height*f2.lpitch);
}
+
diff --git a/Plugins/black.dll b/Plugins/black.dll
index cb8b57a..474d5ef 100644
--- a/Plugins/black.dll
+++ b/Plugins/black.dll
Binary files differ
diff --git a/Plugins/gol.c b/Plugins/gol.c
index 3349df2..222a894 100644
--- a/Plugins/gol.c
+++ b/Plugins/gol.c
@@ -11,6 +11,8 @@
#define BORN 1
#define DYING 2
+INFO("Conway's Game Of Life")
+
int aroundme(_frame f, int x, int y)
{
pixel16 *p;
diff --git a/Plugins/gol.dll b/Plugins/gol.dll
index 611f227..26fe8e9 100644
--- a/Plugins/gol.dll
+++ b/Plugins/gol.dll
Binary files differ
diff --git a/Plugins/green.cpp b/Plugins/green.cpp
index c66e3e6..53f58e5 100644
--- a/Plugins/green.cpp
+++ b/Plugins/green.cpp
@@ -12,3 +12,5 @@ void perform_effect(_frame f, _args a)
p.next();
}
}
+
+INFO("go green")
diff --git a/Plugins/green.dll b/Plugins/green.dll
index 3dc1016..d1f42d6 100644
--- a/Plugins/green.dll
+++ b/Plugins/green.dll
Binary files differ
diff --git a/Plugins/hist.cpp b/Plugins/hist.cpp
index f525db1..84c6a6e 100644
--- a/Plugins/hist.cpp
+++ b/Plugins/hist.cpp
@@ -13,6 +13,8 @@
#include "plugin.h"
#include "pixels.h"
+INFO("helper for fs.hist")
+
void perform_effect(_frame f, _args a)
{
if(!a.s) return;
diff --git a/Plugins/hist.dll b/Plugins/hist.dll
index 7c0bc44..30937b8 100644
--- a/Plugins/hist.dll
+++ b/Plugins/hist.dll
Binary files differ
diff --git a/Plugins/makefile b/Plugins/makefile
index dd1b028..f4e6b6c 100644
--- a/Plugins/makefile
+++ b/Plugins/makefile
@@ -15,9 +15,10 @@ all: noize colortv subtract xbend bend gol shuffle green \
FLAGS = /LD /Gd /GD /Ox
-EFFECT = /export:perform_effect
-COPY = /export:perform_copy
-BOTH = /export:perform_effect /export:perform_copy
+# does this suck or what? how to do it better?
+EFFECT = /export:info /export:perform_effect
+COPY = /export:info /export:perform_copy
+BOTH = /export:info /export:perform_effect /export:perform_copy
noize:
cl noize.c $(FLAGS) /link $(BOTH)
diff --git a/Plugins/plugin.h b/Plugins/plugin.h
index 00281e5..69ed298 100644
--- a/Plugins/plugin.h
+++ b/Plugins/plugin.h
@@ -133,4 +133,8 @@ __inline byte klamp601(long in)
return(out);
}
+// use this to easily describe your plugins:
+
+#define INFO(x) void info(char *s) { sprintf(s, x); }
+
#endif // #ifndef _PLUGINH
diff --git a/Plugins/rgb.c b/Plugins/rgb.c
index d58f784..ebe9c38 100644
--- a/Plugins/rgb.c
+++ b/Plugins/rgb.c
@@ -1,6 +1,8 @@
#include <string.h>
#include "plugin.h"
+INFO("helper for fs.rgb")
+
void perform_effect(_frame f, _args a)
{
char *t;
diff --git a/Plugins/rgb.dll b/Plugins/rgb.dll
index ba7dfd2..76e18b7 100644
--- a/Plugins/rgb.dll
+++ b/Plugins/rgb.dll
Binary files differ
diff --git a/Plugins/shuffle.c b/Plugins/shuffle.c
index 0604595..e4254fa 100644
--- a/Plugins/shuffle.c
+++ b/Plugins/shuffle.c
@@ -1,6 +1,8 @@
#include <string.h>
#include "plugin.h"
+INFO("randomly move around pixels")
+
void perform_effect(_frame f, _args a)
{
int i, o=1000, x1, y1, x2, y2, range=10;
diff --git a/Plugins/shuffle.dll b/Plugins/shuffle.dll
index bd5d552..d46d5aa 100644
--- a/Plugins/shuffle.dll
+++ b/Plugins/shuffle.dll
Binary files differ
diff --git a/Plugins/sonogram.cpp b/Plugins/sonogram.cpp
index 821b94a..68c86fe 100644
--- a/Plugins/sonogram.cpp
+++ b/Plugins/sonogram.cpp
@@ -18,6 +18,8 @@
#define SONOMAXVAL 500
#define sonotype float
+INFO("helper for fs.sonogram")
+
int callcount=-1;
void perform_effect(_frame f, _args a)
@@ -80,3 +82,4 @@ void perform_effect(_frame f, _args a)
}
}
}
+
diff --git a/Plugins/sonogram.dll b/Plugins/sonogram.dll
index db6e132..2615d14 100644
--- a/Plugins/sonogram.dll
+++ b/Plugins/sonogram.dll
Binary files differ
diff --git a/Plugins/subtract.cpp b/Plugins/subtract.cpp
index 3172513..a088146 100644
--- a/Plugins/subtract.cpp
+++ b/Plugins/subtract.cpp
@@ -13,6 +13,8 @@
#include "plugin.h"
#include "pixels.h"
+INFO("subtract color components");
+
void perform_effect(_frame f, _args a)
{
arguments ar(a.s);
diff --git a/Plugins/subtract.dll b/Plugins/subtract.dll
index 65383b3..4bab85c 100644
--- a/Plugins/subtract.dll
+++ b/Plugins/subtract.dll
Binary files differ
diff --git a/Plugins/tile.cpp b/Plugins/tile.cpp
index 47fa5ca..dd584af 100644
--- a/Plugins/tile.cpp
+++ b/Plugins/tile.cpp
@@ -3,6 +3,8 @@
#include "plugin.h"
#include "pixels.h"
+INFO("duplicate image to multiple rows and columns")
+
void perform_copy(_frame f1, _frame f2, _args a)
{
pixels px(f2);
diff --git a/Plugins/tile.dll b/Plugins/tile.dll
index 58a8886..7d7e565 100644
--- a/Plugins/tile.dll
+++ b/Plugins/tile.dll
Binary files differ
diff --git a/README.txt b/README.txt
index 9474305..8f0f51b 100644
--- a/README.txt
+++ b/README.txt
@@ -20,7 +20,7 @@ to tell Pd where to find Framestein's abstractions and externals.
LICENCE
-Copyright (c) 2001-2002 Juha Vehviläinen.
+Copyright (c) 2001-2003 Juha Vehviläinen.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
@@ -39,8 +39,8 @@ Juha Vehviläinen, jusu@iki.fi
"Framestein" name and logo: Vesa Vehviläinen
-Pink Twins (http://pinktwins.com) are making some heavy use of Framestein.
-Check their site!
+Pink Twins (http://pinktwins.com) are using Framestein for all their videos.
+Check that site!
Plugins by Olaf Matthes:
http://www.akustische-kunst.de/puredata/framestein/framestein.html
diff --git a/Source/Framestein.cfg b/Source/Framestein.cfg
index 6ee2f15..d487870 100644
--- a/Source/Framestein.cfg
+++ b/Source/Framestein.cfg
@@ -31,6 +31,7 @@
-M
-$M16384,1048576
-K$00400000
+-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"
diff --git a/Source/Framestein.dof b/Source/Framestein.dof
index ddd0c6f..26929b1 100644
--- a/Source/Framestein.dof
+++ b/Source/Framestein.dof
@@ -39,7 +39,7 @@ MaxStackSize=1048576
ImageBase=4194304
ExeDescription=
[Directories]
-OutputDir=
+OutputDir=e:\fs\Framestein
UnitOutputDir=
PackageDLLOutputDir=
PackageDCPOutputDir=
@@ -90,3 +90,6 @@ Item1=E:\lab\common\DelphiX2000_0717-2\Source;E:\lab\common\fastlib;E:\lab\commo
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
+[HistoryLists\hlOutputDirectorry]
+Count=1
+Item0=e:\fs\Framestein
diff --git a/Source/Framestein.dpr b/Source/Framestein.dpr
index f280e75..009543a 100644
--- a/Source/Framestein.dpr
+++ b/Source/Framestein.dpr
@@ -17,7 +17,8 @@ uses
logunit in 'logunit.pas' {log},
pluginunit in 'pluginunit.pas',
progressunit in 'progressunit.pas' {Progress},
- configureunit in 'configureunit.pas' {configure};
+ configureunit in 'configureunit.pas' {configure},
+ toolbarunit in 'toolbarunit.pas' {toolbar};
{$R *.RES}
@@ -28,6 +29,7 @@ begin
Application.CreateForm(TProgress, Progress);
Application.CreateForm(Tconfigure, configure);
Application.CreateForm(Tlog, log);
+ Application.CreateForm(Ttoolbar, toolbar);
Application.Run;
end.
diff --git a/Source/mainunit.dfm b/Source/mainunit.dfm
index 46a9252..f5d438e 100644
--- a/Source/mainunit.dfm
+++ b/Source/mainunit.dfm
@@ -3505,8 +3505,12 @@ object main: Tmain
Caption = 'Reload plugins'
OnClick = MiReloadPluginsClick
end
+ object MiToolbar: TMenuItem
+ Caption = 'Show Toolbar'
+ OnClick = MiToolbarClick
+ end
object MiLog: TMenuItem
- Caption = 'Show debug'
+ Caption = 'Show Debug'
OnClick = MiLogClick
end
object MiExit: TMenuItem
diff --git a/Source/mainunit.pas b/Source/mainunit.pas
index 1b2a6e1..aebb64b 100644
--- a/Source/mainunit.pas
+++ b/Source/mainunit.pas
@@ -34,6 +34,7 @@ type
csToPd: TClientSocket;
MiExit: TMenuItem;
REConsole: TRichEdit;
+ MiToolbar: TMenuItem;
procedure ss1ClientRead(Sender: TObject; Socket: TCustomWinSocket);
procedure FormCreate(Sender: TObject);
procedure ss1ClientError(Sender: TObject; Socket: TCustomWinSocket;
@@ -63,6 +64,7 @@ type
procedure MiExitClick(Sender: TObject);
procedure ImageLogoDblClick(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
+ procedure MiToolbarClick(Sender: TObject);
private
{ Private declarations }
SocketMem: Pointer;
@@ -142,7 +144,7 @@ uses
fscopyunit, fstextunit, fsdrawunit, fsbrowserunit,
fsinfounit, fsaviunit,
fastfiles,
- Strz, logunit, configureunit, progressunit;
+ Strz, logunit, configureunit, progressunit, toolbarunit;
{$IFDEF FSDLL}
procedure TMainThread.Execute;
@@ -944,5 +946,11 @@ begin
{$ENDIF}
end;
+procedure Tmain.MiToolbarClick(Sender: TObject);
+begin
+ MiToolbar.Checked := not MiToolbar.Checked;
+ Toolbar.Visible := MiToolbar.Checked;
+end;
+
end.
diff --git a/Source/pluginunit.pas b/Source/pluginunit.pas
index ddee99c..f331ed8 100644
--- a/Source/pluginunit.pas
+++ b/Source/pluginunit.pas
@@ -32,18 +32,21 @@ type
const ret: PChar
); cdecl;
+ TInfoProc = procedure(const str: PChar); cdecl;
+
TPointerList = TList;
TLibraryList = TList;
TPlugins = class(TComponent)
private
- Names: TStringList;
EffectProcs: TPointerList;
CopyProcs: TPointerList;
+ InfoProcs: TPointerList;
Libs: TLibraryList;
procedure LoadHandleFile(const SearchRec: TSearchRec;
const FullPath: String);
public
+ Names: TStringList;
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure Load;
@@ -56,6 +59,7 @@ type
function CallCopy(const d1: TDirectDrawSurface;
const d2: TDirectDrawSurface;
const procIndex: Integer; const args: String): Boolean;
+ function Info(const procIndex: Integer): String;
end;
implementation
@@ -70,6 +74,7 @@ type
const
EffectProcName = 'perform_effect';
CopyProcName = 'perform_copy';
+ InfoProcName = 'info';
{ TPlugins }
@@ -79,6 +84,7 @@ begin
Names := TStringList.Create;
EffectProcs := TPointerList.Create;
CopyProcs := TPointerList.Create;
+ InfoProcs := TPointerList.Create;
Libs := TLibraryList.Create;
end;
@@ -114,6 +120,7 @@ var
b: array[0..255] of Char;
EffectProc: TEffectProc;
CopyProc: TCopyProc;
+ InfoProc: TInfoProc;
s: String;
i: Integer;
begin
@@ -123,12 +130,14 @@ begin
if h<>0 then begin
@EffectProc := GetProcAddress(h, EffectProcName);
@CopyProc := GetProcAddress(h, CopyProcName);
+ @InfoProc := GetProcAddress(h, InfoProcName);
s := ExtractFileName(FullPath);
i := Pos('.DLL', UpperCase(s));
if i>0 then Delete(s, i, 255);
Names.Add(s);
EffectProcs.Add(@EffectProc);
CopyProcs.Add(@CopyProc);
+ InfoProcs.Add(@InfoProc);
Libs.Add(@h);
end;
end;
@@ -217,5 +226,23 @@ begin
Result := True;
end;
+function TPlugins.Info(const procIndex: Integer): String;
+var
+ Proc: TInfoProc;
+ buf: array[0..255] of Char;
+ p: PChar;
+begin
+ if (procIndex=-1) or (procIndex>=InfoProcs.Count) then Exit;
+ @Proc := InfoProcs[procIndex];
+ if @Proc=nil then begin
+ Result := '';
+ Exit;
+ end;
+ buf[0]:=#0;
+ p := @buf;
+ Proc(p);
+ Result := StrPas(p);
+end;
+
end.
diff --git a/Source/toolbarunit.dfm b/Source/toolbarunit.dfm
new file mode 100644
index 0000000..5cd6673
--- /dev/null
+++ b/Source/toolbarunit.dfm
@@ -0,0 +1,104 @@
+object toolbar: Ttoolbar
+ Left = 264
+ Top = 454
+ Width = 567
+ Height = 282
+ BorderStyle = bsSizeToolWin
+ Caption = 'Toolbar'
+ Color = clBtnFace
+ Font.Charset = DEFAULT_CHARSET
+ Font.Color = clWindowText
+ Font.Height = -11
+ Font.Name = 'MS Sans Serif'
+ Font.Style = []
+ OldCreateOrder = False
+ 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
+ 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
+ end
+ object Panel2: TPanel
+ Left = 0
+ Top = 0
+ Width = 559
+ Height = 97
+ Align = alTop
+ BevelOuter = bvNone
+ Caption = 'Panel2'
+ TabOrder = 1
+ object LVTools: TListView
+ Left = 0
+ Top = 0
+ Width = 559
+ Height = 97
+ Align = alClient
+ BorderStyle = bsNone
+ Color = clBtnFace
+ Columns = <>
+ ReadOnly = True
+ 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
+ end
+ end
+ object bar: TStatusBar
+ Left = 0
+ Top = 236
+ Width = 559
+ Height = 19
+ Panels = <>
+ SimplePanel = False
+ end
+end
diff --git a/Source/toolbarunit.pas b/Source/toolbarunit.pas
new file mode 100644
index 0000000..5449b53
--- /dev/null
+++ b/Source/toolbarunit.pas
@@ -0,0 +1,136 @@
+unit toolbarunit;
+
+interface
+
+uses
+ Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
+ ComCtrls, ToolWin, Buttons, ExtCtrls, StdCtrls, ImgList;
+
+type
+ Ttoolbar = class(TForm)
+ Panel1: TPanel;
+ LVFilters: TListView;
+ Panel2: TPanel;
+ LVTools: TListView;
+ Splitter1: TSplitter;
+ bar: TStatusBar;
+ m1: TMemo;
+ procedure FormCreate(Sender: TObject);
+ procedure LVFiltersCustomDrawItem(Sender: TCustomListView;
+ Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
+ procedure LVFiltersChange(Sender: TObject; Item: TListItem;
+ Change: TItemChange);
+ procedure LVFiltersSelectItem(Sender: TObject; Item: TListItem;
+ Selected: Boolean);
+ procedure LVToolsSelectItem(Sender: TObject; Item: TListItem;
+ Selected: Boolean);
+ private
+ { Private declarations }
+ public
+ { Public declarations }
+ end;
+
+var
+ toolbar: Ttoolbar;
+
+implementation
+
+uses
+ mainunit, strz;
+
+{$R *.DFM}
+
+procedure Ttoolbar.FormCreate(Sender: TObject);
+var
+ i: Integer;
+begin
+ // Load tools
+ if FileExists(main.FSFolder+'\toolbar.txt') then begin
+ m1.Lines.LoadFromFile(main.FSFolder+'\toolbar.txt');
+ if m1.Lines.Count>0 then
+ for i:=0 to m1.Lines.Count-1 do begin
+ with LVTools.Items.Add do begin
+ Caption := ExtractWord(1, m1.Lines[i], [' ']);
+ Data := Pointer(i);
+ end;
+ end;
+ end;
+
+ // Load filters
+ if main.Plugins.Names.Count>0 then
+ for i:=0 to main.Plugins.Names.Count-1 do begin
+ with LVFilters.Items.Add do begin
+ Caption := main.Plugins.Names[i];
+ SubItems.Add(main.Plugins.Info(i));
+ Data := Pointer(i);
+ end;
+ end;
+ Show;
+end;
+
+const
+ it: TListItem = nil;
+
+procedure Ttoolbar.LVFiltersChange(Sender: TObject; Item: TListItem;
+ Change: TItemChange);
+begin
+ if Item.Selected then
+ it := item;
+ if Item.ListView.Selected=nil then it:=nil;
+end;
+
+procedure Ttoolbar.LVFiltersCustomDrawItem(Sender: TCustomListView;
+ Item: TListItem; State: TCustomDrawState; var DefaultDraw: Boolean);
+var
+ Title: array[0..255] of Char;
+ s, cmd: String;
+ h: THandle;
+begin
+ if (it=nil) or (Item.Caption='') then Exit;
+ if it.Caption=item.Caption then begin
+ Sleep(50); // wait for pd window to get focus
+ h := GetForegroundWindow;
+ if GetWindowText(h, Title, SizeOf(Title))>0 then begin
+ s := StrPas(@Title);
+ if Pos(' - ', S)>0 then begin
+ Delete(S, Pos(' - ', S), 255);
+ 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+';');
+ Item.ListView.Selected := nil;
+ end;
+ end;
+ end;
+end;
+
+procedure Ttoolbar.LVFiltersSelectItem(Sender: TObject; Item: TListItem;
+ Selected: Boolean);
+var
+ S: String;
+begin
+ S := main.Plugins.Info(Integer(Item.Data));
+ if S='' then
+ bar.SimpleText := '<no info available>'
+ else
+ bar.SimpleText := Item.Caption+': '+S;
+end;
+
+procedure Ttoolbar.LVToolsSelectItem(Sender: TObject; Item: TListItem;
+ Selected: Boolean);
+var
+ S: String;
+ i: Integer;
+begin
+ i := Integer(Item.Data);
+ if (i>=0) and (i<m1.Lines.Count) then begin
+ S := m1.Lines[i];
+ if Pos(' ', S)>0 then Delete(S, 1, Pos(' ', S));
+ bar.SimpleText := S;
+ end;
+end;
+
+end.