| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311 |
- //3DMenu. Author: SDraw
- //Original posts are on forum.sa-mp.com, pawno.ru
- /* Fake natives. Thanks to TheArcher.
- native Create3DMenu(Float:x,Float:y,Float:z,Float:rotation,boxes,playerid);
- native SetBoxText(MenuID,box,text[],materialsize,fontface[],fontsize,bold,fontcolor,selectcolor,unselectcolor,textalignment);
- native Select3DMenu(playerid,MenuID);
- native CancelSelect3DMenu(playerid);
- native Destroy3DMenu(MenuID);
- */
- #define INVALID_3DMENU (0xFFFF)
- #define MAX_3DMENUS (MAX_PLAYERS)
- #define MAX_BOXES (16)
- new SelectedMenu[MAX_PLAYERS] = { -1, ...};
- new SelectedBox[MAX_PLAYERS];
- enum MenuParams
- {
- Float:MenuRotation,
- Boxes,
- bool:IsExist,
- Objects[MAX_BOXES],
- Float:OrigPosX[MAX_BOXES],
- Float:OrigPosY[MAX_BOXES],
- Float:OrigPosZ[MAX_BOXES],
- Float:AddingX,
- Float:AddingY,
- SelectColor[MAX_BOXES],
- UnselectColor[MAX_BOXES],
- Player
- }
- new MenuInfo[MAX_3DMENUS][MenuParams];
- //Callbacks
- forward OnPlayerSelect3DMenuBox(playerid,MenuID,boxid);
- forward OnPlayerChange3DMenuBox(playerid,MenuID,boxid);
- // Create a new menu
- tsfunc Create3DMenu(playerid,Float:x,Float:y,Float:z,Float:rotation,boxes)
- {
- // Make sure box is in range
- if(boxes > MAX_BOXES || boxes <= 0) return -1;
- // Create 3D Menu
- for(new i = 0; i < MAX_3DMENUS; i++)
- {
- // Menu exists continue
- if(MenuInfo[i][IsExist]) continue;
- new Float:NextLineX,Float:NextLineY;
- new lineindx,binc;
- MenuInfo[i][MenuRotation] = rotation;
- MenuInfo[i][Boxes] = boxes;
- MenuInfo[i][AddingX] = 0.25*floatsin(rotation,degrees);
- MenuInfo[i][AddingY] = -floatcos(rotation,degrees)*0.25;
- NextLineX = floatcos(rotation,degrees)+0.05*floatcos(rotation,degrees);
- NextLineY = floatsin(rotation,degrees)+0.05*floatsin(rotation,degrees);
- // Create menu objects
- for(new b = 0; b < boxes; b++)
- {
- if(b%4 == 0 && b != 0) lineindx++,binc+=4;
- MenuInfo[i][Objects][b] = CreateDynamicObject(2661,x+NextLineX*lineindx,y+NextLineY*lineindx,z+1.65-0.55*(b-binc),0,0,rotation,-1,-1,playerid,100.0);
- GetDynamicObjectPos(MenuInfo[i][Objects][b],MenuInfo[i][OrigPosX][b],MenuInfo[i][OrigPosY][b],MenuInfo[i][OrigPosZ][b]);
- }
- MenuInfo[i][IsExist] = true;
- MenuInfo[i][Player] = playerid;
- Streamer_Update(playerid);
- return i;
- }
- return -1;
- }
- tsfunc SetBoxMaterial(MenuID,box,index,model,txd[],texture[], selectcolor, unselectcolor)
- {
- if(!MenuInfo[MenuID][IsExist]) return -1;
- if(box == MenuInfo[MenuID][Boxes] || box < 0) return -1;
- if(MenuInfo[MenuID][Objects][box] == INVALID_OBJECT_ID) return -1;
- MenuInfo[MenuID][SelectColor][box] = selectcolor;
- MenuInfo[MenuID][UnselectColor][box] = unselectcolor;
- if(SelectedBox[MenuInfo[MenuID][Player]] == box) SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][box], index, model, txd, texture, selectcolor);
- else SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][box], index, model, txd, texture, unselectcolor);
- return 1;
- }
- tsfunc Select3DMenu(playerid,MenuID)
- {
- if(!IsPlayerConnected(playerid)) return -1;
- if(!MenuInfo[MenuID][IsExist]) return -1;
- if(MenuInfo[MenuID][Player] != playerid) return -1;
- if(SelectedMenu[playerid] != -1) CancelSelect3DMenu(playerid);
- SelectedMenu[playerid] = MenuID;
- Select3DMenuBox(playerid, MenuID, 0);
-
- return 1;
- }
- public OnFilterScriptInit()
- {
- for(new i = 0; i < MAX_3DMENUS; i++)
- {
- for(new b = 0; b < MAX_BOXES; b++) MenuInfo[i][Objects][b] = INVALID_OBJECT_ID;
- MenuInfo[i][Boxes] = 0;
- MenuInfo[i][IsExist] = false;
- MenuInfo[i][AddingX] = 0.0;
- MenuInfo[i][AddingY] = 0.0;
- MenuInfo[i][Player] = -1;
- }
- #if defined TM_OnFilterScriptInit
- TM_OnFilterScriptInit();
- #endif
- return 1;
- }
- #if defined _ALS_OnFilterScriptInit
- #undef OnFilterScriptInit
- #else
- #define _ALS_OnFilterScriptInit
- #endif
- #define OnFilterScriptInit TM_OnFilterScriptInit
- #if defined TM_OnFilterScriptInit
- forward TM_OnFilterScriptInit();
- #endif
- public OnFilterScriptExit()
- {
- for(new i = 0; i < MAX_3DMENUS; i++)
- {
- if(MenuInfo[i][IsExist]) Destroy3DMenu(i);
- }
- #if defined TM_OnFilterScriptExit
- TM_OnFilterScriptExit();
- #endif
- return 1;
- }
- #if defined _ALS_OnFilterScriptExit
- #undef OnFilterScriptExit
- #else
- #define _ALS_OnFilterScriptExit
- #endif
- #define OnFilterScriptExit TM_OnFilterScriptExit
- #if defined TM_OnFilterScriptExit
- forward TM_OnFilterScriptExit();
- #endif
- public OnPlayerConnect(playerid)
- {
- SelectedMenu[playerid] = -1;
- SelectedBox[playerid] = -1;
- #if defined TM_OnPlayerConnect
- TM_OnPlayerConnect(playerid);
- #endif
- return 1;
- }
- #if defined _ALS_OnPlayerConnect
- #undef OnPlayerConnect
- #else
- #define _ALS_OnPlayerConnect
- #endif
- #define OnPlayerConnect TM_OnPlayerConnect
- #if defined TM_OnPlayerConnect
- forward TM_OnPlayerConnect(playerid);
- #endif
- public OnPlayerDisconnect(playerid,reason)
- {
- if(SelectedMenu[playerid] != -1) CancelSelect3DMenu(playerid);
- #if defined TM_OnPlayerDisconnect
- TM_OnPlayerDisconnect(playerid,reason);
- #endif
- return 1;
- }
- #if defined _ALS_OnPlayerDisconnect
- #undef OnPlayerDisconnect
- #else
- #define _ALS_OnPlayerDisconnect
- #endif
- #define OnPlayerDisconnect TM_OnPlayerDisconnect
- #if defined TM_OnPlayerDisconnect
- forward TM_OnPlayerDisconnect(playerid,reason);
- #endif
- OnPlayerKeyStateChange3DMenu(playerid,newkeys,oldkeys)
- {
- #pragma unused oldkeys
- if(SelectedMenu[playerid] != -1)
- {
- new MenuID = SelectedMenu[playerid];
- if(OnPlayerKeyStateChangeMenu(playerid,newkeys,oldkeys)) return 1;
- if(newkeys == KEY_CTRL_BACK || (IsFlyMode(playerid) && (newkeys & KEY_ANALOG_LEFT && (newkeys & KEY_SECONDARY_ATTACK || oldkeys & KEY_SECONDARY_ATTACK) )))
- {
- new model,txd[32],texture[32], color;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][UnselectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- SelectedBox[playerid]++;
- if(SelectedBox[playerid] == MenuInfo[MenuID][Boxes]) SelectedBox[playerid] = 0;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][SelectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]]+MenuInfo[MenuID][AddingX],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]]+MenuInfo[MenuID][AddingY],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- if(funcidx("OnPlayerChange3DMenuBox") != -1) OnPlayerChange3DMenuBox(playerid,MenuID,SelectedBox[playerid]);
- return 1;
- }
- if(newkeys == KEY_YES || (IsFlyMode(playerid) && (newkeys & KEY_ANALOG_RIGHT && (newkeys & KEY_SECONDARY_ATTACK || oldkeys & KEY_SECONDARY_ATTACK) )))
- {
- new model,txd[32],texture[32], color;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][UnselectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- SelectedBox[playerid]--;
- if(SelectedBox[playerid] < 0) SelectedBox[playerid] = MenuInfo[MenuID][Boxes]-1;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][SelectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]]+MenuInfo[MenuID][AddingX],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]]+MenuInfo[MenuID][AddingY],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- if(funcidx("OnPlayerChange3DMenuBox") != -1) OnPlayerChange3DMenuBox(playerid,MenuID,SelectedBox[playerid]);
- return 1;
- }
- }
- return 0;
- }
- tsfunc CancelSelect3DMenu(playerid)
- {
- if(!IsPlayerConnected(playerid)) return -1;
- if(SelectedMenu[playerid] == -1) return -1;
- new MenuID = SelectedMenu[playerid];
- if(SelectedBox[playerid] != -1)
- {
- new model,txd[32],texture[32], color;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][UnselectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- }
-
- SelectedMenu[playerid] = -1;
- SelectedBox[playerid] = -1;
- return 1;
- }
- tsfunc Select3DMenuBox(playerid,MenuID,BoxID)
- {
- if(!IsPlayerConnected(playerid)) return -1;
- if(!MenuInfo[MenuID][IsExist]) return -1;
- if(MenuInfo[MenuID][Player] != playerid) return -1;
- new model,txd[32],texture[32], color;
- if(SelectedBox[playerid] != -1)
- {
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0,model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][UnselectColor][SelectedBox[playerid]]);
-
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- }
- SelectedBox[playerid] = BoxID;
- GetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, color);
- SetDynamicObjectMaterial(MenuInfo[MenuID][Objects][SelectedBox[playerid]],0, model, txd, texture, MenuInfo[MenuID][SelectColor][SelectedBox[playerid]]);
- MoveDynamicObject(MenuInfo[MenuID][Objects][SelectedBox[playerid]],MenuInfo[MenuID][OrigPosX][SelectedBox[playerid]]+MenuInfo[MenuID][AddingX],MenuInfo[MenuID][OrigPosY][SelectedBox[playerid]]+MenuInfo[MenuID][AddingY],MenuInfo[MenuID][OrigPosZ][SelectedBox[playerid]],1.0);
- return 1;
- }
- tsfunc Destroy3DMenu(MenuID)
- {
- if(!MenuInfo[MenuID][IsExist]) return -1;
- if(SelectedMenu[MenuInfo[MenuID][Player]] == MenuID) CancelSelect3DMenu(MenuInfo[MenuID][Player]);
- for(new i = 0; i < MenuInfo[MenuID][Boxes]; i++)
- {
- DestroyDynamicObject(MenuInfo[MenuID][Objects][i]);
- MenuInfo[MenuID][Objects][i] = INVALID_OBJECT_ID;
- }
- MenuInfo[MenuID][Boxes] = 0;
- MenuInfo[MenuID][IsExist] = false;
- MenuInfo[MenuID][AddingX] = 0.0;
- MenuInfo[MenuID][AddingY] = 0.0;
- MenuInfo[MenuID][Player] = -1;
- return 1;
- }
|