PDA

Показать полную графическую версию : Скрипты Inno Setup. Помощь и советы [часть 5]


Страниц : 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 [63] 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100

Gnom_aka_Lexander
10-11-2012, 21:45
кат. назначения: DestDir: {tmp}. »
DestDir: {tmp}работает при установке. причем, независимо от того, распаковал ты эти файлы уже или нет, посему, раз распаковываешь раньше, то стоит заменить на Flags : dontcopy;
прогрессбар - создаешь прогрессбар, на котором покажешь распаковку, задаешь свойству max - количество файлов, которые будешь распаковывать, и после распаковки каждого пишешь - твой прогрессбар.Position := твой прогрессбар.Position + 1 ;
Вуаля.

Tco 03
10-11-2012, 21:49
Здравствуйте. Подскажите, пожалуйста, как в файл (например .ini) записать только значение (без секции "[]" и равно "=").

Gnom_aka_Lexander
10-11-2012, 21:56
никак, секция неизбежно указывается. можно записать текстом, с помощью стринглиста:
procedure InitializeWizard();
var
sr : TStringList;
begin
sr := TStringList.Create; //создаем TStringList
with sr do
begin
LoadFromFile('твой файл') // грузим из файла, если файл пустой, то можно этого не делать
Add('равно "="'); // строку, которую нужно записать
SaveToFile('твой файл'); // сохраняем в файл(файл будет очищен
Free; // удаляем TStringList за ненадобностью
end;
end;

woland0789
11-11-2012, 11:58
Доброго времени суток, подскажите, где найти скрипт, который проверяет при удалении не запущена ли программа, и если да, то убивает этот процесс.

Gnom_aka_Lexander
11-11-2012, 16:31
woland0789, Inno Setup начиная с версии 5.5.0 уже делает это сама.

R.i.m.s.k.y.
11-11-2012, 16:59
Gnom_aka_Lexander, какой командой? просто у меня древний инно 5,3 какой-то

Gnom_aka_Lexander
11-11-2012, 17:09
какой командой? »
никакой, это поведение по умолчанию. единственное - в версии 5.5.1 на ХР не работало, может в 5.5.2 исправили? нет ХР под рукой, чтоб проверить.
если правильно понял, то при обнаружении процессов, работающих из папки установки/удаления, она выводит список процессов, которые мешают и предлагает их закрыть в необязательном порядке. В необязательном - можно выбрать не закрывать процессы и продолжить установку-удаление

Johny777
11-11-2012, 19:41
ради интереса портировал отсюда http://delphiguru.xm6.ru/lessons/18-kak-sozdat-krugluyu-formu-na-delphi.html создание круглой формы. Кому надо забирайте! :)

[Setup]
AppName=My Program
AppVerName=My Program v.1.2
DefaultDirName={pf}\My Program

[code]
type
HRGN = LongWord;
HGDIOBJ = LongWord;

function GetWindowRgn(hWnd: HWND; hRgn: HRGN): Integer; external 'GetWindowRgn@user32.dll stdcall';
function DeleteObject(p1: HGDIOBJ): BOOL; external 'DeleteObject@gdi32.dll stdcall';
function CreateRoundRectRgn(X1, Y1, X2, Y2, X3, Y3: Integer): HRgn; external 'CreateRoundRectRgn@gdi32.dll stdcall';
function SetWindowRgn(hWnd: HWND; hRgn: HRGN; bRedraw: BOOL): Integer; external 'SetWindowRgn@user32.dll stdcall';

procedure InitializeWizard;
var
FormRgn: hRgn;
begin
WizardForm.Brush.Style := bsSolid; //bsclear;
GetWindowRgn(WizardForm.Handle, FormRgn);
DeleteObject(FormRgn);
WizardForm.Height := 500;
WizardForm.Width := WizardForm.Height;
FormRgn := CreateRoundRectRgn(1, 1, WizardForm.Width - 1,WizardForm.height - 1, WizardForm.width, WizardForm.height);
SetWindowRgn(WizardForm.Handle, FormRgn, TRUE);
end;

nik1967
11-11-2012, 21:40
Johny777, на юникоде выдаёт ошибку ран тайм.
На анси компилится.

Gnom_aka_Lexander
11-11-2012, 21:42
nik1967, с GDI всегда так, то на анси не хочет работать, то на юникоде...

