|
| |

Visual-Basic Einsteiger| Collisionserkennung ala VB@RCHIV | |  | | Autor: unbekannt | | Datum: 24.03.02 19:37 |
| Hi MasterM,
so, da ist sie die Klasse clsWall!
Es folgt gleich weiteres.
In das Projekt ein KLassenmodul einfügen, die Klasse: clsWall nennen, diesen Code einfügen, die Class ist fertig.
Eigenschaften:
Target = das gerade bewegte Object
Wall = die Mauer, die die Klasse repräsentiert
WallID = Eine Nummer, die die Wall erhalten wird
Collision = Wahr, wenn Collision, False wenn nein
Methode:
MoveTarget = hier wird die Wall bei jedem Spielzug angesprochen .
Leider blieb von Deinem Code gar nichts übrig, weil die Collisionserkennung rein mit WINAPI gelöst ist.
<code>
Private Declare Function GetWindowRect Lib "user32" _
(ByVal hWnd As Long, lpRect As RECT) As Long
Private Declare Function CreateRectRgnIndirect Lib "gdi32" _
(lpRect As RECT) As Long
Private Declare Function RectInRegion Lib "gdi32" _
(ByVal hRgn As Long, lpRect As RECT) As Long
Private Declare Function SetRect Lib "user32" _
(lpRect As RECT, ByVal X1 As Long, _
ByVal Y1 As Long, ByVal X2 As Long, _
ByVal Y2 As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" _
(ByVal hObject As Long) As Long
Private Type RECT
Left As Long
Top As Long
Right As Long
Bottom As Long
End Type
Private tmpWall As Object
Private tmpTarget As Object
Private tmpWallID As Long
Private tmpColl As Boolean
'Objekt Wall
Public Property Get Wall() As Object
Set Wall = tmpWall
End Property
Public Property Set Wall(ByRef oWall As Object)
Set tmpWall = oWall
End Property
'Objekt Target
Public Property Get Target() As Object
Set Target = tmpTarget
End Property
Public Property Set Target(ByRef oTarget As Object)
Set tmpTarget = oTarget
End Property
Public Sub MoveTarget()
Dim tRect As RECT
Dim wRect As RECT
Dim hRgn As Long
tmpColl = False
GetWindowRect tmpTarget.hWnd, tRect
GetWindowRect tmpWall.hWnd, wRect
hRgn = CreateRectRgnIndirect(wRect)
If RectInRegion(hRgn, tRect) <> 0 Then
tmpColl = True
End If
DeleteObject hRgn
End Sub
Public Property Get WallID() As Long
WallID = tmpWallID
End Property
Public Property Let WallID(ByVal vNewValue As Long)
tmpWallID = vNewValue
End Property
Public Property Get Collision() As Boolean
Collision = tmpColl
End Property</code> bis gleich,
cu
Lordchen |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
vb@rchiv CD Vol.6 vb@rchiv Vol.6
Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
Online-Update-Funktion Entwickler-Vollversionen u.v.m.Jetzt zugreifen Tipp des Monats Oktober 2025 Matthias KozlowskiUmlaute konvertierenErsetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) Neu! sevCoolbar 3.0 
Professionelle Toolbars im modernen Design!
Mit sevCoolbar erstellen Sie in wenigen Minuten ansprechende und moderne Toolbars und passen diese optimal an das Layout Ihrer Anwendung an (inkl. große Symbolbibliothek) - für VB und MS-Access Weitere Infos
|
| |
|
Copyright ©2000-2025 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
|
|