Schnelleinstieg ins EL

Bild: Würfel

Hallo,

da ich immer wieder erlebe, dass Anfänger im Spiel wenig Lust haben, sich durch lange Anleitungen zu quälen und dann sehr schnell nicht weiter wissen, habe ich hier eine Kurzanleitung für den Schnelleinstieg verfasst.

Zuerst musst Du Dich natürlich in das Spiel Efferdland anmelden. Das geht über diesen Link. Über kurz oder lang wirst du dir aber ein eigenes Programm zum Spieler zulegen, wie z.B Mutlet.

Bist Du diesem Link gefolgt, öffnet sich das Fenster zum Anmelden. Dort gibst Du Dir einen Namen, der noch nicht vergeben ist, oder wählst für ein kurzes Reinschnuppern ‘gast’ und folgst den Anweisungen.

Nun bist Du im Efferdland.

Wenn Du wissen willst, wo Du dich gerade aufhältst, so tippe: schau

Wenn Du etwas sagen möchtest, dann tippe: sag Hallo

Wenn Du mit allen Spielern reden willst, dann tippe: -a Hallo! (-a ist eine sogenannte Ebene, vergleichbar mit einem Chatroom, hier kannst Du alles fragen, was Dir in den Sinn kommt.)

Wenn Du Dich bewegen willst, dann tippe die Richtung, z.B. osten (kurz: o)

Wenn Du etwas untersuchen möchtest, z.B. den Boden: untersuche Boden (kurz unt)

Wenn Du ein Monster bei Dir in der Nähe siehst und diesem etwas fragen möchtest, dann tippe: frage monster nach frage.

Wenn etwas im Raum herum liegt, das Du haben willst, dann tippe: nimm gegenstand.

Wenn Du den Gegenstand untersuchen willst, dann tippe: unt gegenstand (untersuche anfangs einfach alles, was du entdeckst)

Wenn Du wissen willst, was Du dabei hast, dann tippe: inventar (kurz i)

Wenn Dir die Ansicht zu farblos ist, dann tippe: farben

Eine Übersicht über die Befehle bekommst Du mit: hilfe

Eine detaillierte Übersicht mit: hilfe befehl

Wir helfen Dir gerne auf der Ebene -a wenn Du Fragen hast! Bitte beachte, dass es im Efferldand keine Umlaute gibt, also schreibe für ö: oe, ä:ae, ß: ss usw.

LG, It@Efferdland


Informiert bleiben

Bild: Social

Hallo,

um die Entwicklung des Efferdlands zu verfolgen, kann man natürlich unsere Webseite regelmäßig nach neuen Einträgen durchforsten, oder direkt im Spiel die Ingame Zeitung lesen.

Wer aber nichts verpassen möchte, für den gibt es nun 3 Möglichkeiten, immer auf dem Laufenden zu bleiben.

1. Unseren RSS Feed. Dieser ist zu erreichen unter: https://efferdland.de/feed/

Dafür ist natürlich ein RSS Reader nötig, den gibt es quasi für alle aktuellen Betriebssysteme, auch für Smartphones mit Android oder iOS. Eine Liste von RSS Reader für alle möglichen Systeme findet sich hier.

2. Unsere Facebook Seite findet sich unter https://facebook.com/Efferdland.

Um diese Seite zu sehen, muss man natürlich bei Facebook angemeldet sein.

3. Unser Telegram Channel.

Telegram ist ein Messanger, ähnlich Whatsapp. Um über Telegram informiert zu werden, einfach in Telegram nach ‘Efferdland’ suchen und unserem Channel beitreten. Telegram gibt es ebenfalls für alle aktuellen Betriebssysteme, auch für Smartphoes mit Android oder iOS.

Mehr zum Telegram Messanger findet sich hier.

Mindestanforderung für Räume

Bild: Nordland

Ein Raum ist eines der wichtigsten Elemente in einem Mud. Deshalb sollte man Räume gut beschreiben (Details) und gründlich programmieren, denn die Stimmung in einem Gebiet hängt fast ausschließlich von den Räumen ab!

Bemerkung:

Solche Details sollte es NICHT mehr geben:

  • der Boden ist unter deinen Fuessen.
  • die Decke ist über deinem Kopf.
  • tatsaechlich, es gibt hier auch Waende.

So etwas wie dies will wirklich niemand mehr lesen! Grundsätzlich ist ein Raum auch erst dann fertig, wenn der Befehl ‘ottest’ nichts mehr an fehlenden Details bemängelt. Schau Dir die Seite ‘Gebiete entwickeln‘ von Rhyan an, wenn Du nicht weißt, wie Du ein Gebiet aufziehen kannst.

Im Efferdland muss man den Räumen zudem einige Eigenschaften mitgeben, die es in anderen Muds nicht gibt. Beispiel hierfür ist das Terrain und das Environment (hier beschrieben). Diese Eigenschaften sind kein schöner Gag, sondern tatsächlich u.a. wichtig für die Rassen. Ein Elf beispielsweise heilt im Wald schneller als in der Wüste, ein Zwerg in der Unterwelt besser als im Wald…

Beispiel für einen Raum im Efferdland:

#include (...)

inherit "/std/room";

protected void create() {
  ::create();

  // Licht an
  SetProp(P_LIGHT,1);
  
  // der Raum ist draussen
  SetProp(P_INDOORS,0);

  // die Kurzbeschreibung
  SetProp(P_INT_SHORT,"Ein Waldpfad");

  // die Langbeschreibung
  SetProp(P_INT_LONG,
  "Dies ist ein Pfad in einem kuehlen, schattigen Wald.");

  // Die Details. ALLE Details müssen beschrieben sein.
  // Magier haben zum Testen den Befehl: ottest

  // Draussen IMMER: Himmel, Sonne, Wolken beschreiben
  // Innnen IMMER  : Wand, Waende, Decke beschreiben
  // IMMER         : Boden, Fussboden beschreiben!

  AddDetail(({"schatten"}),
  "Der Schatten ist schoen kuehl.");

  AddDetail(({"baum","baeume"}),
  "Maechtige Eichen ragen in den Himmel.");

  // hier ist das noch nicht vorbei. Baeume haben mind.
  // Blaetter, Aeste, Rinde, Wurzeln. Die auch beschreiben,
  // auch wenn sie nicht erwaehnt werden im Text!
  
  // hier wird ein Detail per Random ausgewählt:
  AddDetail(({"wald"}),
  ({
    "Neben dem Pfad wachsen maechtige Eichen.",

    "Dies ist ein Eichenwald.",
  }));

  // das Terrain. Sehr wichtig! Hier: Wald und Pfad
  SetProp(P_TERRAIN,T_FOREST | T_TRACK);

  // das Environment, ebenfalls wichtig!
  SetProp(P_ENVIRONMENT,
  ([
    ENV_TEMPERATURE :  3,    // 3 Grad, ziemlich kalt...
    ENV_ENVSPEED    :  1,    // Windstärken 1-12
    ENV_ALTITUDE    :  6,    // 6 Meter über Normal
    ENV_HUMIDITY    :  60,   // Luftfeuchtigkeit in %.
  ]);

  // Geräusche. Sollte es immer geben.
  AddSound(DEFAULT_SOUND,
  "Voegel zwitschern.");

  AddSound(({"vogel","voegel","zwitschern"}),
  "Traeller!");

  // Gerüche
  AddSmell(DEFAULT_SMELL,
  "Es riecht nach Pilze.");

  AddSmell(({"pilz","pilze"}),
  "Wie lecker! Hoffentlich hast Du eine Pfanne dabei!");

  // Hier geht es in den nächsten Raum:
  AddExit("osten", "raum2");
}

Bei Fragen kannst Du Dich gerne an It@Efferdand oder Torin@Efferdland wenden.

Gruß, It@chaos

P_TERRAIN & P_ENVIRONMENT

Bild: Berge

Jeder Raum im Efferdland muss bestimmte Elemente enthalten, damit er in das Konzept passt. Wichtige Elemente im Efferdland sind z.B. P_ENVIRONMENT und P_TERRAIN, die (fast) immer gesetzt werden müssen.

P_TERRAIN:

P_TERRAIN beschreibt den Landschaftstypen und ist definiert in /sys/room/terrain.h. Das Setzen dieser Property ist natürlich nur ausserhalb von Gebäuden sinnvoll.

Folgende Terrain Typen gibt es im Efferdland

T_AIRin der Luftz.B. in einem Ballon
T_UNDER_WATERunter Wasserbeim Tauchen
T_AT_WATERam Wasserz.B. Flussufer
T_IN_WATERim Wasserschwimmend
T_HILLauf einem Hügel
T_MOUNTAINim Gebirge
T_PLAINin einer Ebene
T_SWAMPim Sumpf
T_DESERTin einer Wüste
T_FORESTWaldgebiet
T_URBANStadtgebiet
T_FLOODPLAINim Auenegebieteines Flusses…
T_GARDENim Gartenauch Parks u.ä.
T_MOORim Moor
T_UNDERGROUNDim UntergrundHöhlen, Gänge, Tunnel…
T_JUNGLEim Dschungelauch Urwälder
T_COPSEim Unterholz
T_ICEEislandschaft
T_MEADOWWeisen / Wiesen
T_VELDin einer Steppe
T_VILLAGEin einem Dorf
T_POISENDgiftige Umgebungz.B. im Vulkankrater
T_PATHauf einem Pfad
T_TRACKauf einem Weg
T_ROADauf einer Strasse
T_VALLEYTal
T_SANDSand
T_QUICKSANDTreibsand
T_COASTKüste
T_CANYONSchlucht
T_PLACEPlätzez.B. Marktplätze etc.
T_BUILDINGGebäudeKünstliche Gebäude jeglicher Art

Es können auch mehrere Terrains gleichzeitig gesetzt werden. Dies ist nötig, wenn man sich z.B. auf einen Weg in einem Dorf befindet. Die Syntax hierfür ist: SetProp(P_TERRAIN, T_TRACK | T_VILLAGE);

Wie gesagt ist P_TERRAIN zwingend zu setzen! Diese Property sollte ernst genommen werden und es ist untersagt, hier irgendwelchen Mumpitz einzutragen!

P_ENVIRONMENT:

Ähnlich wichtig ist die Property P_ENVIRONMENT. Sie beschreibt die Eigenschaften einer Umgebung, z.B. Temperatur. Höhe über NN und Windgeschwindigkeiten. Auch diese Property muss in jedem Raum gesetzt werden. P_ENVIRONMENT ist definiert in /sys/environment.h

P_ENVIRONMENT ist ein Mapping und kann folgende Werte enthalten:

ENV_TEMPERATURETemperaturin Grad Celsius
ENV_ENVSPEEDUmgebungs Geschwindigkeit1 Beaufort (Wertebereich: 1-12), unter Wasser: Strömung
ENV_ALTITUDEHöheüber NN in Meter
ENV_WATERWassertiefein Meter
ENV_HUMIDITYLuftfeuchtigkeitIn %

Aus ENV_TEMPERATURE und ENV_SPEED wird die Property P_WINDCHILL
berechnet, die nur abfragbar ist und die gefühlte Temperatur enthält. Hier ein Beispiel, wie man P_ENVIRONMENT richtig setzt.

SetProp(P_ENVIRONMENT,
([
  ENV_ENVSPEED: 3,     // Windstärke 3
  ENV_TEMPERAURE: -5   // -5 Grad Celsius
  ENV_ALTITUDE: 300    // Meter Höhe 
]));

Schreibt man P_ENVIRONMENT in ein STD-File und möchte man z.B. nur die Temperatur ändern, weil man z.B. immer weiter in den kalten Norden geht, muss man nicht die komplette Property neu setzen, sondern nur den Wert, den man ändern möchte:

// So ändert man nur die Temperatur und lässt alle anderen Werte unberührt:
SetProp(P_ENVIRONMENT,
([
  ENV_TEMPERATURE: -10,
]));

P_ENVIRONMENT enthält von Haus aus STD-Werte:

ENV_ENVSPEEDWindgeschwindigkeitIm Raum: 0
Draußen: 1
ENV_HUMIDITYLuftfeuchtigkeitIm Raum: 50%
Draußen: 60%
ENV_TEMPERATURETemperatur.Im, Raum: 20
Draußen: 15
ENV_ALTITUDEHöhe3m über NN

LG, It@Efferdland

Neues von der Lagerabeit

Bild: Lager

Hallo,

um das Abenteuer ‘Lagerarbeit’ zu bestehen, muss man eine Karte lesen können. Die ist aber in als Ascii-Karte realisiert und kann leider bei dieser Art von Abenteurer auch nicht geändert werden, so dass Spieler mit Sehproblemen dieses Abenteuer nicht lösen können. Das ist natürlich ärgerlich, da man die Punkte nicht bekommen kann.

Man kann das Abenteuer jetzt aber als Team (nicht zu verwechseln mit dem Teamkampf) bestehen. Der eine arbeitet im Lager, der andere steuert den Arbeiter.

Der Arbeiter lernt dabei das Kartenlesen. Missglückt ihm dies, kann der Helfer nicht helfen. Ebenso werden die Fähigkeiten des Helfers im Kartenlesen abgefragt. Beides muss also stimmen.

Damit dies alles auch funktioniert, benötigt der Arbeiter eine neue Karte von Tante Emma. Zudem müssen beide (Helfer und Arbeiter) einmal ‘ende’ gemacht und sich neu eingeloggt haben.

Es gibt noch eine weitere Bedingung: Der Arbeiter muss mindestens eine Woche lang den ‘einfachen Grafikmodus’ benutzt haben. Mal kurz hin- und herschalten ist also nicht möglich.

Gruß, It@Efferdland

Struktur eines EL – Projekts

Bild: Computer

Die Struktur eines Efferdland Projektes unterscheidet sich von diversen anderen MUDs. Deshalb ist es für wechselwillige Magier aus anderen MUDs manchmal etwas schwierig, sich anfangs im Efferdland zurecht zu finden.

Wenn man kein eigenes Home-Mud zur Verfügung hat, kann man auch direkt im Efferdland Programmieren. Hierzu gibt es die Region /d/work/. Ein Regionsmagier legt Dir dort Dein Projekt Verzeichnis an und gibt Dir die nötigen Schreibrechte. Deine Files kannst Du dann mit einem FTP-Programm übertragen. Der FTP Port des Efferdlands lautet ‘6666’.

In Deinem neuen Arbeitsverzeichnis /d/work/<mein projekt>/ findest Du die Unterverzeichnisse für Objekte ( obj/ ), Monster ( npc/ ) und Räume ( room/ ).

Waffen und Rüstungen liegen aber nicht dort, sondern befinden sich im Efferdland in /p/armour/ bzw. /p/weapon/. Auf unser Beispiel Projekt bezogen wären das

  1. /p/armour/work/<mein_projekt>/ für Deine Rüstungen
  2. /p/weapon/work/<mein_projekt>/ für Deine Waffen.

Im Efferdland benutzen alle Magier die selben Header-Files, um für alle identische Defines für die Pfade zu erhalten. Das macht die spätere Fehlersuche einfacher und man kann ganze Projekte ohne größere Anpassungen in andere Regionen verschieben.

Dafür legt man sich in seinem Wurzelverzeichnis in /d/work/<mein_projekt>/ eine Datei def.h an (wenn das der zuständige Regionsmagier nicht schon alles für Dich erledigt hat) und bindet die ../region.h ein. Zusätzlich muss man in def.h noch ein paar Anpassungen machen. Z.B. musst Du Deinen Magiernamen eintragen und den Verzeichnisnamen Deines Projekts. In unserem Beispiel wäre das ‘mein_projekt’.

Beispiel für die def.h:

#ifndef __MEIN_PROJEKT_H__
#define __MEIN_PROJEKT_H__

#define MAGIERNAME "manwe"
#define GEBIET     "mein_project"

#include "../region.h"

#endif

Nun hast Du folgende Defines zur Verfügung:

  1. WEAPON : Waffen in /p/weapon/work/<mein_projekt>/
  2. ARMOUR : Rüstungen in /p/armour/work/<mein_projekct>/
  3. NPC : Monster in /d/work/<mein_projekt>/npc/
  4. OBJ: Objekte in /d/work/<mein_projekt>/obj/
  5. ROOM : In /d/work/<mein_projekt>/room/

Willst du jetzt z.b. ein NPC in Deinen Raum einbinden, geht das wie folgt:

#include "../def.h"

inherit "/std/room";

protected void create() {
  ::create();
  SetProp(P_INT_SHORT, "Ein Raum");
  SetProp(P_INT_LONG,  "Ein Raum.");

  // mein_monster.c aus /d/work/mein_projekt/npc/
  AddItem(NPC "mein_monster", REFRESH_DESTRUCT);
}

Viele Magier binden auch einfach diverse System-Defines in ihr def.h ein, damit sie das nicht jedes mal in ihr Programm schreiben müssen. Da kann man sich drüber streiten, ob das gut oder schlecht ist, das sollte jeder aber für sich entscheiden. Das sähe dann so aus:

#ifndef __MEIN_PROJEKT_H__
#define __MEIN_PROJEKT_H__

#define MAGIERNAME "manwe"
#define GEBIET     "mein_projekt"

#include "../region.h"

#include <v_compiler.h>
#include <properties.h>
#include <moving.h>
#include <jewel.h>
#include <kneipe.h>
#include <bank.h>
#include <quest.h>
#include <mudmaster.h>
#include <sequence.h>
#include <living/bskills.h>

#endif

Zum Schluss erwähne ich hier noch einem die Standard Files, die viele Magier anlegen. Das kann beispielsweise ein Standard Monster oder ein Standard Raum sein. In solchen Standard Files werden oftmals Dinge eingetragen, die sich ständig wiederholen, um sie nicht doppelt und dreifach schreiben zu müssen.

Im Efferdland ist es wichtig, dass solche Standard Files in einem Unterverzeichnis std/ liegen. Für STD-Räume ist das wichtig, damit sie sich nicht in die Efferdland-Karte eintragen, für STD-Monster, damit ihnen kein Erstkill zugewiesen wird.

Beispiel für einen Raum in /d/work/mein_projekt/room/

Man legt zuerst eine neues Verzeichnis an. Für einen Raum wäre das /p/work/<mein_projekt>/room/std/

In diesem Verzeichnis erstellt man dann seinen STD-Raum, in unserem Fall /p/work/<mein_projekt>/room/std/raum_std.c

#include ../../def.h"

inherit "/std/room"; // Dies ist ein STD-Raum, den die
                     // Mudlib zur Verfügung stellt

protected void create() {
  ::create();
  SetProp(P_INT_SHORT,"Ein STD-Raum");
  SetProp(P_INT_LONG, "Ein STD-Raum");

  AddDetail(({"boden","fussboden"}),
  "Der Boden ist unter deinen Fuessen.");
}

Dann schreibt man seinen Raum in /d/work/mein_project/room/raum.c

#include "../def.h"

inherit ROOM "std/raum_std";  // Hier binden wir den STD-
                              // Raum ein.

protected void create() {
  ::create();
  SetProp(P_INT_SHORT,"Ein Raum");
  SetProp(P_INT_LONG, "Ein Raum.");
}

Unser raum.c in /d/work/mein_project/room/ besitzt jetzt auch das Detail ‘boden’ und ‘fussboden’, so dass dieses nicht ständig neu mit dem selben Wortlaut in raum.c geschrieben werden muss. Sowas sollte man aber nicht zu oft machen, da dann Deine Gegend schnell langweilig wird.

Firstkills bei den Wikingern

Bild: Langhaus

Hallo,

vielleicht hat sich schon jemand mal gewundert, wie viele verschiedene Wikingerwächter im Efferdland es doch gibt…

Früher brachten die Wächter aber nur einen Erstkill (für alle zusammen!).

Jetzt gibt es allerdings für jeden Wikingerwächter mit eigenem Namen  
einen Erstkillpunkt.

Es lohnt sich also, mal wieder im Wikingerdorf vorbei zu schauen.

Gruß, – It –