Merhaba arkadaşlar. Bir sorum olacakdı sizlere. Outlook la birlikte çalışan bir programın işlem esnasında bir mesaj penceresi çıkıyor ve bu mesajı "Yes" diyerek işlemin tamamlanmasını sağlıyoruz. (çıkan mesaj ekranında "microsoft outlook ile fax gönderiyorsunuz. onaylıyormusunuz" gibi bir mesaj. Bu mesajı engelleme gibi bir şansımız yokmuş)
sorum : Bu mesajı geçmesi için bir program yapılma şansı varmı ? (Mesaj çıktıgı zaman aktif pencere kendisi oluyor)
bu işlemi günde 100 - 150 kere yapmak zorunda kalıyoruz. Baya bir iş aksamasına neden oluyor.
Yardımlarınız için teşekkür ederim
Çıkan mesajı aracı bir programla otomatik olarak geçmek
Forum kuralları
Forum kurallarını okuyup, uyunuz!
Forum kurallarını okuyup, uyunuz!
Merhaba,
İnşallah derdinize derman olacak parçaları birleştirmeyi başarmışızdır.
Boş bir projedeyken, öncelikle forumdan bulduğum aşağıdaki kodu Delphi de File /New /Unit
seçenekleri kullanarak kaydedin. Çıkan sayfadaki tüm yazıları silip aşağıdaki kodu copy paste ile yapıştırın.
Kodun uzunluğu gözünüzü korkutmasın
onlarla pek işiniz olmayacak.
Ben windows apilerini tam bilmediğim için kulağımızı diğer taraftan gösteriyoruz.
Ctrl+S ile dosyayı sndkey32tr.pas olarak kaydedin. Daha sonra form1 deyken sağ tuş ile view as text seçeneğini seçin. Oradaki yazıları silip aşağıdakini copy paste yapın.
Ctrl +S ye basıp Pencere_Ismi.dfm olarak kaydedin.Yine sağ tuşla View as form olarak seçin . Ctrl + f12 ye basarak project1 i seçin . oradakileri silip aşağıdaki kodu yapıştırın.
Ctrl +s ile pencere_ismi.dpr olarak kaydedin.
Kayıt bittikten sonra Ctrl+f12 ile Unit1 i seçiyoruz. Oradakileri silip aşağıdaki kodu kopy paste ile yapıştırıyoruz.
File /save as ile pencere_ismiu.pas olarak kaydediyoruz.
*********** devamı var. ************
____________________
ofenX
İnşallah derdinize derman olacak parçaları birleştirmeyi başarmışızdır.
Boş bir projedeyken, öncelikle forumdan bulduğum aşağıdaki kodu Delphi de File /New /Unit
seçenekleri kullanarak kaydedin. Çıkan sayfadaki tüm yazıları silip aşağıdaki kodu copy paste ile yapıştırın.
Kodun uzunluğu gözünüzü korkutmasın

Ben windows apilerini tam bilmediğim için kulağımızı diğer taraftan gösteriyoruz.

