Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- //----------------------------------------------------------------//
- // Handysystem v.1 - Gescriptet von .Toby - since. 2013 //
- //----------------------------------------------------------------//
- //Includes
- #include <a_samp>
- #define dcmd(%1,%2,%3) if ((strcmp((%3)[1], #%1, true, (%2)) == 0) && ((((%3)[(%2) + 1] == 0) && (dcmd_%1(playerid, "")))||(((%3)[(%2) + 1] == 32) && (dcmd_%1(playerid, (%3)[(%2) + 2]))))) return 1
- //Farbcodes
- #define COLOR_RED 0xFF0A00FF
- //Definierungen
- enum handyenum
- {
- Nummer,
- Akku,
- HatHandy,
- bool:On
- };
- new Handy[MAX_PLAYERS][handyenum];
- new eingangpickup;
- new ausgangpickup;
- new bool:Aktiv[MAX_PLAYERS];
- new Anderer[MAX_PLAYERS];
- new wirdangerufen[MAX_PLAYERS];
- public OnFilterScriptInit()
- {
- print("\n--------------------------------------");
- print(" Handysystem by .Toby wurde geladen...");
- print("--------------------------------------\n");
- SetTimer("Handyakku",10000,1);
- eingangpickup = CreatePickup(1239, 2, 1161.6005,-1602.5582,13.5469,0);
- ausgangpickup = CreatePickup(1239, 2, -2240.468505,137.060440,1035.414062,0);
- return 1;
- }
- public OnFilterScriptExit()
- {
- print("\n--------------------------------------");
- print(" Handysystem by .Toby wurde entladen...");
- print("--------------------------------------\n");
- return 1;
- }
- public OnPlayerText(playerid, text[])
- {
- if(Aktiv[playerid] == true)
- {
- new string[128];
- format(string,sizeof(string),"Ins Handy: %s",text);
- SendClientMessage(playerid,COLOR_RED,string);
- format(string,sizeof(string),"Handy: %s",text);
- SendClientMessage(Anderer[playerid],COLOR_RED,string);
- }
- return 1;
- }
- public OnPlayerConnect(playerid)
- {
- Handy[playerid][Nummer] = playerid + 100 + random(500);
- Handy[playerid][Akku] = 0;
- Handy[playerid][HatHandy] = 0;
- Handy[playerid][On] = false;
- wirdangerufen[playerid] = -1;
- Anderer[playerid] = 0-1;
- return 1;
- }
- public OnPlayerCommandText(playerid, cmdtext[])
- {
- dcmd(call,4,cmdtext);
- dcmd(sms,3,cmdtext);
- dcmd(aufladen,8,cmdtext);
- dcmd(handykaufen,11,cmdtext);
- dcmd(pickup,1,cmdtext);
- dcmd(hangup,1,cmdtext);
- dcmd(handy,2,cmdtext);
- return 0;
- }
- public OnPlayerClickPlayer(playerid, clickedplayerid, source)
- {
- new string[128];
- format(string,sizeof(string),"Telefonnummer: %d",Handy[clickedplayerid][Nummer]);
- SendClientMessage(playerid, COLOR_RED,string);
- return 1;
- }
- public OnPlayerPickUpPickup(playerid, pickupid)
- {
- if(pickupid == eingangpickup)
- {
- SetPlayerPos(playerid,-2243.468505,137.060440,1035.414062);
- SetPlayerInterior(playerid,6);
- }
- if(pickupid == ausgangpickup)
- {
- SetPlayerPos(playerid,1165.6005,-1602.5582,13.5469);
- SetPlayerInterior(playerid,0);
- }
- return 1;
- }
- //Eigene Publics
- forward Handyakku();
- public Handyakku()
- {
- for(new i; i < MAX_PLAYERS; i++)
- {
- if(Handy[i][HatHandy] > 0)
- {
- if(Handy[i][On] == true)
- {
- Handy[i][Akku] --;
- }
- if(Handy[i][Akku] <= 0)
- {
- Handy[i][On] = false;
- }
- }
- }
- return 1;
- }
- //Befehle
- dcmd_handykaufen(playerid,params[])
- {
- #pragma unused params
- if(Handy[playerid][HatHandy] == 1) return SendClientMessage(playerid,COLOR_RED," Du hast schon ein Handy");
- if(!IsPlayerInRangeOfPoint(playerid,10.0,-2240.468505,137.060440,1035.414062)) return SendClientMessage(playerid,COLOR_RED," Du bist nicht am Handyladen");
- if(GetPlayerMoney(playerid) < 50) return SendClientMessage(playerid,COLOR_RED," Du hast nicht genug Geld");
- Handy[playerid][HatHandy] = 1;
- SendClientMessage(playerid,COLOR_RED,"Du hast nun ein eigenes Handy");
- GivePlayerMoney(playerid,-50);
- return 1;
- }
- dcmd_aufladen(playerid,params[])
- {
- #pragma unused params
- if(Handy[playerid][HatHandy] == 0)return SendClientMessage(playerid,COLOR_RED,"Du hast kein Handy");
- if(!IsPlayerInRangeOfPoint(playerid,10.0,-2240.468505,137.060440,1035.414062)) return SendClientMessage(playerid,COLOR_RED," Du bist nicht am Handyladen");
- Handy[playerid][Akku] = 100;
- SendClientMessage(playerid,COLOR_RED,"Handy aufgeladen");
- return 1;
- }
- dcmd_handy(playerid,params[])
- {
- #pragma unused params
- if(Handy[playerid][HatHandy] == 0)return SendClientMessage(playerid,COLOR_RED,"Du hast kein Handy");
- switch(Handy[playerid][On])
- {
- case true:
- {
- if(Handy[playerid][Akku] >0)
- {
- Handy[playerid][On] = false;
- SendClientMessage(playerid,COLOR_RED,"Handy ausgeschaltet");
- }
- else return SendClientMessage(playerid,COLOR_RED,"Akku leer");
- }
- case false:{ Handy[playerid][On] = true; SendClientMessage(playerid,COLOR_RED,"Handy angeschaltet");}
- }
- return 1;
- }
- dcmd_sms(playerid,params[])
- {
- new nummer,string[128];
- if(sscanf(params,"is",nummer,string))return SendClientMessage(playerid, COLOR_RED,"[Benutzung]: /sms [nummer] [text]");
- if(Handy[playerid][HatHandy] == 0 || Handy[playerid][On] == false)return SendClientMessage(playerid,COLOR_RED,"Du hast kein Handy doer es ist nicht an!");
- for(new i; i < MAX_PLAYERS; i++)
- {
- if(IsPlayerConnected(i))
- {
- if(Handy[i][Nummer] == nummer)
- {
- new text[128];
- format(text,sizeof(text),"SMS: %s | NUMMER:%d",Handy[playerid][Nummer],string);
- SendClientMessage(i,COLOR_RED,text);
- format(text,sizeof(text),"SMS an %d gesendet",nummer);
- SendClientMessage(playerid,COLOR_RED,text);
- return 1;
- }
- else
- {
- if(i == 499) return SendClientMessage(playerid,COLOR_RED," Kein Anschluss unter dieser Nummer");
- }
- }
- }
- return 1;
- }
- dcmd_call(playerid,params[])
- {
- new nummer;
- if(sscanf(params,"i",nummer))return SendClientMessage(playerid, COLOR_RED,"[Benutzung]: /call [nummer]");
- if(Handy[playerid][HatHandy] == 0 || Handy[playerid][On] == false)return SendClientMessage(playerid,COLOR_RED,"Du hast kein Handy doer es ist nicht an!");
- if(Aktiv[playerid] == true) return SendClientMessage(playerid,COLOR_RED,"Du bist schon am Telefonieren");
- for(new i; i < MAX_PLAYERS; i++)
- {
- if(IsPlayerConnected(i))
- {
- if(Handy[i][Nummer] == nummer)
- {
- if(Handy[i][HatHandy] == 0 || Handy[i][On] == false)return SendClientMessage(playerid,COLOR_RED,"Der gewünschste Gesprächtsteilnehmer ist nicht zu erreichen");
- new text[128];
- format(text,sizeof(text),"Du wirst angerufen Nummer: %d",Handy[playerid][Nummer]);
- SendClientMessage(i,COLOR_RED,text);
- Aktiv[playerid] = true;
- wirdangerufen[i] = playerid;
- return 1;
- }
- else
- {
- if(i == 499) return SendClientMessage(playerid,COLOR_RED," Kein Anschluss unter dieser Nummer");
- }
- }
- }
- return 1;
- }
- dcmd_pickup(playerid,params[])
- {
- #pragma unused params
- if(wirdangerufen[playerid] >= 0)
- {
- Anderer[playerid] = wirdangerufen[playerid];
- Anderer[wirdangerufen[playerid]] = playerid;
- wirdangerufen[playerid] = 0;
- Aktiv[playerid] = true;
- SendClientMessage(wirdangerufen[playerid],COLOR_RED," Handy wurde abgenommen");
- SendClientMessage(playerid,COLOR_RED,"Du hast das Handy agenommen");
- return 1;
- }
- return 1;
- }
- dcmd_hangup(playerid,params[])
- {
- #pragma unused params
- if(wirdangerufen[playerid] >= 0||Anderer[playerid] >= 0)
- {
- Anderer[Anderer[playerid]] = -1;
- Anderer[playerid] = -1;
- wirdangerufen[playerid] = -1;
- Aktiv[playerid] = true;
- Aktiv[Anderer[playerid]] = true;
- SendClientMessage(wirdangerufen[playerid],COLOR_RED," Handy wurde abgelehnt");
- SendClientMessage(playerid,COLOR_RED,"Handy abgelehnt");
- return 1;
- }
- return 1;
- }
- //SSCANF
- stock sscanf(string[], format[], {Float,_}:...)
- {
- #if defined isnull
- if (isnull(string))
- #else
- if (string[0] == 0 || (string[0] == 1 && string[1] == 0))
- #endif
- {
- return format[0];
- }
- #pragma tabsize 4
- new
- formatPos = 0,
- stringPos = 0,
- paramPos = 2,
- paramCount = numargs(),
- delim = ' ';
- while (string[stringPos] && string[stringPos] <= ' ')
- {
- stringPos++;
- }
- while (paramPos < paramCount && string[stringPos])
- {
- switch (format[formatPos++])
- {
- case '\0':
- {
- return 0;
- }
- case 'i', 'd':
- {
- new
- neg = 1,
- num = 0,
- ch = string[stringPos];
- if (ch == '-')
- {
- neg = -1;
- ch = string[++stringPos];
- }
- do
- {
- stringPos++;
- if ('0' <= ch <= '9')
- {
- num = (num * 10) + (ch - '0');
- }
- else
- {
- return -1;
- }
- }
- while ((ch = string[stringPos]) > ' ' && ch != delim);
- setarg(paramPos, 0, num * neg);
- }
- case 'h', 'x':
- {
- new
- num = 0,
- ch = string[stringPos];
- do
- {
- stringPos++;
- switch (ch)
- {
- case 'x', 'X':
- {
- num = 0;
- continue;
- }
- case '0' .. '9':
- {
- num = (num << 4) | (ch - '0');
- }
- case 'a' .. 'f':
- {
- num = (num << 4) | (ch - ('a' - 10));
- }
- case 'A' .. 'F':
- {
- num = (num << 4) | (ch - ('A' - 10));
- }
- default:
- {
- return -1;
- }
- }
- }
- while ((ch = string[stringPos]) > ' ' && ch != delim);
- setarg(paramPos, 0, num);
- }
- case 'c':
- {
- setarg(paramPos, 0, string[stringPos++]);
- }
- case 'f':
- {
- new changestr[16], changepos = 0, strpos = stringPos;
- while(changepos < 16 && string[strpos] && string[strpos] != delim)
- {
- changestr[changepos++] = string[strpos++];
- }
- changestr[changepos] = '\0';
- setarg(paramPos,0,_:floatstr(changestr));
- }
- case 'p':
- {
- delim = format[formatPos++];
- continue;
- }
- case '\'':
- {
- new
- end = formatPos - 1,
- ch;
- while ((ch = format[++end]) && ch != '\'') {}
- if (!ch)
- {
- return -1;
- }
- format[end] = '\0';
- if ((ch = strfind(string, format[formatPos], false, stringPos)) == -1)
- {
- if (format[end + 1])
- {
- return -1;
- }
- return 0;
- }
- format[end] = '\'';
- stringPos = ch + (end - formatPos);
- formatPos = end + 1;
- }
- case 'u':
- {
- new
- end = stringPos - 1,
- id = 0,
- bool:num = true,
- ch;
- while ((ch = string[++end]) && ch != delim)
- {
- if (num)
- {
- if ('0' <= ch <= '9')
- {
- id = (id * 10) + (ch - '0');
- }
- else
- {
- num = false;
- }
- }
- }
- if (num && IsPlayerConnected(id))
- {
- setarg(paramPos, 0, id);
- }
- else
- {
- #if !defined foreach
- #define foreach(%1,%2) for (new %2 = 0; %2 < MAX_PLAYERS; %2++) if (IsPlayerConnected(%2))
- #define __SSCANF_FOREACH__
- #endif
- string[end] = '\0';
- num = false;
- new
- name[MAX_PLAYER_NAME];
- id = end - stringPos;
- foreach (Player, playerid)
- {
- GetPlayerName(playerid, name, sizeof (name));
- if (!strcmp(name, string[stringPos], true, id))
- {
- setarg(paramPos, 0, playerid);
- num = true;
- break;
- }
- }
- if (!num)
- {
- setarg(paramPos, 0, INVALID_PLAYER_ID);
- }
- string[end] = ch;
- #if defined __SSCANF_FOREACH__
- #undef foreach
- #undef __SSCANF_FOREACH__
- #endif
- }
- stringPos = end;
- }
- case 's', 'z':
- {
- new
- i = 0,
- ch;
- if (format[formatPos])
- {
- while ((ch = string[stringPos++]) && ch != delim)
- {
- setarg(paramPos, i++, ch);
- }
- if (!i)
- {
- return -1;
- }
- }
- else
- {
- while ((ch = string[stringPos++]))
- {
- setarg(paramPos, i++, ch);
- }
- }
- stringPos--;
- setarg(paramPos, i, '\0');
- }
- default:
- {
- continue;
- }
- }
- while (string[stringPos] && string[stringPos] != delim && string[stringPos] > ' ')
- {
- stringPos++;
- }
- while (string[stringPos] && (string[stringPos] == delim || string[stringPos] <= ' '))
- {
- stringPos++;
- }
- paramPos++;
- }
- do
- {
- if ((delim = format[formatPos++]) > ' ')
- {
- if (delim == '\'')
- {
- while ((delim = format[formatPos++]) && delim != '\'') {}
- }
- else if (delim != 'z')
- {
- return delim;
- }
- }
- }
- while (delim > ' ');
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement