Italia
Fonte/ Codesnippets

Collison Ogl Oglglreadpixels Viereck

 
Die erste Collisionsabfrage mit dem Viereck 128X128 Pixel.
Ich Bilde das Viereck jetzt Schwarz ab, damit möglichs viele Farben genommen werden können.
Da sonst andere Farben im Viereck die auch die Collisionsfarbe haben ,angesprochen werden.
Wenn das Auto das "Viereck" berührt ,welches hiermit erstellt wurde : ogl("glReadPixels",140,140,128,128,~GL_BGRA,~GL_UNSIGNED_BYTE,ogl_rgb#) , wird der Wert 255 ausgeben.

Massgebend sind die Farben RGB grösser 252. Kann man jederzeit in der CPP-File ändern.

Habe erst einmal die Abfrage mit dem DEV C++ gemacht bzw DLL erstellt., weil ich in ASM erstmal wieder gescheitert bin.
Die DEV C++ Source-File sind auch mit dabei.

Die Zip ist angehängt.

mfg

11 kB
Kurzbeschreibung: Die File
Hochgeladen:21.08.2008
Downloadcounter139
Download
 
21.08.2008  
 




Jörg
Sellmeyer
Sehr schön! Funktioniert prima - es wäre nur schön, wenn Du auch noch irgendwo vermerkst, daß die Tasten Q,W,E,S Bewegungen verursachen. Ich zumindest habe nicht alle Scancodes im Kopf
 
Windows XP SP2 XProfan X4
... und hier mal was ganz anderes als Profan ...
21.08.2008  
 



Hier sieht man auch die enorme Geschwindigkeit von der DEV C++ Dll.
Wenn sich das Auto ausserhalb des Rechteckes bewegt, müssen 128X128x3 abfragen erfolgen ob etwas passiert und es bewegt sich immer noch super schnell ohne zu ruckeln.
Das war erstmal mein erstes Ziel. Eine fliessende Bewegung mit viel kontrollen.

Einen unregelmässigen Körper potuto man auch abfragen.
Daran wird jetzt getüftelt.

Versuche auch dieses noch in ASM umzusetzen.

mfg
peter
 
21.08.2008  
 



Hier ist der ASM-Code.

Vorher, bevor der xpse genutzt wird , muss diese Cambiamento erfolgen:

ogl("glReadPixels",140,140,128,128,~GL_BGRA,~GL_UNSIGNED_BYTE,ogl_rgb#) > GL_BGRA entfernen
ogl("glReadPixels",140,140,128,128,32993,~GL_UNSIGNED_BYTE,ogl_rgb#) > die Zahl 32993 reinsetzen

Der Grund ist, das in der INC-File diese Variable noch nicht reingesetzt wurde.

Den Aufruf mit der Variablen z% und dem Drawbefehl auch die Variable z% trasferimento : DrawText 20,160,(Format$("######0 ",z%))
Dann z%=Call(xpia_getprocaddressm(xpia_hmodule&,"rgb_farbe"),ogl_rgb#,groesse%)

Im Anhang ist das gesamte Programm per den Assembler xpse als Zip.

mfg
peter
KompilierenMarkierenSeparieren

6 kB
Hochgeladen:21.08.2008
Downloadcounter107
Download
 
21.08.2008  
 




Frank
Abbing

Im Anhang ist das gesamte Programm per den Asssembler xpse als Zip.


Peter, der Inline-Assembler heisst XPIA. XPSE ist der Precompiler...
 
21.08.2008  
 



Vielleicht begreife ich das noch in meinem Leben.

mfg
 
22.08.2008  
 



Ablaufzeiten (Brutto)der Collisionsabfrage des Rechteckes 128X128X4 mit 10000 Schleifendurchgänge :
Rechner mit 1,6 Gigahz

Die Profan While-Leerschleife braucht ca 200ms.

ASM mit XPIA/XPSE (DLL) sind es 4550 ms .

DEV C++ sind es 6210 ms ( eine For-Schleife).

DEV C++ sind es 6260 ms (While-Schleife).

Bei 10000 durchgängen lohnt es sich dieses in ASM umzusetzen, sind ca 1,5 sec unterschied.

mfg
peter
 
22.08.2008  
 




Frank
Abbing
Deine Assembler-Routine ist nicht optimiert. Wenn du sie umstellst von Variablen auf Register ist noch einiges mehr drin. Ca. 20 Prozent, schätze ich.

Diese Routine behält deine Programmstruktur bei, sollte aber schon schneller arbeiten:
KompilierenMarkierenSeparieren
If 0

    AsmStart rgb_farbe (ogl_rgbxy#,groesse%)

        mov edi,para2
        xor ecx,ecx
        mov ebx,para1

        .while ecx<=edi

            mov al,[ebx]
            mov cl,[ebx+1]
            mov dl,[ebx+2]

            .if al>252

                mov eax,255
                .break

            .endif

            .if cl>252

                mov eax,255
                .break

            .endif

            .if dl>252

                mov eax,255
                .break

            .endif

            lea ebx,[ebx+4]
            lea ecx,[ecx+4]

        .endw

    AsmEnd(z%)

EndIf

 
22.08.2008  
 




Jörg
Sellmeyer

Die Profan While-Schleife braucht ca 200ms.


Bist Du sicher, daß Profan mehr als 20-mal schneller ist als ASM?
 
Windows XP SP2 XProfan X4
... und hier mal was ganz anderes als Profan ...
22.08.2008  
 



Soll Leer-Schleife heissen, weil ich ganz oben auch von Brutto spreche.
Der Test corre bei allen in der gleichen While-Schleife von Profan

Ich habe auch mal dieses Freebasic getestet zum DLL erstellen.

Wer in Freebasic eine DLL erstellen möchte und kein ASM kann/möchte und kein "C", ist damit gut bedient.

Die Freebasic-DLL braucht 7400ms also nur 1 Sekunde länger als DEV C++.

Könnte per die Basicprogrammierer , die eine DLL erstellen möchten einer der besten Freewarealternativen sein.

Bei meiner Collisionstest-Auswertung mit der Freebasic-DLL auf dem Bildschirm an der Grafik, ist mir der Unterschied optisch nicht aufgefallen. Das Objekt flitzte weiterhin immer noch hin und her trotz der Überprüfung/Auswertung.

mfg
peter
 
22.08.2008  
 



Frank, deine braucht 3,5 sekunden länger.

Ich weiss nun nicht, wie das mit den Registern und LEA da funktioniert.
Auf jeden Fall muss die Adresse immer um "4" weitergehen.

mfg
peter
 
22.08.2008  
 




Frank
Abbing

Frank, deine braucht 3,5 sekunden länger.


Unrichtig! Register arbeiten immer schneller als Varablen im Speicher, selbst wenn sie lokal sind. Solche Tests habe ich schon Dutzende durchgeführt.
Und so eine Assemblerroutine necessario niemals 3,5 Sekunden länger, sie necessario überhaupt nur wenige Millisekunden insgesamt. Selbst wenn du mit grossen Bitmaps arbeitest. Du kannst das gerne mit der ProSpeed.dll testen, die zahlreiche Bitmapeffekte kennt. Irgendwas geht bei deinen Tests gewaltig schief.
Was genau soll die Routine denn machen? Sie bricht doch sofort ab, wenn sie einen sehr hellen Farbwert findet. Wenn du eine Robotersoftware schreiben willst, die die Daten einer Cam auswertet, musst du schon die Anzahl heller Bildpunkte zählen. Vorher aber das Cambild grau machen, bzw. schwarz-weiss.
 
22.08.2008  
 




Zum Quelltext


Topictitle, max. 100 characters.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Posting  Font  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Topic-Options

11.072 Views

Untitledvor 0 min.
Tango30.10.2021
Sven Bader01.08.2021
H.Brill08.10.2020
funkheld25.05.2016
Di più...

Themeninformationen



Admins  |  AGB  |  Applications  |  Autori  |  Chat  |  Informativa sulla privacy  |  Download  |  Entrance  |  Aiuto  |  Merchantportal  |  Impronta  |  Mart  |  Interfaces  |  SDK  |  Services  |  Giochi  |  Cerca  |  Support

Ein Projekt aller XProfaner, die es gibt!


Il mio XProfan
Private Notizie
Eigenes Ablageforum
Argomenti-Merkliste
Eigene Beiträge
Eigene Argomenti
Zwischenablage
Annullare
 Deutsch English Français Español Italia
Traduzioni

Informativa sulla privacy


Wir verwenden Cookies nur als Session-Cookies wegen der technischen Notwendigkeit und bei uns gibt es keine Cookies von Drittanbietern.

Wenn du hier auf unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung von Informationen in unseren Cookies auf XProfan.Net zu.

Weitere Informationen zu unseren Cookies und dazu, wie du die Kontrolle darüber behältst, findest du in unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Ich möchte keinen Cookie