1
0
mirror of https://github.com/moparisthebest/Simba synced 2024-11-29 12:32:14 -05:00

Lil updates!

git-svn-id: http://www.villavu.com/repositories/merlijn/mufasa@369 3f818213-9676-44b0-a9b4-5e4c4e03d09d
This commit is contained in:
Raymond 2010-01-04 16:52:43 +00:00
parent b7f2cf6a61
commit 332e568042

View File

@ -96,6 +96,8 @@ type
FrozenData : PRGB32; FrozenData : PRGB32;
FrozenSize : TPoint; FrozenSize : TPoint;
TargetBitmap : TMufasaBitmap; TargetBitmap : TMufasaBitmap;
{:Called before setting the NewTarget, deletes stuff related to OldTarget and sets the new targetmode}
procedure OnSetTarget(NewTarget,OldTarget : TTargetWindowMode);
public public
// Target Window Mode. // Target Window Mode.
TargetMode: TTargetWindowMode; TargetMode: TTargetWindowMode;
@ -174,6 +176,8 @@ begin
Self.ArrayPtr := nil; Self.ArrayPtr := nil;
Self.ArraySize := Classes.Point(-1, -1); Self.ArraySize := Classes.Point(-1, -1);
Self.TargetBitmap := nil;
{$IFDEF MSWINDOWS} {$IFDEF MSWINDOWS}
Self.DrawBitmap := TBitmap.Create; Self.DrawBitmap := TBitmap.Create;
Self.DrawBitmap.PixelFormat:= pf32bit; Self.DrawBitmap.PixelFormat:= pf32bit;
@ -225,6 +229,24 @@ begin
inherited; inherited;
end; end;
procedure TMWindow.OnSetTarget(NewTarget,OldTarget : TTargetWindowMode);
begin
case OldTarget of
w_Window: begin
if not Self.TargetDC= Self.DesktopDC then
ReleaseDC(Self.TargetHandle,Self.TargetDC);
end;
w_XWindow: Self.FreeReturnData;
end;
//Set them to zero, just in case ;-).
if NewTarget <> w_BMP then
Self.TargetBitmap := nil;
if NewTarget <> w_ArrayPtr then
self.ArrayPtr := nil;
Self.TargetMode:= NewTarget;
end;
procedure TMWindow.SetWindow(Window: TMWindow); procedure TMWindow.SetWindow(Window: TMWindow);
begin begin
case Window.TargetMode of case Window.TargetMode of
@ -256,7 +278,9 @@ begin
{$IFDEF LINUX} {$IFDEF LINUX}
Self.SetTarget(Self.DesktopWindow); Self.SetTarget(Self.DesktopWindow);
{$ELSE} {$ELSE}
Self.SetTarget(Self.DesktopHWND, w_Window); OnSetTarget(w_window, Self.TargetMode);
Self.TargetDC:= DesktopDC;
Self.TargetHandle:= DesktopHWND;
{$ENDIF} {$ENDIF}
end; end;
@ -268,20 +292,23 @@ var
Attrib: TXWindowAttributes; Attrib: TXWindowAttributes;
{$ENDIF} {$ENDIF}
begin begin
case Self.TargetMode of
w_BMP : result := TargetBitmap <> nil;
w_Window : result := IsWindow(self.TargetHandle);
w_ArrayPtr : result := ArrayPtr <> nil;
w_HDC : result := Self.TargetDC <> 0;
w_XWindow : begin
{$IFDEF LINUX} {$IFDEF LINUX}
old_handler := XSetErrorHandler(@MufasaXErrorHandler); old_handler := XSetErrorHandler(@MufasaXErrorHandler);
{ There must be a better way to do this, at least with less overhead. } { There must be a better way to do this, at least with less overhead. }
if XGetWindowAttributes(Self.XDisplay, Self.CurWindow, @Attrib) = 0 then if XGetWindowAttributes(Self.XDisplay, Self.CurWindow, @Attrib) = 0 then
result := false result := false
else else
result := true; result := true;
XSetErrorHandler(old_handler); XSetErrorHandler(old_handler);
{$ELSE}
writeln('stub: TMWindow.TargetValid on Windows. Returning true.');
Exit(True);
{$ENDIF} {$ENDIF}
end;
end;
end; end;
procedure TMWindow.OnTargetBitmapDestroy(Bitmap: TMufasaBitmap); procedure TMWindow.OnTargetBitmapDestroy(Bitmap: TMufasaBitmap);
@ -454,8 +481,8 @@ begin
raise Exception.CreateFMT('TMWindow.Unfreeze: The window is not frozen.',[]); raise Exception.CreateFMT('TMWindow.Unfreeze: The window is not frozen.',[]);
FreeMem(Self.FrozenData); FreeMem(Self.FrozenData);
Self.FrozenData := nil; Self.FrozenData := nil;
Result := True;
Self.FreezeState:=False; Self.FreezeState:=False;
Result := True;
end; end;
// Set's input focus on Linux, does not mean the window will look `active', but // Set's input focus on Linux, does not mean the window will look `active', but
@ -621,10 +648,8 @@ var
begin begin
if Self.Frozen then if Self.Frozen then
raise Exception.CreateFMT('You cannot set a target when Frozen',[]); raise Exception.CreateFMT('You cannot set a target when Frozen',[]);
Old_Handler := XSetErrorHandler(@MufasaXErrorHandler); OnSetTarget(w_XWindow,Self.TargetMode)
Self.CurWindow := XWindow; Self.CurWindow := XWindow;
Self.TargetMode:= w_XWindow;
XSetErrorHandler(Old_Handler);
end; end;
{$ENDIF} {$ENDIF}
@ -635,18 +660,21 @@ begin
raise Exception.CreateFMT('You cannot set a target when Frozen',[]); raise Exception.CreateFMT('You cannot set a target when Frozen',[]);
if NewType in [ w_XWindow, w_ArrayPtr ] then if NewType in [ w_XWindow, w_ArrayPtr ] then
raise Exception.createFMT('SetTarget: Invalid new type.', []); raise Exception.createFMT('SetTarget: Invalid new type.', []);
OnSetTarget(NewType,self.TargetMode);
case NewType of case NewType of
w_HDC :
begin
{$ifdef MSWindows}
Self.TargetDC:= Window;
{$else}
Raise Exception.Create('HDC not supported on linux (yet)');
{$endif}
end;
w_Window : w_Window :
begin; begin;
{$IFDEF MSWINDOWS} {$IFDEF MSWINDOWS}
//We had the desktop as target -> Not freeing that DC! //The old DC is free'd in OnSetTarget.
if not Self.TargetDC= Self.DesktopDC then
ReleaseDC(Self.TargetHandle,Self.TargetDC);
Self.TargetHandle := Window; Self.TargetHandle := Window;
if Window = Self.DesktopHWND then
Self.TargetDC := DesktopDC
else
Self.TargetDC := GetWindowDC(Window); Self.TargetDC := GetWindowDC(Window);
{$ENDIF} {$ENDIF}
end; end;
@ -668,29 +696,20 @@ function TMWindow.SetTarget(ArrPtr: PRGB32; Size: TPoint): integer; overload;
begin begin
if Self.Frozen then if Self.Frozen then
raise Exception.CreateFMT('You cannot set a target when Frozen',[]); raise Exception.CreateFMT('You cannot set a target when Frozen',[]);
If Self.TargetMode = w_XWindow then OnSetTarget(w_ArrayPtr,self.TargetMode);
Self.FreeReturnData; Self.SetDesktop;//Set the underlaying window to desktop for key-sending etc..
Self.ArrayPtr := ArrPtr; Self.ArrayPtr := ArrPtr;
Self.ArraySize := Size; Self.ArraySize := Size;
Self.TargetMode:= w_ArrayPtr;
{$IFDEF LINUX}
Self.CurWindow := Self.DesktopWindow;
{$ENDIF}
{$IFDEF WINDOWS}
Self.TargetHandle:= windows.GetDesktopWindow;
{$ENDIF}
end; end;
// Set target to Bitmap // Set target to Bitmap, set desktop for keyinput/output
function TMWindow.SetTarget(Bitmap: TMufasaBitmap): integer; function TMWindow.SetTarget(Bitmap: TMufasaBitmap): integer;
begin begin
if Self.Frozen then if Self.Frozen then
raise Exception.CreateFMT('You cannot set a target when Frozen',[]); raise Exception.CreateFMT('You cannot set a target when Frozen',[]);
TargetBitmap := Bitmap; OnSetTarget(w_BMP,self.TargetMode);
self.TargetMode:= w_BMP; Self.SetDesktop;
Self.TargetBitmap := Bitmap;
Bitmap.OnDestroy:= @OnTargetBitmapDestroy; Bitmap.OnDestroy:= @OnTargetBitmapDestroy;
end; end;