vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
sevAniGif - als kostenlose Vollversion auf unserer vb@rchiv CD Vol.5  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück
Rubrik: Verschiedenes / Sonstiges   |   VB-Versionen: VB2008, VB2010, VB201231.12.14
Ermittlung des Computertyps

Es wird eine Funktion gezeigt, die die Ermittlung des Chassis-Typs des Computers gestattet.

Autor:   Dietrich HerrmannBewertung:     [ Jetzt bewerten ]Views:  5.960 
ohne HomepageSystem:  Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Wer eventuell für eine Anzeige den Chassis-Typ des Computers benötigt, kann diesen mit der nachfolgend gezeigten Funktion ermitteln.

Dazu braucht man zunächst eine Enumeration:

' die Chassistypen von Computern
Public Enum ChassisTypes
  Other
  Unknown
  Desktop
  Low_Profile_Desktop
  Pizza_Box
  Mini_Tower
  Tower
  Portable
  Laptop
  Notebook
  Hand_Held
  Docking_Station
  All_in_One
  Sub_Notebook
  Space_Saving
  Lunch_Box
  Main_System_Chassis
  Expansion_Chassis
  SubChassis
  Bus_Expansion_Chassis
  Peripheral_Chassis
  Storage_Chassis
  Rack_Mount_Chassis
  Sealed_Case_PC
End Enum

... und dann die Funktion:

''' <summary>
''' Ermittelt den Computertyp
''' </summary>
''' <returns>Feld mit den Chassisnamen</returns>
Public Function GetModelType() As String()
  Dim objWMIService, objChassis, objItem As Object, i As Short
  Dim strComputer As String = "."
  Dim names() As String = [Enum].GetNames(GetType(ChassisTypes))
  Dim res(0) As String
 
  objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" _
    & strComputer & "\root\cimv2")
  objChassis = objWMIService.ExecQuery _
    ("Select * from Win32_SystemEnclosure")
 
  For Each objChassis In objChassis
    For Each objItem In objChassis.ChassisTypes
      res(i) = Replace(names(objItem - 1), "_", " ")
      ReDim Preserve res(i)
      ' Debug.Print("Chassis Type: " & res(i))
      i += 1
    Next 
  Next 
 
  Return res
End Function

Einfach aufrufen:

Dim pcTypes() As String = GetModelType()

... und bspw. in einer ListBox anzeigen:

If pcTypes.Length > 0 Then
  ListBox1.Items.AddRange(pcTypes)
End If

Dieser Tipp wurde bereits 5.960 mal aufgerufen.

Voriger Tipp   |   Zufälliger Tipp   |   Nächster Tipp

Über diesen Tipp im Forum diskutieren
Haben Sie Fragen oder Anregungen zu diesem Tipp, können Sie gerne mit anderen darüber in unserem Forum diskutieren.

Neue Diskussion eröffnen

nach obenzurück


Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
   

Druckansicht Druckansicht Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel