AOQML Library: Unterschied zwischen den Versionen
(Neuer Eintrag ergänzt: == Über verschiedene Proben (und Szenen) hinweg die *FeP (oder andere Werte) sammeln für anschließende Verwendung / Auswertung ==) |
|||
Zeile 1: | Zeile 1: | ||
Die Bibliothek (library) stellt einige spezielle Funktionen für alle Questautoren und ZB-Schreiber zur Verfügung. | Die Bibliothek (library) stellt einige spezielle Funktionen für alle Questautoren und ZB-Schreiber zur Verfügung. | ||
+ | |||
+ | Kleinere / Simplere Elemente werden als "[[CodeSnippets]]" bezeichnet und verfügen über eine eigene Sammlung. | ||
+ | |||
Jeder Autor kann sich bei Bedarf aus der Bibliothek bedienen. | Jeder Autor kann sich bei Bedarf aus der Bibliothek bedienen. | ||
Version vom 20. Dezember 2023, 09:25 Uhr
Die Bibliothek (library) stellt einige spezielle Funktionen für alle Questautoren und ZB-Schreiber zur Verfügung.
Kleinere / Simplere Elemente werden als "CodeSnippets" bezeichnet und verfügen über eine eigene Sammlung.
Jeder Autor kann sich bei Bedarf aus der Bibliothek bedienen.
Inhaltsverzeichnis
Prüfungen auf Vorhandensein bestimmer Elemente
Prüfung auf Lichtquelle
Wenn du abfragen möchtest, ob ein Held eine Lichtquelle dabei hat, kannst du dies wie folgt tun:
<include target="/lib/_lichtquelle"/> <!-- prüft, ob der Held Licht dabei hat oder Licht entfachen kann -->
<has name="Lichtquelle">
<success>
<!-- Held hat nun Licht -->
</success>
<failure>
<!-- Held tappt im Dunkeln. Entweder keine Lichtquelle dabei oder Probe zum Entfachen ist misslungen. -->
</failure>
</has>
Ergebnis-Variablen:
- Lichtquelle (scope="hero")
(NULL) - Variable ist nicht gesetzt, wenn kein Licht verfügbar Disareg - wenn Disaregstein genutzt Fackel - wenn Pechfackel genutzt Sturmlaterne - wenn Öl-Sturmlaterne genutzt Lampe - wenn Kerzenlaterne oder Öllampe genutzt Kerze - wenn Stundenkerze oder Spannenlange Kerze
- AOQML_Bibliothek_Lichtquelle_feuer_entfacht (scope="scene")
(NULL) - Variable ist nicht gesetzt, wenn kein Feuer entfacht werden musste. ja - Falls Lichtquelle entzündet werden musste und der Held dies erfolgreich getan hat nein - Falls Held nicht die nötigen Materialien hat und nicht per Improvisation (Probe Wildnisleben) eine Lichtquelle entzünden konnte.
Prüfung auf Lichtquelle (Gruppen-Variante)
Wenn du eine Gruppen-Quest/-ZB schreibst, kannst du wie folgt abfragen, ob die Gruppe Licht hat.
<include target="/lib/_lichtquelle"/> <!-- prüft, ob die Gruppe Licht dabei hat oder Licht entfachen kann -->
<has name="Lichtquelle">
<success>
<!-- Gruppe hat nun Licht -->
</success>
<failure>
<!-- Gruppe tappt im Dunkeln. Entweder keine Lichtquelle dabei oder Probe zum Entfachen ist misslungen. -->
</failure>
</has>
Ergebnis-Variablen:
- Lichtquelle (scope="hero") Nicht bei allen Gruppenmitgliedern, sondern nur bei demjenigen, der die Lichtquelle hat.
(NULL) - Variable ist nicht gesetzt, wenn kein Licht verfügbar Disareg - wenn Disaregstein genutzt Fackel - wenn Pechfackel genutzt Sturmlaterne - wenn Öl-Sturmlaterne genutzt Lampe - wenn Kerzenlaterne oder Öllampe genutzt Kerze - wenn Stundenkerze oder Spannenlange Kerze
- AOQML_Bibliothek_Lichtquelle_Gruppe_id_held (scope="quest")
(NULL) - Variable ist nicht gesetzt, wenn kein Licht verfügbar <HeldID> - HeldID desjenigen, der die Lichtquelle trägt
- AOQML_Bibliothek_Lichtquelle_Gruppe_feuer_entfacht (scope="scene")
(NULL) - Variable ist nicht gesetzt, wenn kein Feuer entfacht werden musste. ja - Falls Lichtquelle entzündet werden musste und der Held dies erfolgreich getan hat nein - Falls Helden nicht die nötigen Materialien haben und nicht per Improvisation (Probe Wildnisleben) eine Lichtquelle entzünden konnten.
Prüfung auf Schreibzeug
Wenn du prüfen möchtest, ob der Held entsprechendes Material dabei hat um sich Sachen zu notieren, kannst du dies wie folgt tun:
<include target="/lib/_hatSchreibzeug"/> <!-- prüft, ob der Held Schreibzeug dabei hat -->
<switch name="hatSchreibzeug">
<case val="true">
<!-- Held hat Schreibzeug -->
</case>
<else>
<!-- Held hat kein Schreibzeug -->
</else>
</switch>
Ergebnis-Variablen:
- hatSchreibzeug (scope="quest") 'true' oder 'false'
Prüfung auf Landessprache
Wenn du prüfen möchtest, ob der Held die hiesige Landessprache beherrscht, kannst du dies wie folgt tun:
<include target="/lib/_landessprache" />
<switch name="KannSprache">
<case val="ja">
<p>Du verstehst alles, was hier in <fetch name="Landessprache" /> gesprochen wird.</p>
</case>
<else>
<p>Du kannst den Einwohnern nicht folgen.</p>
</else>
</switch>
Optionale Input-Variablen:
- LandesspracheFeW
Falls diese Variable gesetzt ist, wird der Wert als Mindestanforderung genutzt.
Andernfalls wird FeW 8 als Voraussetzung benutzt.
Ergebnis-Variablen:
- KannSprache (scope="quest")
ja Wenn Held die hiesige Landessprache beherrscht
nein Wenn Held die hiesige Landessprache nicht beherrscht
- Landessprache (scope="quest")
Enthält die Fertigkeit (=Sprache), welche vorort die Landessprache ist
Zählung der selektierten Helden und Aufzählung der selektierten Helden
Die hier vorgestellten Routinen werden ausschließlich für Gruppen eingesetzt.
Wenn du die Anzahl der gerade selektierten Helden zählen willst oder eine hübsche Aufzählung der selektierten Helden - mit Komma und 'und' am Ende - haben willst, dann schreibst du einmalig zu Beginn deiner Quest oder ZB:
<include target="/lib/_heldenaufzaehlung"/>
Um die selektierten Helden zu zählen:
<replay name="AOQML_Bibliothek_zsh"/>
Ergebnis-Variablen:
- AOQML_Bibliothek_ash (scope="quest") Anzahl der selektierten Helden
Um eine schöne Heldenaufzählung der echten Namen zu bekommen:
<replay name="AOQML_Bibliothek_heldenaufzaehlung"/>
Sind Alrik, Kirla und Rikal selektiert liefert die Methode Alrik, Kirla und Rikal, sind nur Alrik und Kirla selektiert, liefert sie Alrik und Kirla, ist nur Alrik selektiert liefert sie nur Alrik.
Um eine schöne Heldenaufzählung der falschen Namen zu bekommen:
<replay name="AOQML_Bibliothek_heldenaufzaehlung_nick"/>
Die Ausgabe entspricht schematisch derjenigen der Aufzählung der echten Namen.
Beispiel
Ein einfaches Beispiel. Die Helden laufen vor einem Wiesel davon.
<include target="/lib/_heldenaufzaehlung"/>
<challenge talent="Athletik" hero-quantity="all">
<success>
<p>Das Wiesel zerrt euch nicht in seinen Bau.</p>
</success>
<failure select-heroes="true">
<replay name="AOQML_Bibliothek_zsh"/>
<p><replay name="AOQML_Bibliothek_heldenaufzaehlung"/> <if name="AOQML_Bibliothek_ash" equals="1" then="wurde" else="wurden"/> von dem Wiesel in seinen Bau gezerrt.</p>
</failure>
</has>
Geldbetrag von Held/Heldengruppe einziehen
Wenn du von einer Heldengruppe einen Geldbetrag einziehen willst, der von soweit möglich von allen zu gleichen Teilen getragen werden soll, ist das wie folgt möglich. Das funktioniert auch mit einem Solo-Helden.
<set name="lib-geldausgabeteilen-sollbetrag" scope="scene" value="200"/>
<include target="/lib/geldausgabeteilen"/>
<switch name="lib-geldausgabeteilen-restbetrag">
<case min="1">
<p>Zwar habt ihr nur <get name="lib-geldausgabeteilen-zahlbetrag"/> zahlen können,
aber zum Glück bleibt es unbemerkt, dass ihr statt der fehlenden
<get name="lib-geldausgabeteilen-restbetrag"/>
ein paar Knöpfe anstatt klingender Münzen übergeben habt.
</p>
</case>
</switch>
Dem Helden bzw. all Helden einer Gruppe wird ein Gesamtbetrag abgezogen. Der tatsächliche Zahlbetrag und der Restbetrag wird in je einer Variable zurückgegeben.
Bei einer Gruppe wird der Betrag möglichst gleichmäßig auf die Helden verteilt wird. Können einzelne Helden ihren Anteil nicht tragen, muss dieser von anderen Helden übernommen werden.
Bei einem Einzelhelden zahlt dieser soviel wie er hat.
Input-Variable:
- lib-geldausgabeteilen-sollbetrag
Die zu zahlende Gesamtsumme.
Ergebnis-Variablen:
- lib-geldausgabeteilen-zahlbetrag (scope="scene")
der tatsächlich bezahlte Betrag als positive Zahl
- lib-geldausgabeteilen-restbetrag (scope="scene")
die Differenz zum Sollbetrag als positive Zahl
Über verschiedene Proben (und Szenen) hinweg die *FeP (oder andere Werte) sammeln für anschließende Verwendung / Auswertung
Wichtig: Das Speichern von Werten sollte von "hoch" nach "klein" (also absteigend) angeordnet werden! Sonst nutzt AOQML immer den ersten (kleinsten) Speicherbefehl.
<?xml version="1.0" encoding="UTF-8"?>
<scene xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://eisentrutz.antamar.eu/aoqml.xsd">
<!-- Hier bitte grundlegende Informationen zur Quest/ZB notieren. -->
<!-- Wenn du lediglich eine Zufallsbegegnung schreiben möchtest, kannst du den Quest-tag entfernen. Dieser wird dann nicht benötigt. -->
<quest status="running"/>
<store name="Speicher" scope="quest">0</store>
<p>Diese Quest dienst als Test für einen Punktepool, bestehend aus den Erfolgen (*FeP) unterschiedlicher Fertigkeitsproben.</p>
<choice target="Probe_1">Weiter zu Probe 1 (Sinnenschärfe).</choice>
</scene>
<?xml version="1.0" encoding="UTF-8"?>
<scene xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://eisentrutz.antamar.eu/aoqml.xsd">
<p>Probe 1. Sinnenschärfe ohne Modifikator.</p>
<challenge talent="Sinnenschärfe" mod="0" >
<success min="5"><set name="Speicher" inc="5" show="none"/></success>
<success min="4"><set name="Speicher" inc="4" show="none"/></success>
<success min="3"><set name="Speicher" inc="3" show="none"/></success>
<success min="2"><set name="Speicher" inc="2" show="none"/></success>
<success min="1"><set name="Speicher" inc="1" show="none"/></success>
<success>
<p>Sinnenschärfe-Probe gelungen.</p>
</success>
<failure>
<p>Sinnenschärfe-Probe nicht gelungen.</p>
</failure>
</challenge>
<choice target="Probe_2">Weiter zu Probe 2 (Athletik).</choice>
</scene>
<?xml version="1.0" encoding="UTF-8"?>
<scene xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://eisentrutz.antamar.eu/aoqml.xsd">
<p>Probe 2. Athletik ohne Modifikator.</p>
<challenge talent="Athletik" mod="0" >
<success min="5"><set name="Speicher" inc="5" show="none"/></success>
<success min="4"><set name="Speicher" inc="4" show="none"/></success>
<success min="3"><set name="Speicher" inc="3" show="none"/></success>
<success min="2"><set name="Speicher" inc="2" show="none"/></success>
<success min="1"><set name="Speicher" inc="1" show="none"/></success>
<success>
<p>Athletik-Probe gelungen.</p>
</success>
<failure>
<p>Athletik-Probe nicht gelungen.</p>
</failure>
</challenge>
<choice target="Auswertung">Gut! Weiter zur Auswertung.</choice>
</scene>
<?xml version="1.0" encoding="UTF-8"?>
<scene xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://eisentrutz.antamar.eu/aoqml.xsd">
<p>Dir sind <fetch name="Speicher"/> Punkte übrig geblieben!</p>
</scene>