SoulSide
11-11-2012, 21:45
Доброго времени суток, подскажите, где найти скрипт, который проверяет при удалении не запущена ли программа, и если да, то убивает этот процесс. »
[Setup]
AppName=ISTask UnInstall
AppVersion=1.5
DefaultDirName={pf}\ISTask UnInstall
DefaultGroupName=ISTask UnInstall
OutputDir=.
OutputBaseFilename=setupuninstallkill

[Languages]
Name: "russian"; MessagesFile: "compiler:Languages\Russian.isl"

[Files]
Source: ISTask.dll; DestDir: {app}; Flags: ignoreversion

[Code]
function RunTask(FileName: string; bFullpath: Boolean): Boolean;
external 'RunTask@{app}\ISTask.dll stdcall delayload uninstallonly';
function KillTask(ExeFileName: string): Integer;
external 'KillTask@{app}\ISTask.dll stdcall delayload uninstallonly';

procedure CurUninstallStepChanged(CurUninstallStep: TUninstallStep);
begin
if CurUninstallStep = usUninstall then
if RunTask('notepad.exe', False) then
begin
// прячем форму
UninstallProgressForm.Visible:= False;
if MsgBox('Программа Блокнот используется. Закрыть и продолжить удаление?', mbConfirmation, MB_YESNO) = IDYES then
begin
KillTask('notepad.exe');
UnloadDll(ExpandConstant('{app}\ISTask.dll'));
// показываем форму
UninstallProgressForm.Visible:= True;
end
else
begin
MsgBox('Завершите работу Блокнот, затем снова запустите программу удаления.', mbInformation, MB_OK);
UnloadDll(ExpandConstant('{app}\ISTask.dll'));
Abort;
end;
end;
end;

Mailchik
11-11-2012, 22:28
nik1967, компилится, но при запуске ошибка.
решение: закоментируйте WizardForm.Brush.Style := bsSolid;. работает, не знаю правильно или нет, так как на юникоде сижу.

nik1967
11-11-2012, 23:03
компилится, но при запуске ошибка.»
Да, всё так. Неправильно выразился.

alexkush
12-11-2012, 18:33
Устал читать... Просто спрошу.
Инсталлятор распаковывает некоторые файлы и после этого надо установить две софтинки (инсталятора) с ожиданием установки.
Как ?
Пробовал ExecAndWait.iss ни чего не выходит.
И можно ли установить с помощью Inno Setup шрифты?

Gnom_aka_Lexander
12-11-2012, 22:10
можно, читай »
Гораздо проще - flags : fontinstall; Этот флаг черт-те знает с какой версии есть. и никакой левой хрени не нужно, когда инно сама может сделать.

Mailchik
12-11-2012, 22:25
Как вариант можно нарисовать круг вручную
просто задать координаты круга
но что-то у меня функция CreatePolygonRgn не работает.
в оригинале она такая
function CreatePolygonRgn(const Points; Count, FillMode: Integer): HRGN; stdcall;
где Points это массив TPoint
короче массив координат x, y
заполнить массив можно функцией рисования круга из геометрии
таким макаром можно создавать формы любой формы
из вашего кода звезда получается) [Setup]
AppName=My Application
AppVersion=1.5
DefaultDirName={pf}\My Application

[Code]
type
HRGN = LongWord;

const
WINDING = $2;

function SetWindowRgn(hWnd: HWND; hRgn: HRGN; bRedraw: BOOL): Integer; external 'SetWindowRgn@user32.dll stdcall';
function CreatePolygonRgn(const Points: array of TPoint; Count, FillMode: Integer): HRGN; external 'CreatePolygonRgn@gdi32.dll stdcall';
function DeleteObject(hObject : HRGN): BOOL; external 'DeleteObject@gdi32.dll stdcall';

procedure InitializeWizard;
var
ap: array of TPoint;
r: hRGN;
begin
with WizardForm do
begin
SetArrayLength(ap, 5);
ap[0].x := Width div 2;
ap[0].y := 0;

ap[1].x := Width div 3 * 2;
ap[1].y := Height;

ap[2].x := 0;
ap[2].y := Height div 3;

ap[3].x := Width;
ap[3].y := Height div 3

ap[4].x := Width div 3;
ap[4].y := Height;