Kod: Tümünü seç
(*
32-bit Delphi için SendKeys rutini.
Ken Henderson tarafından yazılmıştır.
Copyright (c) 1995 Ken Henderson
Bu unit Visual Basic'in çok popüler iki rutinini taklit eder:
Sendkeys ve AppActicate. Sendkeys ilk olarak PChar bir parametre
alır ve ikinci olarak mantıksal bir parametre alır, aşağıdaki gibi:
SendKeys('BirYazi', Wait);
Yukarıdaki BirYazi tuş adlarından ve değiştiricilerden oluşmuş bir
string'tir. Bununla geçerli odağa tuş yollanabilir ve Wait değişkeni
veya değeri SendKeys fonksiyonunun her tuş mesajının işlenmesinin
beklenmesini sağlar. Daha fazla bilgi için aşağıdaki tabloya bakın.
AppActivate sadece PChar tipinde bir parametre alır, ki:
AppActivate('PencereAdi');
Yukarıdaki PencereAdi odaklanılacak pencere adıdır.
SendKeys Visual Basic'teki yazımı aşağıda da belirtildiği gibi destekler.
Desteklene değiştiriciler:
+ = Shift
^ = Control
% = Alt
Karakterler ve tuş adları parantezler kullanılarak gruplanabilir.
Örneğin '+abc' sadece 'a' harfine shift işlemi uygular, '+(abc)' ise
üç karaktere de shift işlemini uygular.
Desteklenen özel karakterler
~ = Enter
( = Değiştirici gruplama başlangıcı (üste bakın)
) = Değiştirici gruplama sonu (üste bakın)
{ = Tuş adı başlangıcı (alta bakın)
} = Tuş adı sonu (alta bakın)
Desteklenen karakterler:
Yazılabilen tüm karakterler desteklenmektedir. Yukarıda listelenen
değiştirici tuşlar ve süslü parantezlerle belirtilmemiş yazılar
normal yazı olarak gönderilir.
Desteklenen tuş adları (Bunları süslü parantez içine alın):
BKSP, BS, BACKSPACE
BREAK
CAPSLOCK
CLEAR
DEL
DELETE
DOWN
END
ENTER
ESC
ESCAPE
F1
F2
F3
F4
F5
F6
F7
F8
F9
F10
F11
F12
F13
F14
F15
F16
HELP
HOME
INS
LEFT
NUMLOCK
PGDN
PGUP
PRTSC
RIGHT
SCROLLLOCK
TAB
UP
Bir tuşu takip eden bir boşluk ve numara, gönderilecek tuşun verilen
numara kez gönderileceğini belirtir. (e.g., {left 6}).
*)
unit sndkey32tr;
interface
Uses SysUtils, Windows, Messages;
Function SendKeys(SendKeysString : PChar; Wait : Boolean) : Boolean;
function AppActivate(WindowName : PChar) : boolean;
{Buffer for working with PChar's}
const
WorkBufLen = 40;
var
WorkBuf : array[0..WorkBufLen] of Char;
implementation
type
THKeys = array[0..pred(MaxLongInt)] of byte;
var
AllocationSize : integer;
(*
Converts a string of characters and key names to keyboard events and
passes them to Windows.
Example syntax:
SendKeys('abc123{left}{left}{left}def{end}456{left 6}ghi{end}789', True);
*)
Function SendKeys(SendKeysString : PChar; Wait : Boolean) : Boolean;
type
WBytes = array[0..pred(SizeOf(Word))] of Byte;
TSendKey = record
Name : ShortString;
VKey : Byte;
end;
const
{Array of keys that SendKeys recognizes.
If you add to this list, you must be sure to keep it sorted alphabetically
by Name because a binary search routine is used to scan it.}
MaxSendKeyRecs = 41;
SendKeyRecs : array[1..MaxSendKeyRecs] of TSendKey =
(
(Name:'BACKSPACE'; VKey:VK_BACK),
(Name:'BKSP'; VKey:VK_BACK),
(Name:'BREAK'; VKey:VK_CANCEL),
(Name:'BS'; VKey:VK_BACK),
(Name:'CAPSLOCK'; VKey:VK_CAPITAL),
(Name:'CLEAR'; VKey:VK_CLEAR),
(Name:'DEL'; VKey:VK_DELETE),
(Name:'DELETE'; VKey:VK_DELETE),
(Name:'DOWN'; VKey:VK_DOWN),
(Name:'END'; VKey:VK_END),
(Name:'ENTER'; VKey:VK_RETURN),
(Name:'ESC'; VKey:VK_ESCAPE),
(Name:'ESCAPE'; VKey:VK_ESCAPE),
(Name:'F1'; VKey:VK_F1),
(Name:'F10'; VKey:VK_F10),
(Name:'F11'; VKey:VK_F11),
(Name:'F12'; VKey:VK_F12),
(Name:'F13'; VKey:VK_F13),
(Name:'F14'; VKey:VK_F14),
(Name:'F15'; VKey:VK_F15),
(Name:'F16'; VKey:VK_F16),
(Name:'F2'; VKey:VK_F2),
(Name:'F3'; VKey:VK_F3),
(Name:'F4'; VKey:VK_F4),
(Name:'F5'; VKey:VK_F5),
(Name:'F6'; VKey:VK_F6),
(Name:'F7'; VKey:VK_F7),
(Name:'F8'; VKey:VK_F8),
(Name:'F9'; VKey:VK_F9),
(Name:'HELP'; VKey:VK_HELP),
(Name:'HOME'; VKey:VK_HOME),
(Name:'INS'; VKey:VK_INSERT),
(Name:'LEFT'; VKey:VK_LEFT),
(Name:'NUMLOCK'; VKey:VK_NUMLOCK),
(Name:'PGDN'; VKey:VK_NEXT),
(Name:'PGUP'; VKey:VK_PRIOR),
(Name:'PRTSC'; VKey:VK_PRINT),
(Name:'RIGHT'; VKey:VK_RIGHT),
(Name:'SCROLLLOCK'; VKey:VK_SCROLL),
(Name:'TAB'; VKey:VK_TAB),
(Name:'UP'; VKey:VK_UP)
);
{Extra VK constants missing from Delphi's Windows API interface}
VK_NULL=0;
VK_SemiColon=186;
VK_Equal=187;
VK_Comma=188;
VK_Minus=189;
VK_Period=190;
VK_Slash=191;
VK_BackQuote=192;
VK_LeftBracket=219;
VK_BackSlash=220;
VK_RightBracket=221;
VK_Quote=222;
VK_Last=VK_Quote;
ExtendedVKeys : set of byte =
[VK_Up,
VK_Down,
VK_Left,
VK_Right,
VK_Home,
VK_End,
VK_Prior, {PgUp}
VK_Next, {PgDn}
VK_Insert,
VK_Delete];
const
INVALIDKEY = $FFFF {Unsigned -1};
VKKEYSCANSHIFTON = $01;
VKKEYSCANCTRLON = $02;
VKKEYSCANALTON = $04;
UNITNAME = 'SendKeys';
var
UsingParens, ShiftDown, ControlDown, AltDown, FoundClose : Boolean;
PosSpace : Byte;
I, L : Integer;
NumTimes, MKey : Word;
KeyString : String[20];
procedure DisplayMessage(Message : PChar);
begin
MessageBox(0,Message,UNITNAME,0);
end;
function BitSet(BitTable, BitMask : Byte) : Boolean;
begin
Result:=ByteBool(BitTable and BitMask);
end;
procedure SetBit(var BitTable : Byte; BitMask : Byte);
begin
BitTable:=BitTable or Bitmask;
end;
Procedure KeyboardEvent(VKey, ScanCode : Byte; Flags : Longint);
var
KeyboardMsg : TMsg;
begin
keybd_event(VKey, ScanCode, Flags,0);
If (Wait) then While (PeekMessage(KeyboardMsg,0,WM_KEYFIRST, WM_KEYLAST, PM_REMOVE)) do begin
TranslateMessage(KeyboardMsg);
DispatchMessage(KeyboardMsg);
end;
end;
Procedure SendKeyDown(VKey: Byte; NumTimes : Word; GenUpMsg : Boolean);
var
Cnt : Word;
ScanCode : Byte;
NumState : Boolean;
KeyBoardState : TKeyboardState;
begin
If (VKey=VK_NUMLOCK) then begin
NumState:=ByteBool(GetKeyState(VK_NUMLOCK) and 1);
GetKeyBoardState(KeyBoardState);
If NumState then KeyBoardState[VK_NUMLOCK]:=(KeyBoardState[VK_NUMLOCK] and not 1)
else KeyBoardState[VK_NUMLOCK]:=(KeyBoardState[VK_NUMLOCK] or 1);
SetKeyBoardState(KeyBoardState);
exit;
end;
ScanCode:=Lo(MapVirtualKey(VKey,0));
For Cnt:=1 to NumTimes do
If (VKey in ExtendedVKeys)then begin
KeyboardEvent(VKey, ScanCode, KEYEVENTF_EXTENDEDKEY);
If (GenUpMsg) then
KeyboardEvent(VKey, ScanCode, KEYEVENTF_EXTENDEDKEY or KEYEVENTF_KEYUP)
end else begin
KeyboardEvent(VKey, ScanCode, 0);
If (GenUpMsg) then KeyboardEvent(VKey, ScanCode, KEYEVENTF_KEYUP);
end;
end;
Procedure SendKeyUp(VKey: Byte);
var
ScanCode : Byte;
begin
ScanCode:=Lo(MapVirtualKey(VKey,0));
If (VKey in ExtendedVKeys)then
KeyboardEvent(VKey, ScanCode, KEYEVENTF_EXTENDEDKEY and KEYEVENTF_KEYUP)
else KeyboardEvent(VKey, ScanCode, KEYEVENTF_KEYUP);
end;
Procedure SendKey(MKey: Word; NumTimes : Word; GenDownMsg : Boolean);
begin
If (BitSet(Hi(MKey),VKKEYSCANSHIFTON)) then SendKeyDown(VK_SHIFT,1,False);
If (BitSet(Hi(MKey),VKKEYSCANCTRLON)) then SendKeyDown(VK_CONTROL,1,False);
If (BitSet(Hi(MKey),VKKEYSCANALTON)) then SendKeyDown(VK_MENU,1,False);
SendKeyDown(Lo(MKey), NumTimes, GenDownMsg);
If (BitSet(Hi(MKey),VKKEYSCANSHIFTON)) then SendKeyUp(VK_SHIFT);
If (BitSet(Hi(MKey),VKKEYSCANCTRLON)) then SendKeyUp(VK_CONTROL);
If (BitSet(Hi(MKey),VKKEYSCANALTON)) then SendKeyUp(VK_MENU);
end;
{Implements a simple binary search to locate special key name strings}
Function StringToVKey(KeyString : ShortString) : Word;
var
Found, Collided : Boolean;
Bottom, Top, Middle : Byte;
begin
Result:=INVALIDKEY;
Bottom:=1;
Top:=MaxSendKeyRecs;
Found:=false;
Middle:=(Bottom+Top) div 2;
Repeat
Collided:=((Bottom=Middle) or (Top=Middle));
If (KeyString=SendKeyRecs[Middle].Name) then begin
Found:=True;
Result:=SendKeyRecs[Middle].VKey;
end else begin
If (KeyString>SendKeyRecs[Middle].Name) then Bottom:=Middle
else Top:=Middle;
Middle:=(Succ(Bottom+Top)) div 2;
end;
Until (Found or Collided);
If (Result=INVALIDKEY) then DisplayMessage('Invalid Key Name');
end;
procedure PopUpShiftKeys;
begin
If (not UsingParens) then begin
If ShiftDown then SendKeyUp(VK_SHIFT);
If ControlDown then SendKeyUp(VK_CONTROL);
If AltDown then SendKeyUp(VK_MENU);
ShiftDown:=false;
ControlDown:=false;
AltDown:=false;
end;
end;
begin
AllocationSize:=MaxInt;
Result:=false;
UsingParens:=false;
ShiftDown:=false;
ControlDown:=false;
AltDown:=false;
I:=0;
L:=StrLen(SendKeysString);
If (L>AllocationSize) then L:=AllocationSize;
If (L=0) then Exit;
While (I<L) do begin
case SendKeysString[I] of
'(' : begin
UsingParens:=True;
Inc(I);
end;
')' : begin
UsingParens:=False;
PopUpShiftKeys;
Inc(I);
end;
'%' : begin
AltDown:=True;
SendKeyDown(VK_MENU,1,False);
Inc(I);
end;
'+' : begin
ShiftDown:=True;
SendKeyDown(VK_SHIFT,1,False);
Inc(I);
end;
'^' : begin
ControlDown:=True;
SendKeyDown(VK_CONTROL,1,False);
Inc(I);
end;
'{' : begin
NumTimes:=1;
If (SendKeysString[Succ(I)]='{') then begin
MKey:=VK_LEFTBRACKET;
SetBit(Wbytes(MKey)[1],VKKEYSCANSHIFTON);
SendKey(MKey,1,True);
PopUpShiftKeys;
Inc(I,3);
Continue;
end;
KeyString:='';
FoundClose:=False;
While (I<=L) do begin
Inc(I);
If (SendKeysString[I]='}') then begin
FoundClose:=True;
Inc(I);
Break;
end;
KeyString:=KeyString+Upcase(SendKeysString[I]);
end;
If (Not FoundClose) then begin
DisplayMessage('No Close');
Exit;
end;
If (SendKeysString[I]='}') then begin
MKey:=VK_RIGHTBRACKET;
SetBit(Wbytes(MKey)[1],VKKEYSCANSHIFTON);
SendKey(MKey,1,True);
PopUpShiftKeys;
Inc(I);
Continue;
end;
PosSpace:=Pos(' ',KeyString);
If (PosSpace<>0) then begin
NumTimes:=StrToInt(Copy(KeyString,Succ(PosSpace),Length(KeyString)-PosSpace));
KeyString:=Copy(KeyString,1,Pred(PosSpace));
end;
If (Length(KeyString)=1) then MKey:=vkKeyScan(KeyString[1])
else MKey:=StringToVKey(KeyString);
If (MKey<>INVALIDKEY) then begin
SendKey(MKey,NumTimes,True);
PopUpShiftKeys;
Continue;
end;
end;
'~' : begin
SendKeyDown(VK_RETURN,1,True);
PopUpShiftKeys;
Inc(I);
end;
else begin
MKey:=vkKeyScan(SendKeysString[I]);
If (MKey<>INVALIDKEY) then begin
SendKey(MKey,1,True);
PopUpShiftKeys;
end else DisplayMessage('Invalid KeyName');
Inc(I);
end;
end;
end;
Result:=true;
PopUpShiftKeys;
end;
{AppActivate
This is used to set the current input focus to a given window using its
name. This is especially useful for ensuring a window is active before
sending it input messages using the SendKeys function. You can specify
a window's name in its entirety, or only portion of it, beginning from
the left.
}
var
WindowHandle : HWND;
function EnumWindowsProc(WHandle: HWND; lParam: LPARAM): BOOL; export; stdcall;
var
WindowName : array[0..MAX_PATH] of char;
begin
{Can't test GetWindowText's return value since some windows don't have a title}
GetWindowText(WHandle,WindowName,MAX_PATH);
Result := (StrLIComp(WindowName,PChar(lParam), StrLen(PChar(lParam))) <> 0);
If (not Result) then WindowHandle:=WHandle;
end;
function AppActivate(WindowName : PChar) : boolean;
begin
try
Result:=true;
WindowHandle:=FindWindow(nil,WindowName);
If (WindowHandle=0) then EnumWindows(@EnumWindowsProc,Integer(PChar(WindowName)));
If (WindowHandle<>0) then begin
SendMessage(WindowHandle, WM_SYSCOMMAND, SC_HOTKEY, WindowHandle);
SendMessage(WindowHandle, WM_SYSCOMMAND, SC_RESTORE, WindowHandle);
SetForegroundWindow(WindowHandle);
end else Result:=false;
except
on Exception do Result:=false;
end;
end;
end.
Ctrl+S ile dosyayı sndkey32tr.pas olarak kaydedin. Daha sonra form1 deyken sağ tuş ile view as text seçeneğini seçin. Oradaki yazıları silip aşağıdakini copy paste yapın.
Kod: Tümünü seç
object Form1: TForm1
Left = 192
Top = 114
Width = 696
Height = 480
Caption = 'Form1'
Color = clBtnFace
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'MS Sans Serif'
Font.Style = []
OldCreateOrder = False
PixelsPerInch = 96
TextHeight = 13
object Label1: TLabel
Left = 136
Top = 56
Width = 61
Height = 13
Caption = 'Pencere Adı '
end
object Button2: TButton
Left = 144
Top = 128
Width = 225
Height = 73
Caption = 'Timeri aç'
TabOrder = 0
OnClick = Button2Click
end
object Button3: TButton
Left = 144
Top = 224
Width = 217
Height = 65
Caption = 'timeri kapat'
TabOrder = 1
OnClick = Button3Click
end
object Edit1: TEdit
Left = 264
Top = 56
Width = 121
Height = 21
TabOrder = 2
end
object Timer1: TTimer
Enabled = False
Interval = 100
OnTimer = Timer1Timer
Left = 56
Top = 24
end
end
Kod: Tümünü seç
program Pencere_ismi;
uses
Forms,
pencere_ismiu in 'pencere_ismiu.pas' {Form1},
sndkey32tr in 'sndkey32tr.pas';
{$R *.res}
begin
Application.Initialize;
Application.CreateForm(TForm1, Form1);
Application.Run;
end.
Kayıt bittikten sonra Ctrl+f12 ile Unit1 i seçiyoruz. Oradakileri silip aşağıdaki kodu kopy paste ile yapıştırıyoruz.
Kod: Tümünü seç
unit pencere_ismiu;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, ExtCtrls, StdCtrls,sndkey32tr;
type
TForm1 = class(TForm)
Timer1: TTimer;
Button2: TButton;
Button3: TButton;
Edit1: TEdit;
Label1: TLabel;
procedure Timer1Timer(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
private
{ Private declarations }
public
hsonrakiwinmsg:hwnd;
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.Timer1Timer(Sender: TObject);
var
HFare: HWND;
isaretleyici : TPOINT;
baslikUzunlugu : integer;
baslik : string;
h : THandle;
begin
GetCursorPos(isaretleyici);
HFare := WindowFromPoint(isaretleyici);
if HFare = HSonrakiWinMsg then Exit;
HSonrakiWinMsg := HFare;
baslikUzunlugu := SendMessage(HFare, WM_GETTEXTLENGTH, 0, 0) + 1;
SetLength(baslik, baslikUzunlugu);
SendMessage(HSonrakiWinMsg, WM_GETTEXT, baslikUzunlugu,LongInt(@baslik[1]));
Caption:=inttostr(HSonrakiWinMsg)+' '+baslik;
if length(edit1.text)>0 then
begin
h := FindWindow( nil, PChar(Edit1.text));
if h <> 0 then
begin
appactivate(pchar(Edit1.text) );
sendkeyS('{ENTER}',true);
end;
end;
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
timer1.Enabled:=true;
end;
procedure TForm1.Button3Click(Sender: TObject);
begin
timer1.Enabled:=false;
end;
end.
*********** devamı var. ************
____________________
ofenX
Öğrenmek ve öğretmek, akıntıya karşı yüzmek gibidir ilerleyemediğiniz taktirde gerilersiniz.
Şimdi programı çalıştırabiliriz. Program çalışınca timer kapalıdır. Enterlemek istediğiniz pencereyi açın o pencere açıkken bizim programdaki timeri açın. Mouse u enterlenecek pencerenin başlığına götürünce bizim programın başlığına ismini yazacaktır.
Artık timerı kapatabilirsiniz. Edit kısmına o pencerenin ismini yazın. Timer ı açık bırakın. Artık istediğinizin olması lazım.
Ayrıca aşağıdaki linklerde de bu konudaki bilgilere bakabilirsiniz.
viewtopic.php?t=1357&highlight=g%FCvenlik+uyar%FDs%FD
viewtopic.php?t=1587&highlight=sendkey
Bu arada şöyle bir soru aklıma takıldı. Saygıdeğer hocalarımız bizimle paylaşırsa sevinirim. Bu program pencere başlığına göre çalışıyor. Ya farklı programlarda aynı pencere başlığı varsa ??? Apileri pek kullanmadığım için şöyle bir çözüm olabilir mi ? X.exe adlı programın Y adlı penceresinin başlığı şeklinde olamaz mı. Handle numarası derseniz. Program her çalıştığında handle numarası değişiyor.
Değerli hocalarımızın katkılarını bekliyorum.
*** Başlıklardaki boşluklara dikkat edin. Ben bir programımı deneyeyim dedim. Çalışma Yılı yazıyorum çalışmıyor. Sonra en sona bir boşluk ekledim çalıştı.
İyi çalışmalar.
__________________
ofenX
Artık timerı kapatabilirsiniz. Edit kısmına o pencerenin ismini yazın. Timer ı açık bırakın. Artık istediğinizin olması lazım.
Ayrıca aşağıdaki linklerde de bu konudaki bilgilere bakabilirsiniz.
viewtopic.php?t=1357&highlight=g%FCvenlik+uyar%FDs%FD
viewtopic.php?t=1587&highlight=sendkey
Bu arada şöyle bir soru aklıma takıldı. Saygıdeğer hocalarımız bizimle paylaşırsa sevinirim. Bu program pencere başlığına göre çalışıyor. Ya farklı programlarda aynı pencere başlığı varsa ??? Apileri pek kullanmadığım için şöyle bir çözüm olabilir mi ? X.exe adlı programın Y adlı penceresinin başlığı şeklinde olamaz mı. Handle numarası derseniz. Program her çalıştığında handle numarası değişiyor.
Değerli hocalarımızın katkılarını bekliyorum.
*** Başlıklardaki boşluklara dikkat edin. Ben bir programımı deneyeyim dedim. Çalışma Yılı yazıyorum çalışmıyor. Sonra en sona bir boşluk ekledim çalıştı.
İyi çalışmalar.
__________________
ofenX
Öğrenmek ve öğretmek, akıntıya karşı yüzmek gibidir ilerleyemediğiniz taktirde gerilersiniz.