Avatar billede morteeart Nybegynder
17. november 2004 - 11:58 Der er 4 kommentarer og
1 løsning

Lukke application

Hej

I koden, ved Private Sub DeleteKnap_Click()
Der fjerne den korrekt nok objektet fra listen, men den lukker ikke den valgte app. hvorfor ?

[source]

Public Class Form1
    Inherits System.Windows.Forms.Form
    Dim EnTekst As String

#Region "ProcessList Funktionen"
    Function getRunningProcessList(ByVal strComputer)
        ' Hvis intet computernavn bliver specifikeret kører programmet på den lokale maskine
        If Len(strComputer) = 0 Then
            strComputer = Environment.MachineName
        End If

        On Error Resume Next
        Dim ProcessSet
        ' Henten listen af kørende processor fra Windows Management Instrumentation
        ProcessSet = GetObject("winmgmts:{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2").ExecQuery("select * from Win32_Process")
        If (Not Err.Number = 0) Then
            getRunningProcessList = "Kunne ikke retunerer processlist for computer: " & strComputer & vbCrLf & vbCrLf & "Fejl " & Err.Number & " " & Err.Description
        End If

        ' Laver tekst output til CheckedListBox
        Dim strProcessList
        Dim Process
        Dim strPlist
        Label1.Text = ""
        SpywareArea.Items.Clear()
        Label1.Text = "Processor kørende på computer: " & strComputer
        For Each Process In ProcessSet
            strProcessList = strProcessList & Process.Description & vbTab & vbTab
            strPlist = Process.Description & vbTab & vbTab & Process.ExecutablePath
            SpywareArea.Items().Add(strPlist, CheckState.Unchecked)
            If Len(Process.Description) < 8 Then
                strProcessList = strProcessList & vbTab
            End If
            strProcessList = strProcessList & Process.ExecutablePath & vbCrLf
        Next

        ' Retunerer resultatet
        getRunningProcessList = strProcessList
    End Function

#End Region

#Region " Windows Form Designer generated code "

    Public Sub New()
        MyBase.New()

        'This call is required by the Windows Form Designer.
        InitializeComponent()

        'Add any initialization after the InitializeComponent() call

    End Sub

    'Form overrides dispose to clean up the component list.
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
        If disposing Then
            If Not (components Is Nothing) Then
                components.Dispose()
            End If
        End If
        MyBase.Dispose(disposing)
    End Sub

    'Required by the Windows Form Designer
    Private components As System.ComponentModel.IContainer

    'NOTE: The following procedure is required by the Windows Form Designer
    'It can be modified using the Windows Form Designer. 
    'Do not modify it using the code editor.
    Friend WithEvents TilfoejKnap As System.Windows.Forms.Button
    Friend WithEvents DeleteKnap As System.Windows.Forms.Button
    Friend WithEvents SpywareArea As System.Windows.Forms.CheckedListBox
    Friend WithEvents Label1 As System.Windows.Forms.Label
    <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
        Dim resources As System.Resources.ResourceManager = New System.Resources.ResourceManager(GetType(Form1))
        Me.TilfoejKnap = New System.Windows.Forms.Button
        Me.SpywareArea = New System.Windows.Forms.CheckedListBox
        Me.DeleteKnap = New System.Windows.Forms.Button
        Me.Label1 = New System.Windows.Forms.Label
        Me.SuspendLayout()
        '
        'TilfoejKnap
        '
        Me.TilfoejKnap.Cursor = System.Windows.Forms.Cursors.Default
        Me.TilfoejKnap.Location = New System.Drawing.Point(256, 416)
        Me.TilfoejKnap.Name = "TilfoejKnap"
        Me.TilfoejKnap.Size = New System.Drawing.Size(80, 24)
        Me.TilfoejKnap.TabIndex = 2
        Me.TilfoejKnap.Text = "Scan"
        '
        'SpywareArea
        '
        Me.SpywareArea.Location = New System.Drawing.Point(24, 32)
        Me.SpywareArea.Name = "SpywareArea"
        Me.SpywareArea.Size = New System.Drawing.Size(816, 364)
        Me.SpywareArea.TabIndex = 3
        '
        'DeleteKnap
        '
        Me.DeleteKnap.Location = New System.Drawing.Point(72, 416)
        Me.DeleteKnap.Name = "DeleteKnap"
        Me.DeleteKnap.Size = New System.Drawing.Size(120, 24)
        Me.DeleteKnap.TabIndex = 4
        Me.DeleteKnap.Text = "Delete Checked"
        '
        'Label1
        '
        Me.Label1.Location = New System.Drawing.Point(24, 8)
        Me.Label1.Name = "Label1"
        Me.Label1.Size = New System.Drawing.Size(480, 16)
        Me.Label1.TabIndex = 5
        '
        'Form1
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)
        Me.BackColor = System.Drawing.SystemColors.Control
        Me.ClientSize = New System.Drawing.Size(864, 478)
        Me.Controls.Add(Me.Label1)
        Me.Controls.Add(Me.DeleteKnap)
        Me.Controls.Add(Me.SpywareArea)
        Me.Controls.Add(Me.TilfoejKnap)
        Me.Font = New System.Drawing.Font("Arial", 8.25!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(0, Byte))
        Me.Icon = CType(resources.GetObject("$this.Icon"), System.Drawing.Icon)
        Me.Name = "Form1"
        Me.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen
        Me.Text = "UnsafeRemover"
        Me.ResumeLayout(False)

    End Sub

#End Region

    Private Sub DeleteKnap_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles DeleteKnap.Click

        Dim i As Integer
        Dim a As Integer
        On Error Resume Next
        i = 0
        a = SpywareArea.CheckedItems.Count
        While i <= a
            If SpywareArea.CheckedItems(i).Checked = True Then
                SpywareArea.Items.Remove(SpywareArea.CheckedItems(i))
                i = i + 1
            End If
        End While

        'Close one of the instances of notepad based on the selected item in the ListView.
        'There are several ways to identify a process. For example,
        'you can use the mainwindowtitle, windowhandle, or processname, depending
        'on your needs. The process ID is used here because there may be several
        'windows open with the same title.

        Dim procID As Integer = System.Convert.ToInt32(SpywareArea.CheckedItems(i))
        Dim tempProc As Process = Process.GetProcessById(procID)
        tempProc.CloseMainWindow()
        tempProc.WaitForExit()

    End Sub

    Private Sub TilfoejKnap_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles TilfoejKnap.Click
        getRunningProcessList("")
    End Sub

End Class

[/source]
Avatar billede visualdeveloper Nybegynder
22. november 2004 - 19:46 #1
Helt neders mellem tempProc.WaitForExit() og End Sub Indsæt
End
Avatar billede visualdeveloper Nybegynder
22. november 2004 - 19:47 #2
Virker det ???
Avatar billede morteeart Nybegynder
22. november 2004 - 19:53 #3
tester i løbet af aftenen..

Du kan vel bare teste i selv i mellemtiden, hvis du er nysgerrig :~)
Avatar billede morteeart Nybegynder
23. november 2004 - 10:35 #4
nej, det gør absolut ingen forskel..

Læg venligt kun svar når du ved / er meget sikker på, at det virker !
Avatar billede morteeart Nybegynder
24. november 2004 - 23:36 #5
har løst opgaven, tak til folkene på IRC

Quakenet:
#visualbasic
#udvikleren.dk
Efnet:
#visualbasic

Det er gode steder at få live support
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester