cette petite fonction retourne le numero du port serie en connaisant le nom. C'est l'extrapolation de la fonction EnumPorts du composant Tcomport.
Source / Exemple :
function NumeroPort(nomport:string):string;
var
KeyHandle: HKEY;
ErrCode, Index: Integer;
ValueName, Data: string;
ValueLen, DataLen, ValueType: DWORD;
begin
ErrCode := RegOpenKeyEx(
HKEY_LOCAL_MACHINE,
'HARDWARE\DEVICEMAP\SERIALCOMM',
0,
KEY_READ,
KeyHandle);
if ErrCode <> ERROR_SUCCESS then
raise Exception.Create('erreur d''ouverture');
Index := 0;
repeat
ValueLen := 256;
DataLen := 256;
SetLength(ValueName, ValueLen);
SetLength(Data, DataLen);
ErrCode := RegEnumValue(
KeyHandle,
Index,
PChar(ValueName),
{$IFDEF DELPHI_4_OR_HIGHER}
Cardinal(ValueLen),
{$ELSE}
ValueLen,
{$ENDIF}
nil,
@ValueType,
PByte(PChar(Data)),
@DataLen);
if ErrCode = ERROR_SUCCESS then
begin
SetLength(Data, DataLen);
if pos(nomport,valuename)<>0 then result:=data;
Inc(Index);
end
else
until (ErrCode <> ERROR_SUCCESS) ;
RegCloseKey(KeyHandle);
end;
Conclusion :
cette source fait suite à une question posée sur le forum
pour obetnir la liste des descriptions des ports:
sur une forme mettre une listbox
en ligne 40 rajouter:
form1.ListBox1.Items.Add(valuename);// donne la liste des descriptions
et
procedure TForm1.FormCreate(Sender: TObject);
begin
NumeroPort('');
end;
lancer le programme et la listbox vous donne la totalité des ports serie installés
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.