Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

2428 lines
72 KiB

###############################################################################
#
# Win32::GUI - Perl-Win32 Graphical User Interface Extension
#
# 29 Jan 1997 by Aldo Calpini <[email protected]>
#
# Version: 0.0.425 (08 Oct 1999)
#
# Copyright (c) 1997,8,9 Aldo Calpini. All rights reserved.
# This program is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself.
#
###############################################################################
package Win32::GUI;
require Exporter; # to export the constants to the main:: space
require DynaLoader; # to dynuhlode the module.
# Reserves GUI in the main namespace for us (uhmmm...)
*GUI:: = \%Win32::GUI::;
###############################################################################
# STATIC OBJECT PROPERTIES
#
$VERSION = "0.0.425";
$MenuIdCounter = 1;
$TimerIdCounter = 1;
$NotifyIconIdCounter = 1;
@ISA = qw( Exporter DynaLoader );
@EXPORT = qw(
BS_3STATE
BS_AUTO3STATE
BS_AUTOCHECKBOX
BS_AUTORADIOBUTTON
BS_CHECKBOX
BS_DEFPUSHBUTTON
BS_GROUPBOX
BS_LEFTTEXT
BS_NOTIFY
BS_OWNERDRAW
BS_PUSHBUTTON
BS_RADIOBUTTON
BS_USERBUTTON
BS_BITMAP
BS_BOTTOM
BS_CENTER
BS_ICON
BS_LEFT
BS_MULTILINE
BS_RIGHT
BS_RIGHTBUTTON
BS_TEXT
BS_TOP
BS_VCENTER
COLOR_3DFACE
COLOR_ACTIVEBORDER
COLOR_ACTIVECAPTION
COLOR_APPWORKSPACE
COLOR_BACKGROUND
COLOR_BTNFACE
COLOR_BTNSHADOW
COLOR_BTNTEXT
COLOR_CAPTIONTEXT
COLOR_GRAYTEXT
COLOR_HIGHLIGHT
COLOR_HIGHLIGHTTEXT
COLOR_INACTIVEBORDER
COLOR_INACTIVECAPTION
COLOR_MENU
COLOR_MENUTEXT
COLOR_SCROLLBAR
COLOR_WINDOW
COLOR_WINDOWFRAME
COLOR_WINDOWTEXT
DS_3DLOOK
DS_ABSALIGN
DS_CENTER
DS_CENTERMOUSE
DS_CONTEXTHELP
DS_CONTROL
DS_FIXEDSYS
DS_LOCALEDIT
DS_MODALFRAME
DS_NOFAILCREATE
DS_NOIDLEMSG
DS_RECURSE
DS_SETFONT
DS_SETFOREGROUND
DS_SYSMODAL
ES_AUTOHSCROLL
ES_AUTOVSCROLL
ES_CENTER
ES_LEFT
ES_LOWERCASE
ES_MULTILINE
ES_NOHIDESEL
ES_NUMBER
ES_OEMCONVERT
ES_PASSWORD
ES_READONLY
ES_RIGHT
ES_UPPERCASE
ES_WANTRETURN
GW_CHILD
GW_HWNDFIRST
GW_HWNDLAST
GW_HWNDNEXT
GW_HWNDPREV
GW_OWNER
IMAGE_BITMAP
IMAGE_CURSOR
IMAGE_ICON
LR_DEFAULTCOLOR
LR_MONOCHROME
LR_COLOR
LR_COPYRETURNORG
LR_COPYDELETEORG
LR_LOADFROMFILE
LR_LOADTRANSPARENT
LR_DEFAULTSIZE
LR_LOADMAP3DCOLORS
LR_CREATEDIBSECTION
LR_COPYFROMRESOURCE
LR_SHARED
MB_ABORTRETRYIGNORE
MB_OK
MB_OKCANCEL
MB_RETRYCANCEL
MB_YESNO
MB_YESNOCANCEL
MB_ICONEXCLAMATION
MB_ICONWARNING
MB_ICONINFORMATION
MB_ICONASTERISK
MB_ICONQUESTION
MB_ICONSTOP
MB_ICONERROR
MB_ICONHAND
MB_DEFBUTTON1
MB_DEFBUTTON2
MB_DEFBUTTON3
MB_DEFBUTTON4
MB_APPLMODAL
MB_SYSTEMMODAL
MB_TASKMODAL
MB_DEFAULT_DESKTOP_ONLY
MB_HELP
MB_RIGHT
MB_RTLREADING
MB_SETFOREGROUND
MB_TOPMOST
MB_SERVICE_NOTIFICATION
MB_SERVICE_NOTIFICATION_NT3X
MF_STRING
MF_POPUP
SM_ARRANGE
SM_CLEANBOOT
SM_CMOUSEBUTTONS
SM_CXBORDER
SM_CYBORDER
SM_CXCURSOR
SM_CYCURSOR
SM_CXDLGFRAME
SM_CYDLGFRAME
SM_CXDOUBLECLK
SM_CYDOUBLECLK
SM_CXDRAG
SM_CYDRAG
SM_CXEDGE
SM_CYEDGE
SM_CXFIXEDFRAME
SM_CYFIXEDFRAME
SM_CXFRAME
SM_CYFRAME
SM_CXFULLSCREEN
SM_CYFULLSCREEN
SM_CXHSCROLL
SM_CYHSCROLL
SM_CXHTHUMB
SM_CXICON
SM_CYICON
SM_CXICONSPACING
SM_CYICONSPACING
SM_CXMAXIMIZED
SM_CYMAXIMIZED
SM_CXMAXTRACK
SM_CYMAXTRACK
SM_CXMENUCHECK
SM_CYMENUCHECK
SM_CXMENUSIZE
SM_CYMENUSIZE
SM_CXMIN
SM_CYMIN
SM_CXMINIMIZED
SM_CYMINIMIZED
SM_CXMINSPACING
SM_CYMINSPACING
SM_CXMINTRACK
SM_CYMINTRACK
SM_CXSCREEN
SM_CYSCREEN
SM_CXSIZE
SM_CYSIZE
SM_CXSIZEFRAME
SM_CYSIZEFRAME
SM_CXSMICON
SM_CYSMICON
SM_CXSMSIZE
SM_CYSMSIZE
SM_CXVSCROLL
SM_CYVSCROLL
SM_CYCAPTION
SM_CYKANJIWINDOW
SM_CYMENU
SM_CYSMCAPTION
SM_CYVTHUMB
SM_DBCSENABLED
SM_DEBUG
SM_MENUDROPALIGNMENT
SM_MIDEASTENABLED
SM_MOUSEPRESENT
SM_MOUSEWHEELPRESENT
SM_NETWORK
SM_PENWINDOWS
SM_SECURE
SM_SHOWSOUNDS
SM_SLOWMACHINE
SM_SWAPBUTTON
WM_CREATE
WM_DESTROY
WM_MOVE
WM_SIZE
WM_ACTIVATE
WM_SETFOCUS
WM_KILLFOCUS
WM_ENABLE
WM_SETREDRAW
WM_COMMAND
WM_KEYDOWN
WM_SETCURSOR
WM_KEYUP
WS_BORDER
WS_CAPTION
WS_CHILD
WS_CHILDWINDOW
WS_CLIPCHILDREN
WS_CLIPSIBLINGS
WS_DISABLED
WS_DLGFRAME
WS_GROUP
WS_HSCROLL
WS_ICONIC
WS_MAXIMIZE
WS_MAXIMIZEBOX
WS_MINIMIZE
WS_MINIMIZEBOX
WS_OVERLAPPED
WS_OVERLAPPEDWINDOW
WS_POPUP
WS_POPUPWINDOW
WS_SIZEBOX
WS_SYSMENU
WS_TABSTOP
WS_THICKFRAME
WS_TILED
WS_TILEDWINDOW
WS_VISIBLE
WS_VSCROLL
WS_EX_ACCEPTFILES
WS_EX_APPWINDOW
WS_EX_CLIENTEDGE
WS_EX_CONTEXTHELP
WS_EX_CONTROLPARENT
WS_EX_DLGMODALFRAME
WS_EX_LEFT
WS_EX_LEFTSCROLLBAR
WS_EX_LTRREADING
WS_EX_MDICHILD
WS_EX_NOPARENTNOTIFY
WS_EX_OVERLAPPEDWINDOW
WS_EX_PALETTEWINDOW
WS_EX_RIGHT
WS_EX_RIGHTSCROLLBAR
WS_EX_RTLREADING
WS_EX_STATICEDGE
WS_EX_TOOLWINDOW
WS_EX_TOPMOST
WS_EX_TRANSPARENT
WS_EX_WINDOWEDGE
);
###############################################################################
# This AUTOLOAD is used to 'autoload' constants from the constant()
# XS function. If a constant is not found then control is passed
# to the AUTOLOAD in AutoLoader.
#
sub AUTOLOAD {
my($constname);
($constname = $AUTOLOAD) =~ s/.*:://;
#reset $! to zero to reset any current errors.
$! = 0;
my $val = constant($constname, @_ ? $_[0] : 0);
if ($! != 0) {
if ($! =~ /Invalid/) {
$AutoLoader::AUTOLOAD = $AUTOLOAD;
goto &AutoLoader::AUTOLOAD;
} else {
my($pack,$file,$line) = caller; # undef $pack;
die "Can't find '$constname' in package '$pack' ".
"used at $file line $line.";
}
}
eval "sub $AUTOLOAD { $val }";
goto &$AUTOLOAD;
}
###############################################################################
# PUBLIC METHODS
# (@)PACKAGE:Win32::GUI
###########################################################################
# (@)METHOD:Version()
# Returns the module version number.
sub Version {
return $VERSION;
}
###########################################################################
# (@)METHOD:SetFont(FONT)
# Sets the font of the window (FONT is a Win32::GUI::Font object).
sub SetFont {
my($self, $font) = @_;
$font = $font->{-handle} if ref($font);
# 48 == WM_SETFONT
return Win32::GUI::SendMessage($self, 48, $font, 0);
}
###########################################################################
# (@)METHOD:GetFont(FONT)
# Gets the font of the window (returns an handle; use
# $Font = $W->GetFont();
# %details = Win32::GUI::Font::Info( $Font );
# to get font details).
sub GetFont {
my($self) = shift;
# 49 == WM_GETFONT
return Win32::GUI::SendMessage($self, 49, 0, 0);
}
###########################################################################
# (@)METHOD:SetIcon(ICON, [TYPE])
# Sets the icon of the window; TYPE can be 0 for the small icon, 1 for
# the big icon. Default is the same icon for small and big.
sub SetIcon {
my($self, $icon, $type) = @_;
$icon = $icon->{-handle} if ref($icon);
# 128 == WM_SETICON
if(defined($type)) {
return Win32::GUI::SendMessage($self, 128, $type, $icon);
} else {
Win32::GUI::SendMessage($self, 128, 0, $icon); # small icon
Win32::GUI::SendMessage($self, 128, 1, $icon); # big icon
}
}
###########################################################################
# (@)METHOD:SetRedraw(FLAG)
# Determines if a window is automatically redrawn when its content changes.
# FLAG can be a true value to allow redraw, false to prevent it.
sub SetRedraw {
my($self, $value) = @_;
# 11 == WM_SETREDRAW
my $r = Win32::GUI::SendMessage($self, 11, $value, 0);
return $r;
}
###########################################################################
# (@)INTERNAL:MakeMenu(...)
# better used as new Win32::GUI::Menu(...)
sub MakeMenu {
my(@menudata) = @_;
my $i;
my $M = new Win32::GUI::Menu();
my $text;
my %data;
my $level;
my %last;
my $parent;
for($i = 0; $i <= $#menudata; $i+=2) {
$text = $menudata[$i];
undef %data;
if(ref($menudata[$i+1])) {
%data = %{$menudata[$i+1]};
} else {
$data{-name} = $menudata[$i+1];
}
$level = 0;
$level++ while($text =~ s/^\s*>\s*//);
if($level == 0) {
$M->{$data{-name}} = $M->AddMenuButton(
-id => $MenuIdCounter++,
-text => $text,
%data,
);
$last{$level} = $data{-name};
$last{$level+1} = "";
} elsif($level == 1) {
$parent = $last{$level-1};
if($text eq "-") {
$data{-name} = "dummy$MenuIdCounter";
$M->{$data{-name}} = $M->{$parent}->AddMenuItem(
-item => 0,
-id => $MenuIdCounter++,
-separator => 1,
);
} else {
$M->{$data{-name}} = $M->{$parent}->AddMenuItem(
-item => 0,
-id => $MenuIdCounter++,
-text => $text,
%data,
);
}
$last{$level} = $data{-name};
$last{$level+1} = "";
} else {
$parent = $last{$level-1};
if(!$M->{$parent."_Submenu"}) {
$M->{$parent."_Submenu"} = new Win32::GUI::Menu();
$M->{$parent."_SubmenuButton"} =
$M->{$parent."_Submenu"}->AddMenuButton(
-id => $MenuIdCounter++,
-text => $parent,
-name => $parent."_SubmenuButton",
);
$M->{$parent}->SetMenuItemInfo(
-submenu => $M->{$parent."_SubmenuButton"}
);
}
if($text eq "-") {
$data{-name} = "dummy$MenuIdCounter";
$M->{$data{-name}} =
$M->{$parent."_SubmenuButton"}->AddMenuItem(
-item => 0,
-id => $MenuIdCounter++,
-separator => 1,
);
} else {
$M->{$data{-name}} =
$M->{$parent."_SubmenuButton"}->AddMenuItem(
-item => 0,
-id => $MenuIdCounter++,
-text => $text,
%data,
);
}
$last{$level} = $data{-name};
$last{$level+1} = "";
}
}
return $M;
}
###########################################################################
# (@)INTERNAL:_new(TYPE, %OPTIONS)
# This is the generalized constructor;
# it works pretty well for almost all controls.
# However, other kind of objects may overload it.
sub _new {
# this is always Win32::GUI (class of _new);
my $xclass = shift;
# the window type passed by new():
my $type = shift;
# this is the real class:
my $class = shift;
my $oself = {};
# bless($oself, $class);
my %tier = ();
tie %tier, $class, $oself;
my $self = bless \%tier, $class;
my (@input) = @_;
my $handle = Win32::GUI::Create($self, $type, @input);
# print "[_new] self='$self' oself='$oself'\n";
# print "[_new] handle = $handle\n";
# $self->{-handle} = $handle;
# print "[_new] enumerating self.keys\n";
# foreach my $k (keys %$self) {
# print "[_new] '$k' = '$self->{$k}'\n";
# }
if($handle) {
# $Win32::GUI::Windows{$handle} = $self;
if(exists($self->{-background})) {
# this is a little tricky; we must create a brush (and save
# a reference to it in the window, so that it's not destroyed)
# that will be used by the WM_CTLCOLOR message in GUI.xs to
# paint the window background
#
# print "PM(_new): Window has a background!\n";
$self->{-backgroundbrush} = new Win32::GUI::Brush($self->{-background});
# print "PM(_new): -backgroundbrush = $self->{-backgroundbrush}->{-handle}\n";
$self->{-background} = $self->{-backgroundbrush}->{-handle};
}
return $self;
} else {
return undef;
}
}
###############################################################################
# SUB-PACKAGES
#
###############################################################################
# (@)PACKAGE:Win32::GUI::Font
#
package Win32::GUI::Font;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Font(%OPTIONS)
# Creates a new Font object. %OPTIONS are:
# -size
# -height
# -width
# -escapement
# -orientation
# -weight
# -bold => 0/1
# -italic => 0/1
# -underline => 0/1
# -strikeout => 0/1
# -charset
# -outputprecision
# -clipprecision
# -family
# -quality
# -name
# -face
sub new {
my $class = shift;
my $self = {};
my $handle = Create(@_);
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Bitmap
#
package Win32::GUI::Bitmap;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Bitmap(FILENAME, [TYPE, X, Y, FLAGS])
# Creates a new Bitmap object reading from FILENAME; all other arguments
# are optional. TYPE can be:
# 0 bitmap (this is the default)
# 1 icon
# 2 cursor
# You can eventually specify your desired size for the image with X and
# Y and pass some FLAGS to the underlying LoadImage API (at your own risk)
sub new {
my $class = shift;
my $self = {};
my $handle = Win32::GUI::LoadImage(@_);
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Icon
#
package Win32::GUI::Icon;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Icon(FILENAME)
# Creates a new Icon object reading from FILENAME.
sub new {
my $class = shift;
my $file = shift;
my $self = {};
my $handle = Win32::GUI::LoadImage(
$file,
Win32::GUI::constant("IMAGE_ICON", 0),
);
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###########################################################################
# (@)INTERNAL:DESTROY()
sub DESTROY {
my $self = shift;
Win32::GUI::DestroyIcon($self);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Cursor
#
package Win32::GUI::Cursor;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Cursor(FILENAME)
# Creates a new Cursor object reading from FILENAME.
sub new {
my $class = shift;
my $file = shift;
my $self = {};
my $handle = Win32::GUI::LoadImage(
$file,
Win32::GUI::constant("IMAGE_CURSOR", 0),
);
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###########################################################################
# (@)INTERNAL:DESTROY()
sub DESTROY {
my $self = shift;
Win32::GUI::DestroyCursor($self);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Class
#
package Win32::GUI::Class;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD: new Win32::GUI::Class(%OPTIONS)
# Creates a new window class object.
# Allowed %OPTIONS are:
# -name => STRING
# the name for the class (it must be unique!).
# -icon => Win32::GUI::Icon object
# -cursor => Win32::GUI::Cursor object
# -color => COLOR or Win32::GUI::Brush object
# the window background color.
# -menu => STRING
# a menu name (not yet implemented).
# -extends => STRING
# name of the class to extend (aka subclassing).
# -widget => STRING
# name of a widget class to subclass; currently available are:
# Button, Listbox, TabStrip, RichEdit.
# -style => FLAGS
# use with caution!
sub new {
my $class = shift;
my %args = @_;
my $self = {};
$args{-color} =
Win32::GUI::constant("COLOR_WINDOW", 0)
unless exists($args{-color});
my $handle = Win32::GUI::RegisterClassEx(%args);
if($handle) {
$self->{-name} = $args{-name};
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Window
#
package Win32::GUI::Window;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Window(%OPTIONS)
# Creates a new Window object.
# Class specific %OPTIONS are:
# -minsize => [X, Y]
# specifies the minimum size (width and height) in pixels;
# X and Y must be passed in an array reference
# -maxsize => [X, Y]
# specifies the maximum size (width and height) in pixels;
# X and Y must be passed in an array reference
# -minwidth => N
# -minheight => N
# -maxwidht => N
# -maxheight => N
# specify the minimum and maximum size width
# and height, in pixels
# -topmost => 0/1 (default 0)
# the window "stays on top" even when deactivated
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__WINDOW", 0), @_);
}
###########################################################################
# (@)METHOD:AddButton(%OPTIONS)
# See new Win32::GUI::Button().
sub AddButton { return Win32::GUI::Button->new(@_); }
###########################################################################
# (@)METHOD:AddLabel(%OPTIONS)
# See new Win32::GUI::Label().
sub AddLabel { return Win32::GUI::Label->new(@_); }
###########################################################################
# (@)METHOD:AddCheckbox(%OPTIONS)
# See new Win32::GUI::Checkbox().
sub AddCheckbox { return Win32::GUI::Checkbox->new(@_); }
###########################################################################
# (@)METHOD:AddRadioButton(%OPTIONS)
# See new Win32::GUI::RadioButton().
sub AddRadioButton { return Win32::GUI::RadioButton->new(@_); }
###########################################################################
# (@)METHOD:AddTextfield(%OPTIONS)
# See new Win32::GUI::Textfield().
sub AddTextfield { return Win32::GUI::Textfield->new(@_); }
###########################################################################
# (@)METHOD:AddListbox(%OPTIONS)
# See new Win32::GUI::Listbox().
sub AddListbox { return Win32::GUI::Listbox->new(@_); }
###########################################################################
# (@)METHOD:AddCombobox(%OPTIONS)
# See new Win32::GUI::Combobox().
sub AddCombobox { return Win32::GUI::Combobox->new(@_); }
###########################################################################
# (@)METHOD:AddStatusBar(%OPTIONS)
# See new Win32::GUI::StatusBar().
sub AddStatusBar { return Win32::GUI::StatusBar->new(@_); }
###########################################################################
# (@)METHOD:AddProgressBar(%OPTIONS)
# See new Win32::GUI::ProgressBar().
sub AddProgressBar { return Win32::GUI::ProgressBar->new(@_); }
###########################################################################
# (@)METHOD:AddTabStrip(%OPTIONS)
# See new Win32::GUI::TabStrip().
sub AddTabStrip { return Win32::GUI::TabStrip->new(@_); }
###########################################################################
# (@)METHOD:AddToolbar(%OPTIONS)
# See new Win32::GUI::Toolbar().
sub AddToolbar { return Win32::GUI::Toolbar->new(@_); }
###########################################################################
# (@)METHOD:AddListView(%OPTIONS)
# See new Win32::GUI::ListView().
sub AddListView { return Win32::GUI::ListView->new(@_); }
###########################################################################
# (@)METHOD:AddTreeView(%OPTIONS)
# See new Win32::GUI::TreeView().
sub AddTreeView { return Win32::GUI::TreeView->new(@_); }
###########################################################################
# (@)METHOD:AddRichEdit(%OPTIONS)
# See new Win32::GUI::RichEdit().
sub AddRichEdit { return Win32::GUI::RichEdit->new(@_); }
###########################################################################
# (@)INTERNAL:AddTrackbar(%OPTIONS)
# Better used as AddSlider().
sub AddTrackbar { return Win32::GUI::Trackbar->new(@_); }
###########################################################################
# (@)METHOD:AddSlider(%OPTIONS)
# See new Win32::GUI::Slider().
sub AddSlider { return Win32::GUI::Slider->new(@_); }
###########################################################################
# (@)METHOD:AddUpDown(%OPTIONS)
# See new Win32::GUI::UpDown().
sub AddUpDown { return Win32::GUI::UpDown->new(@_); }
###########################################################################
# (@)METHOD:AddAnimation(%OPTIONS)
# See new Win32::GUI::Animation().
sub AddAnimation { return Win32::GUI::Animation->new(@_); }
###########################################################################
# (@)METHOD:AddRebar(%OPTIONS)
# See new Win32::GUI::Rebar().
sub AddRebar { return Win32::GUI::Rebar->new(@_); }
###########################################################################
# (@)METHOD:AddHeader(%OPTIONS)
# See new Win32::GUI::Header().
sub AddHeader { return Win32::GUI::Header->new(@_); }
###########################################################################
# (@)METHOD:AddCombobox(%OPTIONS)
# See new Win32::GUI::Combobox().
sub AddComboboxEx { return Win32::GUI::ComboboxEx->new(@_); }
###########################################################################
# (@)METHOD:AddTimer(NAME, ELAPSE)
# See new Win32::GUI::Timer().
sub AddTimer { return Win32::GUI::Timer->new(@_); }
###########################################################################
# (@)METHOD:AddNotifyIcon(%OPTIONS)
# See new Win32::GUI::NotifyIcon().
sub AddNotifyIcon { return Win32::GUI::NotifyIcon->new(@_); }
###########################################################################
# (@)METHOD:AddMenu()
# See new Win32::GUI::Menu().
sub AddMenu {
my $self = shift;
my $menu = Win32::GUI::Menu->new();
my $r = Win32::GUI::SetMenu($self, $menu->{-handle});
# print "SetMenu=$r\n";
return $menu;
}
###########################################################################
# (@)METHOD:GetDC()
# Returns the DC object associated with the window.
sub GetDC {
my $self = shift;
return Win32::GUI::DC->new($self);
}
###########################################################################
# (@)INTERNAL:DESTROY(HANDLE)
sub DESTROY {
my $self = shift;
my $timer;
if( exists $self->{-timers} ) {
foreach $timer ($self->{-timers}) {
undef $self->{-timers}->{$timer};
}
}
# Win32::GUI::DestroyWindow($self);
}
###########################################################################
# (@)INTERNAL:AUTOLOAD(HANDLE, METHOD)
sub AUTOLOAD {
my($self, $method) = @_;
$AUTOLOAD =~ s/.*:://;
# print "Win32::GUI::Window::AUTOLOAD called for object '$self', method '$method', AUTOLOAD=$AUTOLOAD\n";
if( exists $self->{$AUTOLOAD}) {
return $self->{$AUTOLOAD};
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::DialogBox
#
package Win32::GUI::DialogBox;
@ISA = qw(Win32::GUI::Window);
###########################################################################
# (@)METHOD:new Win32::GUI::DialogBox(%OPTIONS)
# Creates a new DialogBox object. See new Win32::GUI::Window().
sub new {
my $self = Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__DIALOG", 0), @_);
if($self) {
$self->{-dialogui} = 1;
return $self;
} else {
return undef;
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Button
#
package Win32::GUI::Button;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Button(PARENT, %OPTIONS)
# Creates a new Button object;
# can also be called as PARENT->AddButton(%OPTIONS).
# Class specific %OPTIONS are:
# -align => left/center/right (default left)
# -valign => top/center/bottom
#
# -default => 0/1 (default 0)
# -ok => 0/1 (default 0)
# -cancel => 0/1 (default 0)
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__BUTTON", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::RadioButton
#
package Win32::GUI::RadioButton;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::RadioButton(PARENT, %OPTIONS)
# Creates a new RadioButton object;
# can also be called as PARENT->AddRadioButton(%OPTIONS).
# %OPTIONS are the same of Button (see new Win32::GUI::Button() ).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__RADIOBUTTON", 0), @_);
}
###########################################################################
# (@)METHOD:Checked([VALUE])
# Gets or sets the checked state of the RadioButton; if called without
# arguments, returns the current state:
# 0 not checked
# 1 checked
# If a VALUE is specified, it can be one of these (eg. 0 to uncheck the
# RadioButton, 1 to check it).
sub Checked {
my $self = shift;
my $check = shift;
if(defined($check)) {
# 241 == BM_SETCHECK
return Win32::GUI::SendMessage($self, 241, $check, 0);
} else {
# 240 == BM_GETCHECK
return Win32::GUI::SendMessage($self, 240, 0, 0);
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Checkbox
#
package Win32::GUI::Checkbox;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Checkbox(PARENT, %OPTIONS)
# Creates a new Checkbox object;
# can also be called as PARENT->AddCheckbox(%OPTIONS).
# %OPTIONS are the same of Button (see new Win32::GUI::Button() ).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__CHECKBOX", 0), @_);
}
###########################################################################
# (@)METHOD:GetCheck()
# Returns the check state of the Checkbox:
# 0 not checked
# 1 checked
# 2 indeterminate (grayed)
sub GetCheck {
my $self = shift;
# 240 == BM_GETCHECK
return Win32::GUI::SendMessage($self, 240, 0, 0);
}
###########################################################################
# (@)METHOD:SetCheck([VALUE])
# Sets the check state of the Checkbox; for a list of possible values,
# see GetCheck().
# If called without arguments, it checks the Checkbox (eg. state = 1).
sub SetCheck {
my $self = shift;
my $check = shift;
$check = 1 unless defined($check);
# 241 == BM_SETCHECK
return Win32::GUI::SendMessage($self, 241, $check, 0);
}
###########################################################################
# (@)METHOD:Checked([VALUE])
# Gets or sets the check state of the Checkbox; if called without
# arguments, returns the current state:
# 0 not checked
# 1 checked
# 2 indeterminate (grayed)
# If a VALUE is specified, it can be one of these (eg. 0 to uncheck the
# Checkbox, 1 to check it).
sub Checked {
my $self = shift;
my $check = shift;
if(defined($check)) {
# 241 == BM_SETCHECK
return Win32::GUI::SendMessage($self, 241, $check, 0);
} else {
# 240 == BM_GETCHECK
return Win32::GUI::SendMessage($self, 240, 0, 0);
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Label
#
package Win32::GUI::Label;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Label(PARENT, %OPTIONS)
# Creates a new Label object;
# can also be called as PARENT->AddLabel(%OPTIONS).
# Class specific %OPTIONS are:
# -align => left/center/right (default left)
# -bitmap => 0/1 (default 0)
# the control displays a bitmap, not a text.
# -fill => black/gray/white/none (default none)
# fills the control rectangle ("black", "gray" and "white" are
# the window frame color, the desktop color and the window
# background color respectively).
# -frame => black/gray/white/etched/none (default none)
# draws a border around the control. colors are the same
# of -fill, with the addition of "etched" (a raised border).
# -noprefix => 0/1 (default 0)
# disables the interpretation of "&" as accelerator prefix.
# -notify => 0/1 (default 0)
# enables the Click(), DblClick, etc. events.
# -sunken => 0/1 (default 0)
# draws a half-sunken border around the control.
# -truncate => 0/1/word/path (default 0)
# specifies how the text is to be truncated:
# 0 the text is not truncated
# 1 the text is truncated at the end
# path the text is truncated before the last "\"
# (used to shorten paths).
# -wrap => 0/1 (default 1)
# the text wraps automatically to a new line.
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__STATIC", 0), @_);
}
###########################################################################
# (@)METHOD:SetImage(BITMAP)
# Draws the specified BITMAP, a Win32::GUI::Bitmap object, in the Label
# (must have been created with -bitmap => 1 option).
sub SetImage {
my $self = shift;
my $image = shift;
$image = $image->{-handle} if ref($image);
my $type = Win32::GUI::constant("IMAGE_BITMAP", 0);
# 370 == STM_SETIMAGE
return Win32::GUI::SendMessage($self, 370, $type, $image);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Textfield
#
package Win32::GUI::Textfield;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Textfield(PARENT, %OPTIONS)
# Creates a new Textfield object;
# can also be called as PARENT->AddTextfield(%OPTIONS).
# Class specific %OPTIONS are:
# -align => left/center/right (default left)
# aligns the text in the control accordingly.
# -keepselection => 0/1 (default 0)
# the selection is not hidden when the control loses focus.
# -multiline => 0/1 (default 0)
# the control can have more than one line (note that newline
# is "\r\n", not "\n"!).
# -password => 0/1 (default 0)
# masks the user input (like password prompts).
# -passwordchar => char (default '*')
# the char that is shown instead of the text with -password => 1.
# -prompt => (see below)
# -readonly => 0/1 (default 0)
# text can't be changed.
#
# The -prompt option is very special; if a string is passed, a
# Win32::GUI::Label object (with text set to the string passed) is created
# to the left of the Textfield.
# Example:
# $Window->AddTextfield(
# -name => "Username",
# -left => 75,
# -top => 150,
# -prompt => "Your name:",
# );
# Furthermore, the value to -prompt can be a reference to a list containing
# the string and an additional parameter, which sets the width for
# the Label (eg. [ STRING, WIDTH ] ). If WIDTH is negative, it is calculated
# relative to the Textfield left coordinate. Example:
#
# -left => 75, (Label left) (Textfield left)
# -prompt => [ "Your name:", 30 ], 75 105 (75+30)
#
# -left => 75,
# -prompt => [ "Your name:", -30 ], 45 (75-30) 75
#
# Note that the Win32::GUI::Label object is named like the Textfield, with
# a "_Prompt" suffix (in the example above, the Label is named
# "Username_Prompt").
sub new {
my($class, $parent, %options) = @_;
if(exists $options{-prompt}) {
my $add = 0;
my ($text, $left, $width, $height, );
my $visible = 1;
if(ref($options{-prompt}) eq "ARRAY") {
$left = pop(@{$options{'-prompt'}});
$text = pop(@{$options{'-prompt'}});
if($left < 0) {
$left = $options{-left} + $left;
$width = -$left;
} else {
$width = $left;
$left = $options{-left};
$add = $width;
}
} else {
$text = $options{-prompt};
$add = -1;
}
if(exists $options{-height}) {
$height = $options{-height}-3;
} else {
$height = 0;
}
if(exists $options{-visible}) {
$visible = $options{-visible};
}
my $prompt = new Win32::GUI::Label(
$parent,
-name => $options{-name} . '_Prompt',
-width => $width,
-left => $left,
-top => $options{-top} + 3,
-text => $text,
-height => $height,
-visible => $visible,
);
$add = $prompt->Width if $add == -1;
$options{-left} += $add;
}
return Win32::GUI->_new(
Win32::GUI::constant("WIN32__GUI__EDIT", 0),
$class, $parent, %options,
);
}
###########################################################################
# (@)METHOD:Select(START, END)
# Selects the specified range of characters in the Textfield.
sub Select {
my($self, $wparam, $lparam) = @_;
# 177 == EM_SETSEL
return Win32::GUI::SendMessage($self, 177, $wparam, $lparam);
}
###########################################################################
# (@)METHOD:SelectAll()
# Selects all the text in the Textfield.
sub SelectAll {
my($self, $wparam, $lparam) = @_;
# 177 == EM_SETSEL
# 14 == WM_GETTEXTLENGTH
return Win32::GUI::SendMessage(
$self, 177,
0, Win32::GUI::SendMessage($self, 14, 0, 0),
);
}
###########################################################################
# (@)METHOD:MaxLength([CHARS])
# Limits the number of characters that the Textfield accept to CHARS,
# or returns the current limit if no argument is given.
# To remove the limit (eg. set it to the maximum allowed which is 32k
# for a single-line Textfield and 64k for a multiline one) set CHARS
# to 0.
sub MaxLength {
my($self, $chars) = @_;
if(defined $chars) {
# 197 == EM_SETLIMITTEXT
return Win32::GUI::SendMessage($self, 197, $chars, 0);
} else {
# 213 == EM_GETLIMITTEXT
return Win32::GUI::SendMessage($self, 213, 0, 0);
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Listbox
#
package Win32::GUI::Listbox;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Listbox(PARENT, %OPTIONS)
# Creates a new Listbox object;
# can also be called as PARENT->AddListbox(%OPTIONS).
# Class specific %OPTIONS are:
# -multisel => 0/1/2 (default 0)
# specifies the selection type:
# 0 single selection
# 1 multiple selection
# 2 multiple selection ehnanced (with Shift, Control, etc.)
# -sort => 0/1 (default 0)
# items are sorted alphabetically.
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__LISTBOX", 0), @_);
}
###########################################################################
# (@)METHOD:SelectedItem()
# Returns the zero-based index of the currently selected item, or -1 if
# no item is selected.
sub SelectedItem {
my $self = shift;
# 392 == LB_GETCURSEL
return Win32::GUI::SendMessage($self, 392, 0, 0);
}
###########################################################################
# (@)METHOD:ListIndex()
# See SelectedItem().
sub ListIndex { SelectedItem(@_); }
###########################################################################
# (@)METHOD:Select(INDEX)
# Selects the zero-based INDEX item in the Listbox.
sub Select {
my $self = shift;
my $item = shift;
# 390 == LB_SETCURSEL
my $r = Win32::GUI::SendMessage($self, 390, $item, 0);
return $r;
}
###########################################################################
# (@)METHOD:Reset()
# Deletes the content of the Listbox.
sub Reset {
my $self = shift;
# 388 == LB_RESETCONTENT
my $r = Win32::GUI::SendMessage($self, 388, 0, 0);
return $r;
}
###########################################################################
# (@)METHOD:Clear()
# See Reset().
sub Clear { Reset(@_); }
###########################################################################
# (@)METHOD:RemoveItem(INDEX)
# Removes the zero-based INDEX item from the Listbox.
sub RemoveItem {
my $self = shift;
my $item = shift;
# 386 == LB_DELETESTRING
my $r = Win32::GUI::SendMessage($self, 386, $item, 0);
return $r;
}
###########################################################################
# (@)METHOD:Count()
# Returns the number of items in the Listbox.
sub Count {
my $self = shift;
# 395 == LB_GETCOUNT
my $r = Win32::GUI::SendMessage($self, 395, 0, 0);
return $r;
}
sub List {
my $self = shift;
my $index = shift;
if(not defined $index) {
my @list = ();
for my $i (0..($self->Count-1)) {
push @list, Win32::GUI::Listbox::Item->new($self, $i);
}
return @list;
} else {
return Win32::GUI::Listbox::Item->new($self, $index);
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Listbox::Item
#
package Win32::GUI::Listbox::Item;
sub new {
my($class, $listbox, $index) = @_;
$self = {
-parent => $listbox,
-index => $index,
-string => $listbox->GetString($index),
};
return bless $self, $class;
}
sub Remove {
my($self) = @_;
$self->{-parent}->RemoveItem($self->{-index});
undef $_[0];
}
sub Select {
my($self) = @_;
$self->{-parent}->Select($self->{-index});
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Combobox
#
package Win32::GUI::Combobox;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Combobox(PARENT, %OPTIONS)
# Creates a new Combobox object;
# can also be called as PARENT->AddCombobox(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__COMBOBOX", 0), @_);
}
###########################################################################
# (@)METHOD:SelectedItem()
# Returns the zero-based index of the currently selected item, or -1 if
# no item is selected.
sub SelectedItem {
my $self = shift;
# 327 == CB_GETCURSEL
return Win32::GUI::SendMessage($self, 327, 0, 0);
}
###########################################################################
# (@)METHOD:ListIndex()
# See SelectedItem().
sub ListIndex { SelectedItem(@_); }
###########################################################################
# (@)METHOD:Select(INDEX)
# Selects the zero-based INDEX item in the Combobox.
sub Select {
my $self = shift;
my $item = shift;
# 334 == CB_SETCURSEL
my $r = Win32::GUI::SendMessage($self, 334, $item, 0);
return $r;
}
###########################################################################
# (@)METHOD:Reset()
# Deletes the content of the Combobox.
sub Reset {
my $self = shift;
# 331 == CB_RESETCONTENT
my $r = Win32::GUI::SendMessage($self, 331, 0, 0);
return $r;
}
###########################################################################
# (@)METHOD:Clear()
# See Reset().
sub Clear { Reset(@_); }
###########################################################################
# (@)METHOD:RemoveItem(INDEX)
# Removes the zero-based INDEX item from the Combobox.
sub RemoveItem {
my $self = shift;
my $item = shift;
# 324 == CB_DELETESTRING
my $r = Win32::GUI::SendMessage($self, 324, $item, 0);
return $r;
}
###########################################################################
# (@)METHOD:Count()
# Returns the number of items in the Combobox.
sub Count {
my $self = shift;
# 326 == CB_GETCOUNT
my $r = Win32::GUI::SendMessage($self, 326, 0, 0);
return $r;
}
###############################################################################
# (@)PACKAGE:Win32::GUI::ProgressBar
#
package Win32::GUI::ProgressBar;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::ProgressBar(PARENT, %OPTIONS)
# Creates a new ProgressBar object;
# can also be called as PARENT->AddProgressBar(%OPTIONS).
# Class specific %OPTIONS are:
# -smooth => 0/1 (default 0)
# uses a smooth bar instead of the default segmented bar.
# -vertical => 0/1 (default 0)
# display progress status vertically (from bottom to top).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__PROGRESS", 0), @_);
}
###########################################################################
# (@)METHOD:SetPos(VALUE)
# Sets the position of the ProgressBar to the specified VALUE.
sub SetPos {
my $self = shift;
my $pos = shift;
# 1026 == PBM_SETPOS
return Win32::GUI::SendMessage($self, 1026, $pos, 0);
}
###########################################################################
# (@)METHOD:StepIt()
# Increments the position of the ProgressBar of the defined step value;
# see SetStep().
sub StepIt {
my $self = shift;
# 1029 == PBM_STEPIT
return Win32::GUI::SendMessage($self, 1029, 0, 0);
}
###########################################################################
# (@)METHOD:SetRange([MIN], MAX)
# Sets the range of values (from MIN to MAX) for the ProgressBar; if MIN
# is not specified, it defaults to 0.
sub SetRange {
my $self = shift;
my ($min, $max) = @_;
$max = $min, $min = 0 unless defined($max);
# 1025 == PBM_SETRANGE
# return Win32::GUI::SendMessage($self, 1025, 0, ($max + $min >> 8));
return Win32::GUI::SendMessage($self, 1025, 0, ($min | $max << 16));
}
###########################################################################
# (@)METHOD:SetStep([VALUE])
# Sets the increment value for the ProgressBar; see StepIt().
sub SetStep {
my $self = shift;
my $step = shift;
$step = 10 unless $step;
# 1028 == PBM_SETSTEP
return Win32::GUI::SendMessage($self, 1028, $step, 0);
}
# TODO 4.71: Color, BackColor
###############################################################################
# (@)PACKAGE:Win32::GUI::StatusBar
#
package Win32::GUI::StatusBar;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::StatusBar(PARENT, %OPTIONS)
# Creates a new StatusBar object;
# can also be called as PARENT->AddStatusBar(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__STATUS", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::TabStrip
#
package Win32::GUI::TabStrip;
@ISA = qw(Win32::GUI::Window Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::TabStrip(PARENT, %OPTIONS)
# Creates a new TabStrip object;
# can also be called as PARENT->AddTabStrip(%OPTIONS).
# Class specific %OPTIONS are:
# -bottom => 0/1 (default 0)
# -buttons => 0/1 (default 0)
# -hottrack => 0/1 (default 0)
# -imagelist => Win32::GUI::ImageList object
# -justify => 0/1 (default 0)
# -multiline => 0/1 (default 0)
# -right => 0/1 (default 0)
# -vertical => 0/1 (default 0)
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__TAB", 0), @_);
}
###########################################################################
# (@)METHOD:SelectedItem()
# Returns the zero-based index of the currently selected item.
sub SelectedItem {
my $self = shift;
# 4875 == TCM_GETCURSEL
return Win32::GUI::SendMessage($self, 4875, 0, 0);
}
###########################################################################
# (@)METHOD:Select(INDEX)
# Selects the zero-based INDEX item in the TabStrip.
sub Select {
my $self = shift;
# 4876 == TCM_SETCURSEL
return Win32::GUI::SendMessage($self, 4876, shift, 0);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Toolbar
#
package Win32::GUI::Toolbar;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Toolbar(PARENT, %OPTIONS)
# Creates a new Toolbar object;
# can also be called as PARENT->AddToolbar(%OPTIONS).
# Class specific %OPTIONS are:
# -flat => 0/1
# -imagelist => IMAGELIST
# -multiline => 0/1
# -nodivider => 0/1
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__TOOLBAR", 0), @_);
}
###########################################################################
# (@)METHOD:SetBitmapSize([X, Y])
sub SetBitmapSize {
my $self = shift;
my ($x, $y) = @_;
$x = 16 unless defined($x);
$y = 15 unless defined($y);
# 1056 == TB_SETBITMAPSIZE
return Win32::GUI::SendMessage($self, 1056, 0, ($x | $y << 16));
}
###############################################################################
# (@)PACKAGE:Win32::GUI::RichEdit
#
package Win32::GUI::RichEdit;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::RichEdit(PARENT, %OPTIONS)
# Creates a new RichEdit object;
# can also be called as PARENT->AddRichEdit(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__RICHEDIT", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::ListView
#
package Win32::GUI::ListView;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::ListView(PARENT, %OPTIONS)
# Creates a new ListView object;
# can also be called as PARENT->AddListView(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__LISTVIEW", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::TreeView
#
package Win32::GUI::TreeView;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::TreeView(PARENT, %OPTIONS)
# Creates a new TreeView object
# can also be called as PARENT->AddTreeView(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__TREEVIEW", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Slider
# also Trackbar
#
package Win32::GUI::Trackbar;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Slider(PARENT, %OPTIONS)
# Creates a new Slider object;
# can also be called as PARENT->AddSlider(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__TRACKBAR", 0), @_);
}
sub SetRange {
}
sub Min {
my $self = shift;
my $value = shift;
if(defined($value)) {
my $flag = shift;
$flag = 1 unless defined($flag);
# 1031 == TBM_SETRANGEMIN
return Win32::GUI::SendMessage($self, 1031, $flag, $value);
} else {
# 1025 == TBM_GETRANGEMIN
return Win32::GUI::SendMessage($self, 1025, 0, 0);
}
}
sub Max {
my $self = shift;
my $value = shift;
if(defined($value)) {
my $flag = shift;
$flag = 1 unless defined($flag);
# 1032 == TBM_SETRANGEMAX
return Win32::GUI::SendMessage($self, 1032, $flag, $value);
} else {
# 1026 == TBM_GETRANGEMAX
return Win32::GUI::SendMessage($self, 1026, 0, 0);
}
}
sub Pos {
my $self = shift;
my $value = shift;
if(defined($value)) {
my $flag = shift;
$flag = 1 unless defined($flag);
# 1029 == TBM_SETPOS
return Win32::GUI::SendMessage($self, 1029, $flag, $value);
} else {
# 1024 == TBM_GETPOS
return Win32::GUI::SendMessage($self, 1024, 0, 0);
}
}
sub TicFrequency {
my $self = shift;
my $value = shift;
# 1044 == TBM_SETTICFREQ
return Win32::GUI::SendMessage($self, 1044, $value, 0);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Slider
#
package Win32::GUI::Slider;
@ISA = qw(Win32::GUI::Trackbar);
###############################################################################
# (@)PACKAGE:Win32::GUI::UpDown
#
package Win32::GUI::UpDown;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::UpDown(PARENT, %OPTIONS)
# Creates a new UpDown object;
# can also be called as PARENT->AddUpDown(%OPTIONS).
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__UPDOWN", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Tooltip
#
package Win32::GUI::Tooltip;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Tooltip(PARENT, %OPTIONS)
# (preliminary) creates a new Tooltip object
sub new {
my $parent = $_[0];
my $new = Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__TOOLTIP", 0), @_);
if($new) {
if($parent->{-tooltips}) {
push(@{$parent->{-tooltips}}, $new->{-handle});
} else {
$parent->{-tooltips} = [ $new->{-handle} ];
}
}
return $new;
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Animation
#
package Win32::GUI::Animation;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Animation(PARENT, %OPTIONS)
# Creates a new Animation object;
# can also be called as PARENT->AddAnimation(%OPTIONS).
# Class specific %OPTIONS are:
# -autoplay => 0/1 (default 0)
# starts playing the animation as soon as an AVI clip is loaded
# -center => 0/1 (default 0)
# centers the animation in the control window
# -transparent => 0/1 (default 0)
# draws the animation using a transparent background
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__ANIMATION", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Rebar
#
package Win32::GUI::Rebar;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Rebar(PARENT, %OPTIONS)
# Creates a new Rebar object;
# can also be called as PARENT->AddRebar(%OPTIONS).
# Class specific %OPTIONS are:
# -bandborders => 0/1 (default 0)
# display a border to separate bands.
# -fixedorder => 0/1 (default 0)
# band position cannot be swapped.
# -imagelist => Win32::GUI::ImageList object
# -varheight => 0/1 (default 1)
# display bands using the minimum required height.
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__REBAR", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Header
#
package Win32::GUI::Header;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::Header(PARENT, %OPTIONS)
# Creates a new Header object;
# can also be called as PARENT->AddHeader(%OPTIONS).
# Class specific %OPTIONS are:
# -buttons => 0/1 (default 0)
# header items look like push buttons and can be clicked.
# -hottrack => 0/1 (default 0)
# -imagelist => Win32::GUI::ImageList object
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__HEADER", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::ComboboxEx
#
package Win32::GUI::ComboboxEx;
@ISA = qw(Win32::GUI::Combobox Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::ComboboxEx(PARENT, %OPTIONS)
# Creates a new ComboboxEx object;
# can also be called as PARENT->AddComboboxEx(%OPTIONS).
# Class specific %OPTIONS are:
# -imagelist => Win32::GUI::ImageList object
# Except for images, a ComboboxEx object acts like a Win32::GUI::Combobox
# object. See also new Win32::GUI::Combobox().
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__COMBOBOXEX", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::DateTime
#
package Win32::GUI::DateTime;
@ISA = qw(Win32::GUI Win32::GUI::WindowProps);
###########################################################################
# (@)METHOD:new Win32::GUI::DateTime(PARENT, %OPTIONS)
# Creates a new DateTime object;
# can also be called as PARENT->AddDateTime(%OPTIONS).
# Class specific %OPTIONS are:
# [TBD]
sub new {
return Win32::GUI->_new(Win32::GUI::constant("WIN32__GUI__DTPICK", 0), @_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Graphic
#
package Win32::GUI::Graphic;
@ISA = qw(Win32::GUI::DC);
###########################################################################
# (@)METHOD:new Win32::GUI::Graphic(PARENT, %OPTIONS)
# Creates a new Graphic object;
# can also be called as PARENT->AddGraphic(%OPTIONS).
# Class specific %OPTIONS are:
sub new {
my $class = shift;
my $self = {};
bless($self, $class);
my(@input) = @_;
my $handle = Win32::GUI::Create($self, 101, @input);
if($handle) {
return $self;
} else {
return undef;
}
}
###########################################################################
# (@)METHOD:GetDC()
# Returns the DC object associated with the window.
sub GetDC {
my $self = shift;
return Win32::GUI::DC->new($self);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::ImageList
#
package Win32::GUI::ImageList;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::ImageList(X, Y, FLAGS, INITAL, GROW)
# Creates an ImageList object; X and Y specify the size of the images,
# FLAGS [TBD]. INITIAL and GROW specify the number of images the ImageList
# actually contains (INITIAL) and the number of images for which memory
# is allocated (GROW).
sub new {
my $class = shift;
my $handle = Win32::GUI::ImageList::Create(@_);
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
###########################################################################
# (@)METHOD:Add(BITMAP, [BITMAPMASK])
# Adds a bitmap to the ImageList; both BITMAP and BITMAPMASK can be either
# Win32::GUI::Bitmap objects or filenames.
sub Add {
my($self, $bitmap, $bitmapMask) = @_;
$bitmap = new Win32::GUI::Bitmap($bitmap) unless ref($bitmap);
if(defined($bitmapMask)) {
$bitmapMask = new Win32::GUI::Bitmap($bitmapMask) unless ref($bitmapMask);
$self->AddBitmap($bitmap, $bitmapMask);
} else {
$self->AddBitmap($bitmap);
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Menu
#
package Win32::GUI::Menu;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Menu(...)
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $self={};
if($#_ > 0) {
return Win32::GUI::MakeMenu(@_);
} else {
my $handle = Win32::GUI::CreateMenu();
if($handle) {
$self->{-handle} = $handle;
bless($self, $class);
return $self;
} else {
return undef;
}
}
}
###########################################################################
# (@)METHOD:AddMenuButton()
# see new Win32::GUI::MenuButton()
sub AddMenuButton {
return Win32::GUI::MenuButton->new(@_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::MenuButton
#
package Win32::GUI::MenuButton;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::MenuButton()
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $menu = shift;
$menu = $menu->{-handle} if ref($menu);
# print "new MenuButton: menu=$menu\n";
my %args = @_;
my $self = {};
my $handle = Win32::GUI::CreatePopupMenu();
if($handle) {
$args{-submenu} = $handle;
Win32::GUI::MenuButton::InsertMenuItem($menu, %args);
$self->{-handle} = $handle;
bless($self, $class);
if($args{-name}) {
$Win32::GUI::Menus{$args{-id}} = $self;
$self->{-name} = $args{-name};
}
return $self;
} else {
return undef;
}
}
###########################################################################
# (@)METHOD:AddMenuItem()
# see new Win32::GUI::MenuItem()
sub AddMenuItem {
return Win32::GUI::MenuItem->new(@_);
}
###############################################################################
# (@)PACKAGE:Win32::GUI::MenuItem
#
package Win32::GUI::MenuItem;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::MenuItem()
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $menu = shift;
return undef unless ref($menu) =~ /^Win32::GUI::Menu/;
my %args = @_;
my $self = {};
my $handle = Win32::GUI::MenuButton::InsertMenuItem($menu, %args);
if($handle) {
$self->{-handle} = $handle;
$Win32::GUI::menucallbacks{$args{-id}} = $args{-function} if $args{-function};
$self->{-id} = $args{-id};
$self->{-menu} = $menu->{-handle};
bless($self, $class);
if($args{-name}) {
$Win32::GUI::Menus{$args{-id}} = $self;
$self->{-name} = $args{-name};
}
return $self;
} else {
return undef;
}
}
###############################################################################
# (@)PACKAGE: Win32::GUI::Timer
#
package Win32::GUI::Timer;
@ISA = qw(Win32::GUI);
###########################################################################
# (@)METHOD:new Win32::GUI::Timer(PARENT, NAME, ELAPSE)
# Creates a new timer in the PARENT window named NAME that will
# trigger its Timer() event after ELAPSE milliseconds.
# Can also be called as PARENT->AddTimer(NAME, ELAPSE).
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $window = shift;
my $name = shift;
my $elapse = shift;
my %args = @_;
my $id = $Win32::GUI::TimerIdCounter;
$Win32::GUI::TimerIdCounter++;
Win32::GUI::SetTimer($window, $id, $elapse);
my $self = {};
bless($self, $class);
# add $self->{name}
$self->{-id} = $id;
$self->{-name} = $name;
$self->{-parent} = $window;
$self->{-handle} = $window->{-handle};
$self->{-interval} = $elapse;
# add to $window->timers->{$id} = $self;
$window->{-timers}->{$id} = $self;
$window->{$name} = $self;
return $self;
}
###########################################################################
# (@)METHOD:Interval(ELAPSE)
# Changes the timeout value of the Timer to ELAPSE milliseconds.
# If ELAPSE is 0, the Timer is disabled;
# can also be used to resume a Timer after a Kill().
sub Interval {
my $self = shift;
my $interval = shift;
if(defined $interval) {
Win32::GUI::SetTimer($self->{-parent}->{-handle}, $self->{-id}, $interval);
$self->{-interval} = $interval;
} else {
return $self->{-interval};
}
}
###########################################################################
# (@)METHOD:Kill()
# Disables the Timer.
sub Kill {
my $self = shift;
Win32::GUI::KillTimer($self->{-parent}->{-handle}, $self->{-id});
}
###########################################################################
# (@)INTERNAL:DESTROY(HANDLE)
sub DESTROY {
my $self = shift;
Win32::GUI::KillTimer($self->{-handle}, $self->{-id});
undef $self->{-parent}->{-timers}->{$self->{-id}};
}
###############################################################################
# (@)PACKAGE:Win32::GUI::NotifyIcon
#
package Win32::GUI::NotifyIcon;
###########################################################################
# (@)METHOD:new Win32::GUI::NotifyIcon(PARENT, %OPTIONS)
# Creates a new NotifyIcon (also known as system tray icon) object;
# can also be called as PARENT->AddNotifyIcon(%OPTIONS).
# %OPTIONS are:
# -icon => Win32::GUI::Icon object
# -id => NUMBER
# a unique identifier for the NotifyIcon object
# -name => STRING
# the name for the object
# -tip => STRING
# the text that will appear as tooltip when the mouse is
# on the NotifyIcon
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $window = shift;
my %args = @_;
$Win32::GUI::NotifyIconIdCounter++;
if(!exists($args{-id})) {
$args{-id} = $Win32::GUI::NotifyIconIdCounter;
}
Win32::GUI::NotifyIcon::Add($window, %args);
my $self = {};
bless($self, $class);
$self->{-id} = $args{-id};
$self->{-name} = $args{-name};
$self->{-parent} = $window;
$self->{-handle} = $window->{-handle};
$window->{-notifyicons}->{$args{-id}} = $self;
$window->{$args{-name}} = $self;
return $self;
}
###########################################################################
# (@)INTERNAL:DESTROY(OBJECT)
sub DESTROY {
my($self) = @_;
Win32::GUI::NotifyIcon::Delete(
$self->{-parent},
-id => $self->{-id},
);
undef $self->{-parent}->{$self->{-name}};
}
###############################################################################
# (@)PACKAGE:Win32::GUI::DC
#
package Win32::GUI::DC;
###########################################################################
# (@)METHOD:new Win32::GUI::DC(WINDOW | DRIVER, DEVICE)
# Creates a new DC object; the first form (WINDOW is a Win32::GUI object)
# gets the DC for the specified window (can also be called as
# WINDOW->GetDC). The second form creates a DC for the specified DEVICE;
# actually, the only supported DRIVER is the display driver (eg. the
# screen). To get the DC for the entire screen use:
# $Screen = new Win32::GUI::DC("DISPLAY");
#
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $self = {};
bless($self, $class);
my $window = shift;
if(defined($window)) {
if(ref($window)) {
$self->{-handle} = GetDC($window->{-handle});
$self->{-window} = $window->{-handle};
} else {
my $device = shift;
$self->{-handle} = CreateDC($window, $device);
}
} else {
$self = CreateDC("DISPLAY", 0);
}
return $self;
}
sub DESTROY {
my $self = shift;
if($self->{-window}) {
ReleaseDC($self->{-window}, $self->{-handle});
} else {
DeleteDC($self->{-handle});
}
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Pen
#
package Win32::GUI::Pen;
###########################################################################
# (@)METHOD:new Win32::GUI::Pen(COLOR | %OPTIONS)
# Creates a new Pen object.
# Allowed %OPTIONS are:
# -style =>
# 0 PS_SOLID
# 1 PS_DASH
# 2 PS_DOT
# 3 PS_DASHDOT
# 4 PS_DASHDOTDOT
# 5 PS_NULL
# 6 PS_INSIDEFRAME
# -width => number
# -color => COLOR
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $self = {};
bless($self, $class);
$self->{-handle} = Create(@_);
return $self;
}
###############################################################################
# (@)PACKAGE:Win32::GUI::Brush
#
package Win32::GUI::Brush;
###########################################################################
# (@)METHOD:new Win32::GUI::Brush(COLOR | %OPTIONS)
# Creates a new Brush object.
# Allowed %OPTIONS are:
# -style =>
# 0 BS_SOLID
# 1 BS_NULL
# 2 BS_HATCHED
# 3 BS_PATTERN
# -pattern => Win32::GUI::Bitmap object (valid for -style => BS_PATTERN)
# -hatch => (valid for -style => BS_HATCHED)
# 0 HS_ORIZONTAL (-----)
# 1 HS_VERTICAL (|||||)
# 2 HS_FDIAGONAL (\\\\\)
# 3 HS_BDIAGONAL (/////)
# 4 HS_CROSS (+++++)
# 5 HS_DIAGCROSS (xxxxx)
# -color => COLOR
sub new {
my $class = shift;
$class = "Win32::" . $class if $class =~ /^GUI::/;
my $self = {};
bless($self, $class);
$self->{-handle} = Create(@_);
return $self;
}
###############################################################################
# (@)INTERNAL:Win32::GUI::WindowProps
# the package we'll tie to a window hash to set/get properties in a more
# fashionable way...
#
package Win32::GUI::WindowProps;
my %TwoWayMethodMap = (
-text => "Text",
-left => "Left",
-top => "Top",
-width => "Width",
-height => "Height",
);
my %OneWayMethodMap = (
-scalewidth => "ScaleHeight",
-scaleheight => "ScaleWidth",
);
###########################################################################
# (@)INTERNAL:TIEHASH
sub TIEHASH {
my($class, $object) = @_;
my $tied = { UNDERLYING => $object };
# print "[TIEHASH] called for '$class' '$object'\n";
# return bless $tied, $class;
return bless $object, $class;
}
###########################################################################
# (@)INTERNAL:STORE
sub STORE {
my($self, $key, $value) = @_;
# print "[STORE] called for '$self' {$key}='$value'\n";
if(exists $TwoWayMethodMap{$key}) {
if(my $method = $self->can($TwoWayMethodMap{$key})) {
# print "[STORE] calling method '$TwoWayMethodMap{$key}' on '$self'\n";
return &{$method}($self, $value);
} else {
print "[STORE] PROBLEM: method '$TwoWayMethodMap{$key}' not found on '$self'\n";
}
} elsif($key eq "-style") {
# print "[STORE] calling GetWindowLong\n";
return Win32::GUI::GetWindowLong($self, -16, $value);
} else {
# print "[STORE] storing key '$key' in '$self'\n";
# return $self->{UNDERLYING}->{$key} = $value;
return $self->{$key} = $value;
}
}
###########################################################################
# (@)INTERNAL:FETCH
sub FETCH {
my($self, $key) = @_;
if($key eq "UNDERLYING") {
# print "[FETCH] returning UNDERLYING for '$self'\n";
return $self->{UNDERLYING};
} elsif(exists $TwoWayMethodMap{$key}) {
# if(my $method = $self->{UNDERLYING}->can($TwoWayMethodMap{$key})) {
if(my $method = $self->can($TwoWayMethodMap{$key})) {
# print "[FETCH] calling method $TwoWayMethodMap{$key} on $self->{UNDERLYING}\n";
# print "[FETCH] calling method '$TwoWayMethodMap{$key}' on '$self'\n";
# return &{$method}($self->{UNDERLYING});
return &{$method}($self);
} else {
# print "[FETCH] method not found '$TwoWayMethodMap{$key}'\n";
return undef;
}
} elsif($key eq "-style") {
return Win32::GUI::GetWindowLong($self->{UNDERLYING}, -16);
#} elsif(exists $self->{UNDERLYING}->{$key}) {
# print "[FETCH] fetching key $key from $self->{UNDERLYING}\n";
# return $self->{UNDERLYING}->{$key};
} elsif(exists $self->{$key}) {
#print "[FETCH] fetching key '$key' from '$self'\n";
return $self->{$key};
} else {
# print "Win32::GUI::WindowProps::FETCH returning nothing for '$key' on $self->{UNDERLYING}\n";
#print "[FETCH] returning nothing for '$key' on '$self'\n";
return undef;
# return 0;
}
}
sub FIRSTKEY {
my $self = shift;
my $a = keys %{ $self };
my ($k, $v) = each %{ $self };
# print "[FIRSTKEY] k='$k' v='$v'\n";
return $k;
}
sub NEXTKEY {
my $self = shift;
my ($k, $v) = each %{ $self };
# print "[NEXTKEY] k='$k' v='$v'\n";
return $k;
}
sub EXISTS {
my($self, $key) = @_;
# return exists $self->{UNDERLYING}->{$key};
return exists $self->{$key};
}
###############################################################################
# dynamically load in the GUI.dll module.
#
package Win32::GUI;
bootstrap Win32::GUI;
# Preloaded methods go here.
$Win32::GUI::StandardWinClass = Win32::GUI::Class->new(
-name => "PerlWin32GUI_STD_OBSOLETED"
);
$Win32::GUI::StandardWinClassVisual = Win32::GUI::Class->new(
-name => "PerlWin32GUI_STD",
-visual => 1,
);
$Win32::GUI::GraphicWinClass = Win32::GUI::Class->new(
-name => "Win32::GUI::Graphic",
-widget => "Graphic",
);
$Win32::GUI::RICHED = Win32::GUI::LoadLibrary("RICHED32");
END {
# print "Freeing library RICHED32\n";
Win32::GUI::FreeLibrary($Win32::GUI::RICHED);
}
#Currently Autoloading is not implemented in Perl for win32
# Autoload methods go after __END__, and are processed by the autosplit program.
1;
__END__