📄 jvqimagelist.pas
字号:
{******************************************************************************}
{* WARNING: JEDI VCL To CLX Converter generated unit. *}
{* Manual modifications will be lost on next release. *}
{******************************************************************************}
{-----------------------------------------------------------------------------
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: JvImageList.pas, released on 2003-10-09
The Initial Developers of the Original Code are: Andreas Hausladen <Andreas dott Hausladen att gmx dott de>
Copyright (c) 2003 Andreas Hausladen
All Rights Reserved.
Portions created by Uwe Schuster are Copyright (C) 2003, 2004 Uwe Schuster.
Contributor(s):
Uwe Schuster [jedivcs att bitcommander dott de]
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:
ImageKind ikMappedResourceBitmap is not support so far
-----------------------------------------------------------------------------}
// $Id: JvQImageList.pas,v 1.23 2004/11/06 22:08:18 asnepvangers Exp $
unit JvQImageList;
{$I jvcl.inc}
interface
uses
QWindows,
{$IFDEF MSWINDOWS}
CommCtrl,
{$ENDIF MSWINDOWS}
SysUtils, Classes, QGraphics, QControls, QImgList;
type
TJvImageListMode = (imClassic, imPicture, imResourceIds, imItemList);
TJvImageListTransparentMode = (tmNone, tmAuto, tmColor);
EJvImageListError = class(Exception);
TJvImageListItemKind = (ikResourceBitmap, ikMappedResourceBitmap, ikInlineBitmap);
TJvImageListItem = class(TCollectionItem)
private
FBitmap: TBitmap;
FKind: TJvImageListItemKind;
FResourceName: string;
FTransparentColor: TColor;
procedure AddToImageList(AImageList: TImageList);
procedure BitmapChanged(Sender: TObject);
function GetImageList: TImageList;
procedure SetBitmap(ABitmap: TBitmap);
procedure SetKind(AKind: TJvImageListItemKind);
procedure SetResourceName(const AResourceName: string);
procedure SetTransparentColor(AColor: TColor);
procedure UpdateImageListItem(AImageList: TImageList; AIndex: Integer);
protected
function GetDisplayName: string; override;
procedure SetIndex(Value: Integer); override;
public
constructor Create(Collection: TCollection); override;
destructor Destroy; override;
procedure UpdateImageList;
published
property Kind: TJvImageListItemKind read FKind write SetKind;
property TransparentColor: TColor read FTransparentColor write
SetTransparentColor;
property Bitmap: TBitmap read FBitmap write SetBitmap;
property ResourceName: string read FResourceName write SetResourceName;
end;
TJvImageListItems = class(TOwnedCollection)
private
function GetItem(AIndex: Integer): TJvImageListItem;
procedure SetItem(AIndex: Integer; Value: TJvImageListItem);
protected
procedure Update(Item: TCollectionItem); override;
public
constructor Create(AOwner: TComponent);
function Add: TJvImageListItem;
property Items[AIndex: Integer]: TJvImageListItem read GetItem write SetItem; default;
end;
TJvImageList = class(TImageList)
private
FUpdateLock: Integer;
FModified: Boolean;
FItems: TJvImageListItems;
FTransparentMode: TJvImageListTransparentMode;
FTransparentColor: TColor;
FPicture: TPicture;
FFileName: TFileName;
FResourceIds: TStrings;
FMode: TJvImageListMode;
procedure SetFileName(const Value: TFileName);
procedure SetItems(AItems: TJvImageListItems);
procedure SetPicture(Value: TPicture);
procedure SetTransparentMode(Value: TJvImageListTransparentMode);
procedure SetTransparentColor(Value: TColor);
procedure SetResourceIds(Value: TStrings);
procedure SetMode(const Value: TJvImageListMode);
procedure SlicePictureToImageList;
procedure ResourceIdsToImageList;
procedure DoLoadFromFile;
protected
procedure ItemListError;
procedure DefineProperties(Filer: TFiler); override;
procedure InitializeImageList; virtual; // called by Initialize (VCL and VCLX)
procedure Initialize(const AWidth, AHeight: Integer); override;
procedure Change; override;
procedure DataChanged(Sender: TObject); virtual;
procedure UpdateImageList;
public
destructor Destroy; override;
procedure Assign(Source: TPersistent); override;
procedure BeginUpdate;
procedure EndUpdate;
procedure GetIcon(Index: Integer; Ico: TIcon);
procedure SaveToFile(const FileName: string);
procedure SaveToStream(Stream: TStream); virtual;
procedure LoadFromFile(const FileName: string);
procedure LoadFromStream(Stream: TStream); virtual;
{ imItemList }
// (usc) DeleteItem, ClearItem and GetItemInfoStr are obsolete because the are
// directly mapped to Items
procedure AddItem(ABitmap: TBitmap; ATransparentColor: TColor); overload;
// AddItem adds a bitmap to the ItemList with ATransparentColor as
// transparent color. If the image list mode is not imItemList the image
// list is cleared and the mode is set to imItemList.
procedure AddItem(const AResourceName: string; ATransparentColor: TColor); overload;
// AddItem adds the resource AResourceName from the HInstance libarary to
// the ItemList with ATransparentColor as transparent color. If the image
// list mode is not imItemList the image list is cleared and the mode is
// set to imItemList.
procedure DeleteItem(AIndex: Integer);
// DeleteItem deletes the ItemList item that is identified by AIndex.
// When the ImageList is not in imItenList mode the method raises an
// RJvImageListError.
procedure ClearItems;
// ClearItems clears the ItemList. When the ImageList is not in imItemList
// mode the method raises an RJvImageListError.
function GetItemInfoStr(AIndex: Integer): string;
// GetItemInfoStr returns the info string of the ItemList item that is
// identified by AIndex. When the ImageList is not in imItenList mode the
// method raises an RJvImageListError.
published
property Mode: TJvImageListMode read FMode write SetMode default imPicture;
// Mode specifies which property the component should use.
// imClassic: be a normal TImageList
// imPicture: split the image in Picture
// imResourceIds: load the images by ResourceIds
// imItemList: the AddItem, DeleteItem, ClearItems and GetItemInfoStr methods are available
property TransparentMode: TJvImageListTransparentMode read FTransparentMode write SetTransparentMode default
tmColor;
// TransparentMode is used for adding the bitmaps from Picture or
// ResourceIds.
// tmNone: no mask
// tmAuto: use the pixel at the left bottom edge
// tmColor: use TransparentColor
property TransparentColor: TColor read FTransparentColor write SetTransparentColor default clFuchsia;
// TransparentColor specifies the color that is used as the MaskColor
// when spitting the graphic in Picture.Graphic or adding the Resource
// bitmaps to the image list.
property FileName: TFileName read FFileName write SetFileName;
// (only for designtime)
// FileName specifies a graphic file that is available on the developer's
// system which contains the bitmaps which can be exported by the
// ImageList. The Data is copied to Picture.Graphic. If the file does not
// exists at design time the stored Picture.Graphic is used.
property Picture: TPicture read FPicture write SetPicture;
// Picture.Graphic is updated at design time by the graphic file specified
// by FileName. The Picture property is only loaded into the image list if
// the Mode is imPicture.
property ResourceIds: TStrings read FResourceIds write SetResourceIds;
// ResourceIds contains the resource ids of the bitmaps to load. Allowed
// are RCDATA (a bitmap file) and BITMAP. ResourceIds property is only
// loaded into the image list if Mode is imResourceIds.
property Items: TJvImageListItems read FItems write SetItems;
end;
function LoadImageListFromBitmap(ImgList: TCustomImageList; const Bitmap: TBitmap;
MaskColor: TColor = clFuchsia; AutoMaskColor: Boolean = False): Integer; overload;
function LoadImageListFromBitmap(ImgList: TCustomImageList; const Bitmap: TBitmap;
MaskBitmap: TBitmap): Integer; overload;
implementation
uses
{$IFDEF UNITVERSIONING}
JclUnitVersioning,
{$ENDIF UNITVERSIONING}
QConsts, TypInfo,
JvQJVCLUtils, JvQResources;
resourcestring
// (usc) there is no real need to move this string to JvResource.pas because
// hopefully ikMappedResourceBitmap will be supported soon
RsENotSupportedItemKind = 'The item kind %s is not supported so far.';
{$IFDEF UNIX}
const
RT_RCDATA = PChar(10);
{$ENDIF UNIX}
//=== { TJvImageListItem } ===================================================
constructor TJvImageListItem.Create(Collection: TCollection);
begin
inherited Create(Collection);
FBitmap := TBitmap.Create;
FBitmap.OnChange := BitmapChanged;
FKind := ikResourceBitmap;
FResourceName := '';
FTransparentColor := clFuchsia;
if GetImageList <> nil then
AddToImageList(GetImageList);
end;
destructor TJvImageListItem.Destroy;
var
ImageList: TImageList;
begin
ImageList := GetImageList;
if Assigned(ImageList) and (Index >= 0) and (ImageList.Count > Index) then
ImageList.Delete(Index);
FBitmap.Free;
inherited Destroy;
end;
procedure TJvImageListItem.AddToImageList(AImageList: TImageList);
var
Bitmap: TBitmap;
begin
Bitmap := TBitmap.Create;
try
Bitmap.Width := AImageList.Width;
Bitmap.Height := AImageList.Height;
AImageList.AddMasked(Bitmap, FTransparentColor);
finally
Bitmap.Free;
end;
UpdateImageListItem(AImageList, Pred(AImageList.Count));
end;
procedure TJvImageListItem.BitmapChanged(Sender: TObject);
begin
UpdateImageList;
end;
function TJvImageListItem.GetDisplayName: string;
begin
case FKind of
ikResourceBitmap:
Result := Format(RsResource, [FResourceName]);
ikMappedResourceBitmap:
Result := Format(RsMappedResource, [FResourceName]);
ikInlineBitmap:
Result := Format(RsBitmap,
[GetEnumName(TypeInfo(TPixelFormat), Ord(FBitmap.PixelFormat))]);
else
inherited GetDisplayName;
end;
end;
function TJvImageListItem.GetImageList: TImageList;
begin
Result := TImageList(TJvImageListItems(Collection).Owner);
end;
procedure TJvImageListItem.SetBitmap(ABitmap: TBitmap);
begin
if FKind = ikInlineBitmap then
begin
FBitmap.Assign(ABitmap);
UpdateImageList;
end;
end;
procedure TJvImageListItem.SetIndex(Value: Integer);
var
ImageList: TImageList;
OldIndex: Integer;
begin
OldIndex := Index;
inherited SetIndex(Value);
ImageList := GetImageList;
if Assigned(ImageList) and (OldIndex >= 0) and (ImageList.Count > OldIndex) and
(Index >= 0) and (ImageList.Count > Index) then
ImageList.Move(OldIndex, Index);
end;
procedure TJvImageListItem.SetKind(AKind: TJvImageListItemKind);
begin
// (usc) remove when MappedResourceBitmap support is finished
if AKind = ikMappedResourceBitmap then
raise EJvImageListError.CreateResFmt(@RsENotSupportedItemKind, ['ikMappedResourceBitmap']);
if FKind <> AKind then
begin
FKind := AKind;
if FKind in [ikResourceBitmap, ikMappedResourceBitmap] then
FBitmap.Assign(nil)
else
if FKind = ikInlineBitmap then
FResourceName := '';
end;
end;
procedure TJvImageListItem.SetResourceName(const AResourceName: string);
begin
if (FKind in [ikResourceBitmap, ikMappedResourceBitmap]) and
(FResourceName <> AResourceName) then
begin
FResourceName := AResourceName;
UpdateImageList;
end;
end;
procedure TJvImageListItem.SetTransparentColor(AColor: TColor);
begin
if FTransparentColor <> AColor then
begin
FTransparentColor := AColor;
UpdateImageList;
end;
end;
procedure TJvImageListItem.UpdateImageList;
begin
UpdateImageListItem(GetImageList, Index);
end;
procedure TJvImageListItem.UpdateImageListItem(AImageList: TImageList; AIndex: Integer);
var
Bitmap: TBitmap;
begin
if (FKind in [ikResourceBitmap, ikMappedResourceBitmap]) and (FResourceName <> '') then
begin
Bitmap := TBitmap.Create;
try
try
if FKind = ikResourceBitmap then
Bitmap.LoadFromResourceName(HInstance, FResourceName);
{// (usc) include when MappedResourceBitmap support is finished
else
if FKind = ikMappedResourceBitmap then
GetMappedResourceBitmap(FResourceName, Bitmap);
}
AImageList.ReplaceMasked(AIndex, Bitmap, FTransparentColor);
except
end;
finally
Bitmap.Free;
end;
end
else
if (FKind = ikInlineBitmap) and Assigned(FBitmap) and
(FBitmap.Width = AImageList.Width) and (FBitmap.Height = AImageList.Height) then
AImageList.ReplaceMasked(AIndex, FBitmap, FTransparentColor);
end;
//=== { TJvImageListItems } ==================================================
constructor TJvImageListItems.Create(AOwner: TComponent);
begin
inherited Create(AOwner, TJvImageListItem);
end;
function TJvImageListItems.Add: TJvImageListItem;
begin
Result := TJvImageListItem(inherited Add);
end;
function TJvImageListItems.GetItem(AIndex: Integer): TJvImageListItem;
begin
Result := TJvImageListItem(inherited GetItem(AIndex));
end;
procedure TJvImageListItems.SetItem(AIndex: Integer; Value: TJvImageListItem);
begin
inherited SetItem(AIndex, Value);
end;
procedure TJvImageListItems.Update(Item: TCollectionItem);
begin
if Assigned(Item) then
TJvImageListItem(Item).UpdateImageList;
end;
{ Loads the bitmaps for the ImageList from the bitmap Bitmap.
The return value is the number of added bitmaps. }
function LoadImageListFromBitmap(ImgList: TCustomImageList; const Bitmap: TBitmap;
MaskColor: TColor = clFuchsia; AutoMaskColor: Boolean = False): Integer; overload;
var
Bmp: TBitmap;
Width, Height: Integer;
i: Integer;
TempImageList: TCustomImageList;
begin
Result := 0;
if (ImgList = nil) or (ImgList.Width = 0) or (ImgList.Height = 0) or
(Bitmap = nil) then
Exit;
Width := ImgList.Width;
Height := ImgList.Height;
Result := Bitmap.Width div Width; // count
if (Result = 0) and (Bitmap.Width > 0) then
Result := 1;
TempImageList := TCustomImageList.CreateSize(Width, Height);
Bmp := TBitmap.Create;
try
Bmp.PixelFormat := Bitmap.PixelFormat;
// split Bitmap and add all bitmaps to ImgList
for i := 0 to Result - 1 do
begin
if AutoMaskColor then
MaskColor := Bitmap.Canvas.Pixels[i * Width, Height - 1];
Bmp.Canvas.Brush.Color := MaskColor;
Bmp.Width := 0; // clear bitmap
Bmp.Width := Width;
Bmp.Height := Height;
Bmp.Canvas.CopyRect(Rect(0, 0, Width, Height),
Bitmap.Canvas, Rect(i * Width, 0, (i + 1) * Width, Height));
TempImageList.AddMasked(Bmp, MaskColor);
end;
ImgList.AddImages(TempImageList);
finally
Bmp.Free;
TempImageList.Free;
end;
end;
function LoadImageListFromBitmap(ImgList: TCustomImageList; const Bitmap: TBitmap;
MaskBitmap: TBitmap): Integer; overload;
var
Bmp, MaskBmp: TBitmap;
Width, Height: Integer;
i: Integer;
TempImageList: TCustomImageList;
begin
Result := 0;
if (ImgList = nil) or (ImgList.Width = 0) or (ImgList.Height = 0) or
(Bitmap = nil) or (MaskBitmap = nil) then
Exit;
Width := ImgList.Width;
Height := ImgList.Height;
Result := Bitmap.Width div Width; // calc count
if (Result = 0) and (Bitmap.Width > 0) then
Result := 1;
TempImageList := TCustomImageList.CreateSize(Width, Height);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -