Componentes.Terceros.jvcl/official/3.32/run/JvgImage.pas

565 lines
15 KiB
ObjectPascal

{-----------------------------------------------------------------------------
The contents of this file are subject to the Mozilla Public License
Version 1.1 (the "License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.mozilla.org/MPL/MPL-1.1.html
Software distributed under the License is distributed on an "AS IS" basis,
WITHOUT WARRANTY OF ANY KIND, either expressed or implied. See the License for
the specific language governing rights and limitations under the License.
The Original Code is: JvgImage.PAS, released on 2003-01-15.
The Initial Developer of the Original Code is Andrey V. Chudin, [chudin att yandex dott ru]
Portions created by Andrey V. Chudin are Copyright (C) 2003 Andrey V. Chudin.
All Rights Reserved.
Contributor(s):
Michael Beck [mbeck att bigfoot dott com].
You may retrieve the latest version of this file at the Project JEDI's JVCL home page,
located at http://jvcl.sourceforge.net
Known Issues:
-----------------------------------------------------------------------------}
// $Id: JvgImage.pas 10612 2006-05-19 19:04:09Z jfudickar $
unit JvgImage;
{$I jvcl.inc}
interface
uses
{$IFDEF USEJVCL}
{$IFDEF UNITVERSIONING}
JclUnitVersioning,
{$ENDIF UNITVERSIONING}
{$ENDIF USEJVCL}
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms,
Dialogs, ExtCtrls,
{$IFDEF USEJVCL}
JvComponent,
{$ENDIF USEJVCL}
JvgTypes, JvgUtils, JvgCommClasses;
type
{$IFDEF USEJVCL}
TJvgBitmapImage = class(TJvGraphicControl)
{$ELSE}
TJvgBitmapImage = class(TGraphicControl)
{$ENDIF USEJVCL}
private
FAutoSize: Boolean;
FImageAlign: TJvg2DAlign;
FBitmapOption: TglWallpaperOption;
FDrawState: TglDrawState;
FTransparent: Boolean;
FTransparentColor: TColor;
FMasked: Boolean;
FMaskedColor: TColor;
FMaskedToColor: TColor;
FDisabledMaskColor: TColor;
FBitmap: TBitmap;
FImage: TImage;
FAutoTransparentColor: TglAutoTransparentColor;
FFastDraw: Boolean;
FBmp: TBitmap;
FChanged: Boolean;
FOnChangeParams: TNotifyEvent;
// FOldClientRect: TRect;
FOldWidth: Integer;
FOldHeight: Integer;
procedure CreateResBitmap;
procedure Changed;
procedure SmthChanged(Sender: TObject);
function CalcAlignOffset: TPoint;
function GetBitmap: TBitmap;
procedure SetBitmap(Value: TBitmap);
procedure SetImage(Value: TImage);
procedure SetBitmapOption(Value: TglWallpaperOption);
procedure SetDrawState(Value: TglDrawState);
procedure SetTransparent(Value: Boolean);
procedure SetTransparentColor(Value: TColor);
procedure SetMasked(Value: Boolean);
procedure SetMaskedColor(Value: TColor);
procedure SetMaskedToColor(Value: TColor);
procedure SetDisabledMaskColor(Value: TColor);
procedure SetAutoTransparentColor(Value: TglAutoTransparentColor);
procedure SetFastDraw(Value: Boolean);
protected
procedure SetAutoSize(Value: Boolean); override;
procedure Loaded; override;
procedure Notification(AComponent: TComponent; Operation: TOperation); override;
public
FResBitmap: TBitmap; //...you can use it!
// procedure PaintTo(Canvas: TCanvas);
procedure Paint; override;
property Canvas;
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure RemakeBackground; //...for users
// procedure RepaintBackground; //...for users
published
property AutoSize: Boolean read FAutoSize write SetAutoSize default False;
property Bitmap: TBitmap read GetBitmap write SetBitmap;
property Image: TImage read FImage write SetImage;
property ImageAlign: TJvg2DAlign read FImageAlign write FImageAlign;
property BitmapOption: TglWallpaperOption read FBitmapOption write SetBitmapOption default fwoNone;
property DrawState: TglDrawState read FDrawState write SetDrawState default fdsDefault;
property Transparent: Boolean read FTransparent write SetTransparent default False;
property TransparentColor: TColor read FTransparentColor write SetTransparentColor default clOlive;
property Masked: Boolean read FMasked write SetMasked default False;
property MaskedColor: TColor read FMaskedColor write SetMaskedColor default clOlive;
property MaskedToColor: TColor read FMaskedToColor write SetMaskedToColor default clBtnFace;
property DisabledMaskColor: TColor read FDisabledMaskColor write SetDisabledMaskColor default clBlack;
property AutoTransparentColor: TglAutoTransparentColor read FAutoTransparentColor
write SetAutoTransparentColor default ftcLeftBottomPixel;
property FastDraw: Boolean read FFastDraw write SetFastDraw default False;
property Anchors;
property Align;
property Color;
property DragCursor;
property DragMode;
property Enabled;
property Font;
property ParentColor;
property ParentFont;
property ParentShowHint;
property PopupMenu;
property ShowHint;
property Visible;
property OnClick;
property OnDblClick;
property OnDragDrop;
property OnDragOver;
property OnEndDrag;
property OnMouseDown;
property OnMouseMove;
property OnMouseUp;
property OnStartDrag;
property OnChangeParams: TNotifyEvent read FOnChangeParams write FOnChangeParams;
end;
{$IFDEF USEJVCL}
{$IFDEF UNITVERSIONING}
const
UnitVersioning: TUnitVersionInfo = (
RCSfile: '$URL: https://jvcl.svn.sourceforge.net/svnroot/jvcl/tags/JVCL3_32/run/JvgImage.pas $';
Revision: '$Revision: 10612 $';
Date: '$Date: 2006-05-19 21:04:09 +0200 (ven., 19 mai 2006) $';
LogPath: 'JVCL\run'
);
{$ENDIF UNITVERSIONING}
{$ENDIF USEJVCL}
implementation
uses
Math;
constructor TJvgBitmapImage.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
Width := 105;
Height := 105;
FResBitmap := TBitmap.Create;
FImageAlign := TJvg2DAlign.Create;
FImageAlign.OnChanged := SmthChanged;
FChanged := True;
// FOldClientRect := Rect(left, top, left + Width, top + Height);
//...defaults
FAutoSize := False;
FBitmapOption := fwoNone;
FDrawState := fdsDefault;
FTransparent := False;
FTransparentColor := clOlive;
FMasked := False;
FMaskedColor := clOlive;
FMaskedToColor := clBtnFace;
FDisabledMaskColor := clBlack;
FAutoTransparentColor := ftcLeftBottomPixel;
FFastDraw := False;
OnChangeParams := nil;
end;
destructor TJvgBitmapImage.Destroy;
begin
FResBitmap.Free;
FBitmap.Free;
FImageAlign.Free;
inherited Destroy;
end;
procedure TJvgBitmapImage.Loaded;
begin
inherited Loaded;
if Assigned(FBitmap) and not FBitmap.Empty then
FBmp := FBitmap;
SetAutoTransparentColor(FAutoTransparentColor);
end;
procedure TJvgBitmapImage.Notification(AComponent: TComponent; Operation: TOperation);
begin
inherited Notification(AComponent, Operation);
if (AComponent = Image) and (Operation = opRemove) then
Image := nil;
end;
procedure TJvgBitmapImage.Paint;
var
//R, IntersectR: TRect;
Pt: TPoint;
begin
if Assigned(Bitmap) then
FBmp := Bitmap;
if Assigned(Image) then
FBmp := Image.Picture.Bitmap;
if Assigned(FBmp) and (FBmp.Handle <> 0) then
begin
if (FOldWidth <> Width) or (FOldHeight <> Height) then
begin
FChanged := True;
{if (OldLeft=Left)and(OldTop=Top) then
begin
R:=Rect( left, top, left+Width, top+Height );
IntersectRect( IntersectR, FOldClientRect, R );
InvalidateRect( Parent.Handle, @R, False );
ValidateRect( Parent.Handle, @IntersectR );
FOldClientRect := R;
end;}
end;
//OldLeft := Left; OldTop := Top;
FOldWidth := Width;
FOldHeight := Height;
if FChanged or not FFastDraw then
begin
CreateResBitmap;
FChanged := False;
end;
Pt := CalcAlignOffset;
BitBlt(Canvas.Handle, Pt.X, Pt.Y, FResBitmap.Width, FResBitmap.Height,
FResBitmap.Canvas.Handle, 0, 0, SRCCOPY);
end;
if (csDesigning in ComponentState) and (Tag <> 9999) then
with Canvas do
begin
Pen.Color := clBlack;
Pen.Style := psDash;
Brush.Style := bsClear;
Rectangle(0, 0, Width, Height);
end;
end;
procedure TJvgBitmapImage.RemakeBackground;
begin
FChanged := True;
Repaint;
end;
//procedure TJvgBitmapImage.WMSize(var Message: TWMSize);
//var R,IntersectR: TRect;
//begin
{ Exit;
if FAutoSize then
begin Width:=FResBitmap.Width; Height:=FResBitmap.Height; end;
if not FTransparent then
begin
R:=Rect( left, top, left+Width, top+Height );
IntersectRect( IntersectR, FOldClientRect, R );
InvalidateRect( Parent.Handle, @R, False );
ValidateRect( Parent.Handle, @IntersectR );
FOldClientRect := R;
end
else
Invalidate;
Changed;}
//end;
procedure TJvgBitmapImage.CreateResBitmap;
var
Pt: TPoint;
// BmpInfo: Windows.TBitmap;
begin
if (FBitmapOption = fwoStretch) or (FBitmapOption = fwoPropStretch) or
(FBitmapOption = fwoTile) then
begin
FResBitmap.Width := Width;
FResBitmap.Height := Height;
end
else
begin
FResBitmap.Width := FBmp.Width;
FResBitmap.Height := FBmp.Height;
end;
with FResBitmap do
begin
// if FTransparent then Canvas.Brush.Color := FTransparentColor
Canvas.Brush.Color := clBtnFace;
Canvas.Brush.Style := bsSolid;
Canvas.FillRect(Bounds(0, 0, Width, Height));
end;
Pt := CalcAlignOffset;
if FTransparent then
GetParentImageRect(Self, Bounds(Left + Pt.X, Top + Pt.Y, FResBitmap.Width,
FResBitmap.Height),
FResBitmap.Canvas.Handle);
//BringParentWindowToTop(parent);
// BitBlt( FResBitmap.Canvas.Handle, 0,0, Width, Height, Canvas.Handle, 0, 0, SRCCOPY);
CreateBitmapExt(FResBitmap.Canvas.Handle, FBmp, ClientRect, 0, 0,
FBitmapOption, FDrawState,
FTransparent, FTransparentColor, FDisabledMaskColor);
if FMasked then
ChangeBitmapColor(FResBitmap, FMaskedColor, FMaskedToColor);
{ GetObject( FResBitmap.Handle, SizeOf(Windows.TBitmap), @BmpInfo );
if BmpInfo.bmBitsPixel >= 8 then
with FResBitmap,BmpInfo do
begin
for i := 1 to bmWidth*bmHeight*(bmBitsPixel div 8)-1 do
begin
asm
inc BmpInfo.bmBits
end;
Byte(bmBits^):=1;
end;
end;}
end;
procedure TJvgBitmapImage.Changed;
begin
FChanged := True;
if Assigned(OnChangeParams) then
OnChangeParams(Self);
end;
procedure TJvgBitmapImage.SmthChanged(Sender: TObject);
begin
Changed;
Invalidate;
end;
function TJvgBitmapImage.CalcAlignOffset: TPoint;
var
D, D1: Double;
Pt: TPoint;
begin
Result.X := 0;
Result.Y := 0;
if (FBitmapOption = fwoNone) or (FBitmapOption = fwoPropStretch) then
begin
Pt.X := FBmp.Width;
Pt.Y := FBmp.Height;
if FBitmapOption = fwoPropStretch then
begin
D1 := Width / Pt.X;
D := Height / Pt.Y;
if D > D1 then
D := D1; //...D == Min
Pt.X := Trunc(Pt.X * D);
Pt.Y := Trunc(Pt.Y * D);
end;
case ImageAlign.Horizontal of
fhaCenter:
Result.X := Max(0, (Width - Pt.X) div 2);
fhaRight:
Result.X := Max(0, Width - Pt.X);
end;
case ImageAlign.Vertical of
fvaCenter:
Result.Y := Max(0, (Height - Pt.Y) div 2);
fvaBottom:
Result.Y := Max(0, Height - Pt.Y);
end;
end;
end;
procedure TJvgBitmapImage.SetAutoSize(Value: Boolean);
begin
if (FAutoSize = Value) or not Assigned(FBmp) then
Exit;
FAutoSize := Value;
if FAutoSize and (FBitmapOption = fwoNone) and
// (rom) strange this evaluates to FBmp.Width <> FBmp.Height
((FBmp.Width and FBmp.Height) <> 0) then
begin
Width := FBmp.Width;
Height := FBmp.Height;
Changed;
Invalidate;
end;
end;
function TJvgBitmapImage.GetBitmap: TBitmap;
begin
if not Assigned(FBitmap) then
FBitmap := TBitmap.Create;
Result := FBitmap;
end;
procedure TJvgBitmapImage.SetBitmap(Value: TBitmap);
begin
FBitmap.Free;
FBitmap := TBitmap.Create;
FBitmap.Assign(Value);
if Assigned(Value) then
FBmp := FBitmap
else
if Assigned(FImage) and Assigned(FImage.Picture) and
Assigned(FImage.Picture.Bitmap) then
FBmp := FImage.Picture.Bitmap
else
FBmp := nil;
SetAutoTransparentColor(FAutoTransparentColor);
Changed;
Invalidate;
end;
procedure TJvgBitmapImage.SetImage(Value: TImage);
begin
FImage := Value;
if Assigned(FImage) and Assigned(FImage.Picture) and
Assigned(FImage.Picture.Bitmap) then
FBmp := FImage.Picture.Bitmap
else
if Assigned(FBitmap) then
FBmp := FBitmap
else
FBmp := nil;
SetAutoTransparentColor(FAutoTransparentColor);
Changed;
Invalidate;
end;
procedure TJvgBitmapImage.SetBitmapOption(Value: TglWallpaperOption);
begin
if FBitmapOption <> Value then
begin
FBitmapOption := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetDrawState(Value: TglDrawState);
begin
if FDrawState <> Value then
begin
FDrawState := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetTransparent(Value: Boolean);
begin
if FTransparent <> Value then
begin
FTransparent := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetTransparentColor(Value: TColor);
begin
if (FAutoTransparentColor <> ftcUser) or (FTransparentColor = Value) then
Exit;
FTransparentColor := Value;
Changed;
Invalidate;
end;
procedure TJvgBitmapImage.SetMasked(Value: Boolean);
begin
if FMasked <> Value then
begin
FMasked := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetMaskedColor(Value: TColor);
begin
if FMaskedColor <> Value then
begin
FMaskedColor := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetMaskedToColor(Value: TColor);
begin
if FMaskedToColor <> Value then
begin
FMaskedToColor := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetDisabledMaskColor(Value: TColor);
begin
if FDisabledMaskColor <> Value then
begin
FDisabledMaskColor := Value;
Changed;
Invalidate;
end;
end;
procedure TJvgBitmapImage.SetAutoTransparentColor(Value: TglAutoTransparentColor);
begin
FAutoTransparentColor := Value;
if not Assigned(FBmp) then
Exit;
if Value <> ftcUser then
FTransparentColor := GetTransparentColor(FBmp, Value);
Changed;
Invalidate;
end;
procedure TJvgBitmapImage.SetFastDraw(Value: Boolean);
begin
if FFastDraw <> Value then
begin
FFastDraw := Value;
Changed;
Invalidate;
end;
end;
{procedure TJvgBitmapImage.SetWidth(Value: Integer);
begin
if FWidth = Value then Exit;
FWidth := Value; Invalidate;
end;
procedure TJvgBitmapImage.SetHeight(Value: Integer);
begin
if FHeight = Value then Exit;
FHeight := Value; Invalidate;
end;}
{$IFDEF USEJVCL}
{$IFDEF UNITVERSIONING}
initialization
RegisterUnitVersion(HInstance, UnitVersioning);
finalization
UnregisterUnitVersion(HInstance);
{$ENDIF UNITVERSIONING}
{$ENDIF USEJVCL}
end.