AOQML Library

Aus AntamarWiki
Version vom 17. August 2020, 09:50 Uhr von Lowlander (Diskussion | Beiträge) (Geldbetrag von allen Gruppenmitlgiedern)
Wechseln zu: Navigation, Suche

Die Bibliothek (library) stellt einige spezielle Funktionen für alle Questautoren und ZB-Schreiber zur Verfügung. Jeder Autor kann sich bei Bedarf aus der Bibliothek bedienen.

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'


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>

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


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