Beiträge von Kaliber

    So sieht das denke sinnvoller aus:


    PS: Extra ohne returns gelöst, damit du unten drunter noch Code ausführen kannst :)

    alter AUGENKREBS

    Augenkrebs ist vllt das falsche Wort, ist ja ein ganz normaler Dialog.


    Finde das Casino sehr gelungen. Egal ob man gewinnt oder verliert, da das clientseitig geregelt wird, wird das als Cheat erkannt und das Geld resettet :D


    Lustiges Feature auf jeden Fall :)


    Ansonsten joa...euch fehlt im Namen Startbonus & Statsback, denke so würdet ihr noch einige Leute holen können :)

    Ganz einfach: Punkt vor Strich.

    Daher wird zuerst multiplizierst und danach geteilt. xD

    Das ist absoluter Quatsch.


    Die Prioritäten sind so: Zuerst /, dann *, dann - und dann +.


    Der Fehler liegt hier, dass Pawn, ähnlich wie C versucht Integer zu teilen und diese werden nicht in floats konvertiert, für die Gleitkommaoperationen und das führt zu dem 0 ergebnis.


    Da 9/100 = 0 ist und 0*35 = 0


    Ergo so schreiben:


    C
    printf("Okay here go: %d",floatround(9.0 / 100.0 * 35.0,floatround_round));

    Oder Operationen dafür nutzen:


    C
    printf("Okay here go: %d",floatround(floatmul(floatdiv(9,100),35),floatround_round));

    Dann ist das auch ersichtlicher, was zuerst gerechnet werden soll.

    SetDynamicObjectMaterialText

    Die Definition davon lautet:


    C
    native SetDynamicObjectMaterialText(STREAMER_TAG_OBJECT objectid, materialindex, const text[], materialsize = OBJECT_MATERIAL_SIZE_256x128, const fontface[] = "Arial", fontsize = 24, bold = 1, fontcolor = 0xFFFFFFFF, backcolor = 0, textalignment = 0);

    Im Gegensatz zu SetObjectMaterialText ist hier der Text und der materialindex vertauscht. Wieso auch immer das Incognito so gemacht hat, weil das einfach alle und jedes mal abfuckt xD


    Einfach so schreiben:


    C
    SetDynamicObjectMaterialText(City[2][ProductionText], 0, string3, 140, "Arial", 45, 1, 0xFFFFFFFF, 0xFFB40404, 1);


    Bei dem Anderen kommt kein Fehler, weil es nicht auf ein "Dynamic-Objekt" bezieht, sondern auf ein normales Objekt.

    Halte mich für altmodisch, aber unter einem Tutorial verstehe ich etwas anderes, als wenn ich jemandem wortlos zuschaue wie er Code schreibt.


    Das erinnert eher an ein ASMR Video 😅


    Es würde ja einfach reichen ein Github-Repo zu machen, wo du deinen Code hochlädst, wenn du diesen nicht einmal erklärst.


    Es gibt ja nicht einmal Kommentare und keinen Link zum Source-Code.


    Also meiner Meinung nach, sollte man in Tutorials reden und den Code erklären, wieso man es so macht und nicht anders, was man sich dabei denkt und wie das alles zusammenhängt, sonst schreibt man das blind ab und dann ist ja auch keinem geholfen.

    Der Befehl ergibt ja vorne und hinten auch keinen Sinn.


    item ist immer leer hahaha xD

    menge ist immer 0

    und params ist verfälscht durch die "items" eingabe :D


    ...Jetzt mal nichts für ungut, aber schau dir doch ein paar Basics mal an oder lass dir etwas Nachhilfe geben...


    Darauf warten, dass jetzt jemand den Befehl für dich macht und das dann beim Nächsten auch usw bringt doch niemandem wirklich was.

    Versuche es mal mit Code-Logik:


    Naja, da scheint ja alles richtig zu sein, da ist der Wert ja auf 1.


    Wie rufst du denn saveCar auf?


    Das wäre mal interessant, in welchem Kontext die Funktion aufgerufen wird.

    Ja, weil besitzer immernoch auf 0 ist.


    Da wird der falsche Wert genommen.


    Wie setzt du denn von PlayerInfo die db_id?


    Beim laden dieser id machst du irgendwas falsch...

    Was soll ich den als Verschlüsselung nutzen hab das halt von Jeffry genommen :D und wie würde ich das denn jetzt noch ändern (ist es einfach und fix oder recht schwer)?

    1. Ist das keine Verschlüsselung, lies dir meinen Beitrag (den ich doch eben verlinkt habe) dazu mal durch.


    2. Jeffry solltest das Tutorial mal in dieser Hinsicht updaten, das wirklich keine gute Idee, das so zu gestalten.


    Was genau soll ich jetzt in der Tabelle aus der DB löschen (die beiden Fahrzeuge)?

    Exakt.

    1. Bitte nutze kein MD5 beim Passwort, da kannst du es eig schon gleich bleiben lassen...Zudem steht dein Passwort jetzt hier in Klartext...(Hash Verfahren genauer erklärt)
    2. Das Select query ist nun richtig, aber ich sehe kein Insert query. Lösche nochmal die Sachen aus der Tabelle und mache das von Neu.
    3. Lösche jetzt die Log Datei, damit sie gleich frisch erstellt wird.


    Zeige dann nochmal den Log.

    Da musst du den Fehler suchen.


    Entweder bei der Zuweisung oder bei der Speicherung...printe es halt mal oder zeig uns mal deinen MySQL Log.


    (Den aktivierst du indem du unter OnGameModeInit mysql_log(ALL); eingibst)

    besitzer = 0 in der Datenbank sieht irgendwie falsch aus, meinst du nicht? :D


    Da ist wohl beim Speichern oder der ID Zuweisung was schief gelaufen...

    bei einem gmx sind diese leider komplett weg

    Super.


    ...wie sieht die Datenbank aus?

    Was sagen die Querys?

    Hast du irgendwas geprintet?


    Du solltest immer Informationen liefern, einfach nur sagen ja, bla bla geht nicht, da kann man dir meist nicht helfen.