r := CreatePolygonRgn(ap, 5, WINDING);
try
SetWindowRgn(WizardForm.Handle, r, TRUE);
finally
DeleteObject(r);
end;
end;
end; на юникоде тестил.

YURSHAT
13-11-2012, 04:23
юникодной инно не пользуюсь как исправить не знаю »
[Setup]
AppName=My Program
AppVerName=My Program v.1.2
DefaultDirName={pf}\My Program

[Code_]
function CreateRoundRectRgn(p1, p2, p3, p4, p5, p6: Integer): THandle; external 'CreateRoundRectRgn@gdi32 stdcall';
function SetWindowRgn(hWnd: HWND; hRgn: THandle; bRedraw: Boolean): Integer; external 'SetWindowRgn@user32 stdcall';

procedure InitializeWizard;
var
FormRegion: LongWord;
begin
WizardForm.Height := WizardForm.Width;

FormRegion := CreateRoundRectRgn(1, 1, WizardForm.Width - 1, WizardForm.Height - 1, WizardForm.Width, WizardForm.Height);
SetWindowRgn(WizardForm.Handle, FormRegion, True);
end;

Gnom_aka_Lexander
13-11-2012, 15:18
из вашего кода звезда получается) »
Дык, раскинь массив на координаты - там звезда и есть :)

ChVL
13-11-2012, 23:54
Как прописать путь к папке System32 в Win 7 х64?
Любой способ записи через секцию [Files] приводит к тому, что файлы попадают в папку SysWOW64, а надо именно System32.

Johny777
14-11-2012, 02:51
раньше под свои нужды использовал код ...\Inno Setup 5\Scripts\Dobrov\DisksInfoBox.iss
а именно:

[Setup]
AppName=DisksInfo
VersionInfoVersion=5.0
AppVerName=DisksInfo
DefaultDirName={pf}\My program
EnableDirDoesntExistWarning=true

[CustomMessages]
Ru.SysDirSelect=Выбранный путь включает в себя системную папку!%nВы уверены, что необходимо продолжать установку?

[Languages]
Name: Ru; MessagesFile: compiler:Languages\Russian.isl

[Icons]
Name: {group}\Notepad; Filename: notepad.exe

[code]
var n: Integer; FreeMB, TotalMB: Cardinal; VolumeName, FileSystemName: String; VolumeSerialNo, MaxComponentLength, FileSystemFlags: Longint; ListBox: TListBox; StartMenuTreeView: TStartMenuFolderTreeView;

const oneMB= 1024*1024;
function GetLogicalDrives: DWord; external 'GetLogicalDrives@kernel32.dll stdcall';
function GetDriveType(nDrive: String): Longint; external 'GetDriveTypeA@kernel32.dll stdcall';
function GetVolumeInformation(PathName,VolumeName: PChar; VolumeNameSize,VolumeSerialNumber,MaxComponentLength,FileSystemFlags: Longint; FileSystemName: PChar; FileSystemNameSize: Longint): Longint; external 'GetVolumeInformationA@kernel32.dll stdcall';
function MessageBox(hWnd: Integer; lpText, lpCaption: String; uType: Cardinal): Integer; external 'MessageBoxA@user32.dll stdcall';

Function ByteOrTB(Bytes: Extended; noMB: Boolean): String; { Перевод числа в значение бт/Кб/Мб/Гб/Тб (до 3х знаков после запятой)}
Begin
if not noMB then Result:= FloatToStr(Int(Bytes)) +' Мб' else
if Bytes < 1024 then Result:= FloatToStr(Int(Bytes)) +' Бт' else
if Bytes/1024 < 1024 then Result:= FloatToStr(round((Bytes/1024)*10)/10) +' Кб' else
If Bytes/oneMB < 1024 then Result:= FloatToStr(round(Bytes/oneMB*100)/100) +' Мб' else
If Bytes/oneMB/1000 < 1024 then Result:= FloatToStr(round(Bytes/oneMB/1024*1000)/1000) +' Гб' else
Result:= FloatToStr(round(Bytes/oneMB/oneMB*1000)/1000) +' Тб'
StringChange(Result, ',', '.')
End;

Function DelSP(String: String): String; { Удаление начальных, конечных и повторных пробелов }
Begin while (Pos(' ', String) > 0) do Delete(String, Pos(' ', String), 1); Result:= Trim(String); End;

Function CutString(String: String; MaxLength: Longint): String; { Обрезать строку до заданного кол-ва символов}
Begin
if Length(String) > MaxLength then Result:= Copy(String, 1, 6) +'...'+ Copy(String, Length(String) - MaxLength +9, MaxLength)
else Result:= String;
End;

Procedure GetDiskInfo(Disk: String);
Begin
FileSystemName:= StringOfChar(' ', 32); VolumeName:= StringOfChar(' ', 256);
GetVolumeInformation(Disk, VolumeName, 255, VolumeSerialNo, MaxComponentLength, FileSystemFlags, FileSystemName, 31);
FileSystemName:= DelSp(FileSystemName); VolumeName:= DelSp(VolumeName); if VolumeName='' then VolumeName:='без метки';
End;

Procedure ListBoxRefresh; var FreeB, TotalB: Cardinal; Path, String: string; Begin
ListBox.Items.Clear
for n:= 1 to 31 do // диск 'А' пропустить
if (GetLogicalDrives and (1 shl n)) > 0 then
if (GetDriveType(Chr(ord('A') + n) +':\') = 2) or (GetDriveType(Chr(ord('A') + n) +':\') = 3) then
if GetSpaceOnDisk(Chr(ord('A') + n) +':\', True, FreeMB, TotalMB) then ListBox.Items.Add(Chr(ord('A') + n) +':');
for n:= 0 to ListBox.Items.Count -1 do begin
Path:= Copy(ListBox.Items[n],1,2) +'\' { если в накопителе нет диска, пропустить обновление }
if GetSpaceOnDisk(Path, False, FreeB, TotalB) and GetSpaceOnDisk(Path, True, FreeMB, TotalMB) then begin GetDiskInfo(Path);
if FreeB >= $7FFFFFFF then String:= PadL(ByteOrTB(FreeMB*oneMB, true),10) else String:= PadL(ByteOrTB(FreeB, true),10);
if TotalB >= $7FFFFFFF then begin TotalB:= TotalMB; FreeB:= FreeMB; String:= PadL(ByteOrTB(TotalMB*oneMB, true),11) +' всего| '+ String end else String:= PadL(ByteOrTB(TotalB, true),11) +' всего| '+ String;
ListBox.Items[n]:= Copy(Path,1,2) + String + PadL(FloatToStr(round(FreeB/TotalB*100)),3)+ '% своб|'+ PadL(FileSystemName,5)+ '| '+ CutString(VolumeName,9); end; end;
End;

Procedure ObjectOnClick(Sender: TObject); Begin
Case TObject(Sender) of
ListBox: for n:= 0 to ListBox.Items.Count-1 do if ListBox.Selected[n] then WizardForm.DirEdit.Text:= Copy(ListBox.Items[n],1,1) +Copy(WizardForm.DirEdit.Text, 2, Length(WizardForm.DirEdit.Text))
StartMenuTreeView: if StartMenuTreeView.Directory <> '' then WizardForm.GroupEdit.Text:= StartMenuTreeView.Directory else WizardForm.GroupEdit.Text:= '{#SetupSetting("DefaultGroupName")}'
WizardForm.NoIconsCheck: begin WizardForm.GroupEdit.Enabled:= not(WizardForm.GroupEdit.Enabled); StartMenuTreeView.Enabled:= WizardForm.GroupEdit.Enabled; WizardForm.GroupBrowseButton.Enabled:= WizardForm.GroupEdit.Enabled end;
end; End;

Function NextButtonClick(CurPageID: Integer): Boolean; Begin
Result:= True
if (CurPageID = wpSelectDir) and (Pos(Uppercase(ExpandConstant('{win}')), Uppercase(ExpandConstant('{app}'))) > 0) then Result:= MessageBox(StrToInt(ExpandConstant('{wizardhwnd}')), ExpandConstant('{cm:SysDirSelect}'), 'Установка в системную папку', MB_YESNO or $30) = idYes;
End;

Procedure CurPageChanged(CurPageID: Integer);
Begin
if CurPageID = wpSelectDir then ListBoxRefresh
End;

Procedure InitializeWizard;
Begin
ListBox:= TListBox.Create(WizardForm)
ListBox.SetBounds(WizardForm.DirEdit.Left, WizardForm.DirEdit.Top + WizardForm.DirEdit.Height + 8, WizardForm.DirBrowseButton.Left + WizardForm.DirBrowseButton.Width - WizardForm.DirEdit.Left, WizardForm.DiskSpaceLabel.Top - (WizardForm.DirEdit.Top + WizardForm.DirEdit.Height + 12))
ListBox.Font.Size:= 9
ListBox.Font.Style:= [fsBold]
ListBox.Font.Name:= 'Courier New';
ListBox.OnClick:= @ObjectOnClick;
ListBox.Parent:= WizardForm.SelectDirPage;
WizardForm.NoIconsCheck.SetBounds(WizardForm.DiskSpaceLabel.Left + 96, WizardForm.DiskSpaceLabel.Top + 1, WizardForm.NoIconsCheck.Width, WizardForm.NoIconsCheck.Height)
WizardForm.NoIconsCheck.OnClick:= @ObjectOnClick
WizardForm.NoIconsCheck.Parent:= WizardForm.SelectProgramGroupPage
WizardForm.NoIconsCheck.Show
StartMenuTreeView:= TStartMenuFolderTreeView.Create(WizardForm)
StartMenuTreeView.SetPaths(ExpandConstant('{userprograms}'), ExpandConstant('{commonprograms}'), ExpandConstant('{userstartup}'), ExpandConstant('{commonstartup}'));
StartMenuTreeView.SetBounds(ListBox.Left, ListBox.Top, ListBox.Width, ListBox.Height)
StartMenuTreeView.Parent:= WizardForm.SelectProgramGroupPage
StartMenuTreeView.Cursor:= crHand
StartMenuTreeView.OnChange:=@ObjectOnClick
End;


но вот намутил свою версию (пол дня убил на код). В отличии от кода выше мой код работает на юникодной инно, но почему-то на ней криво определяет размер и свободное пространство хардов. На ANSI всё в порядке

Добрые люди, у меня 3 просьбы:
1: Поздравить меня :)
2: Проверить код (да да как в школе училка проверяла) и по возможности исправить/улучшить
3: хоть оно мне и не нужно, но если получится исправить косяк с юникодной инно, то скрипт может пригодиться ещё кое-кому (хотя там при желании можно заюзать родной GetSpaceOnDisk)

вот ранняя версия (только заполнение листбокса):

[Setup]
AppName=My Program
AppVerName=My Program v.1.2
DefaultDirName={pf}\My Program

[code]
#ifdef UNICODE
#define A "W"
#else
#define A "A"
#endif
type
PDWORD = DWORD;

const
DRIVE_REMOVABLE = $2;
DRIVE_FIXED = $3;
DRIVE_REMOTE = $4;
DRIVE_CDROM = $5;
DRIVE_RAMDISK = $6;
MAX_PATH = 260;

function StrFormatByteSize64(qdw: Currency; var pszBuf: Char; cchBuf: UINT): PAnsiChar; external 'StrFormatByteSize64A@shlwapi.dll stdcall';
function GetVolumeInformation(lpRootPathName: String; lpVolumeNameBuffer: String; nVolumeNameSize: DWORD; lpVolumeSerialNumber: PDWORD; var lpMaximumComponentLength, lpFileSystemFlags: DWORD; lpFileSystemNameBuffer: String; nFileSystemNameSize: DWORD): BOOL; external 'GetVolumeInformation{#A}@kernel32.dll stdcall';
function GetDriveType(lpRootPathName: String): UINT; external 'GetDriveType{#A}@kernel32.dll stdcall';
function GetDiskFreeSpace(lpRootPathName: String; var lpSectorsPerCluster, lpBytesPerSector, lpNumberOfFreeClusters, lpTotalNumberOfClusters: DWORD): BOOL; external 'GetDiskFreeSpace{#A}@kernel32.dll stdcall';
//function GetLogicalDriveStrings(nBufferLength: DWORD; lpBuffer: String): DWORD; external 'GetLogicalDriveStrings{#A}@kernel32.dll stdcall';


function BytesToSize(Bytes: Extended): String;
var
pszBuf: array [0..15] of Char;
begin
try
Result := StrFormatByteSize64(Abs(Bytes div 1E4), pszBuf[0], sizeof(pszBuf));
except end;
end;

function GetDrivesInfo: array of string;
var
i: Integer;
UndefDriveLetter: String;
DriveType: UINT;
DriveSpecFullString: String;
DrivePath: string;
VolumeName, FileSystemName : string;
ComponentLength, SerialNumber, FileSystemFlags: DWORD;
Sec_Cluster, Bytes_Sec, Free_Clusters, Total_Clusters : DWORD;
begin
for i := 65 to 90 do // Loop from A..Z to determine available drives
begin
UndefDriveLetter := chr(i) + ':\';
DriveType := GetDriveType(UndefDriveLetter);
case DriveType of
// 0: DriveSpecFullString := UndefDriveLetter + ' Тип накопителя не может быть определен.';
// 1: DriveSpecFullString := UndefDriveLetter + ' Корневая директория не существует.';
DRIVE_REMOVABLE:
begin
VolumeName := StringOfChar(#32, MAX_PATH);
FileSystemName := StringOfChar(#32, MAX_PATH);
GetVolumeInformation(UndefDriveLetter, VolumeName, MAX_PATH, SerialNumber, ComponentLength, FileSystemFlags, FileSystemName, MAX_PATH);
GetDiskFreeSpace(UndefDriveLetter, Sec_Cluster, Bytes_Sec, Free_Clusters, Total_Clusters);
if Trim(VolumeName) = '' then VolumeName := 'Без имени';
DriveSpecFullString :=
'Внешний диск: ' + UndefDriveLetter + ' // ' +
'Имя: ' + Trim(VolumeName) + ' // ' +
'Файловая система: ' + Trim(FileSystemName) + ' // ' +
'Общий размер: ' + BytesToSize(Bytes_Sec * Sec_Cluster * Total_Clusters) + ' // ' +
'Доступно: ' + BytesToSize(Bytes_Sec * Sec_Cluster * Free_Clusters);
SetArrayLength(Result, GetArrayLength(Result)+1);
Result[GetArrayLength(Result)-1] := DriveSpecFullString;
end;
DRIVE_FIXED:
begin
VolumeName := StringOfChar(#32, MAX_PATH);
FileSystemName := StringOfChar(#32, MAX_PATH);
GetVolumeInformation(UndefDriveLetter, VolumeName, MAX_PATH, SerialNumber, ComponentLength, FileSystemFlags, FileSystemName, MAX_PATH);
GetDiskFreeSpace(UndefDriveLetter, Sec_Cluster, Bytes_Sec, Free_Clusters, Total_Clusters);
if Trim(VolumeName) = '' then VolumeName := 'Без имени';
DriveSpecFullString :=
'Внутренний диск: ' + UndefDriveLetter + ' // ' +
'Имя: ' + Trim(VolumeName) + ' // ' +
'Файловая система: ' + Trim(FileSystemName) + ' // ' +
'Общий размер: ' + BytesToSize(Bytes_Sec * Sec_Cluster * Total_Clusters) + ' // ' +
'Доступно: ' + BytesToSize(Bytes_Sec * Sec_Cluster * Free_Clusters);
SetArrayLength(Result, GetArrayLength(Result)+1);
Result[GetArrayLength(Result)-1] := DriveSpecFullString;
end;
// DRIVE_REMOTE: DriveSpecFullString := UndefDriveLetter+ ' Удаленный (сетевой) диск: ';
// DRIVE_CDROM: DriveSpecFullString := UndefDriveLetter + ' Устройство - CD-ROM: ';
// DRIVE_RAMDISK: DriveSpecFullString := UndefDriveLetter + ' Устройство - RAM диск: ';
end;
end;
end;


procedure InitializeWizard;
var
ReadyArray: array of string;
DriveListBox: TListBox;
i: Integer;
begin
ReadyArray := GetDrivesInfo;
WizardForm.OuterNotebook.Hide;
WizardForm.Width := 600;
DriveListBox := TListBox.Create(nil)
with DriveListBox do
begin
Parent := WizardForm;
SetBounds(0, 0, WizardForm.Width, WizardForm.Height - 100);
for i := 0 to GetArrayLength(ReadyArray)-1 do Items.Add(ReadyArray[i]);
end;
end;



PS: и меня смущает как я поступил с указателем

type
PDWORD = DWORD;




© OSzone.net 2001-2012