Raised This Month: $51 Target: $400
 12% 

Solved Improve this music menu plugin


Post New Thread Reply   
 
Thread Tools Display Modes
Author Message
JuanitoAlimana
Senior Member
Join Date: Aug 2021
Old 06-07-2022 , 04:43   Improve this music menu plugin
Reply With Quote #1

So this music menu plugin works great but I would like to create a "music.ini" file from which to load the new songs so I don't have to modify and compile every time I want to upload a new song. Thanks!


PHP Code:
#include <amxmodx>

#define PLUGIN  "Random Sounds by Command and Menu"
#define VERSION "1.4"
#define AUTHOR  "[N]drs"

enum _:DATA
{
    
NAME[20],
    
RUTA[126]
}  

new const 
SONIDO[][DATA] =
{
    {
"Toto - Africa""sound/music/africa.mp3"},
    {
"Korn - Thoughless""sound/music/thoughtless.mp3"}
}

public 
plugin_init()
{
    
register_plugin(PLUGINVERSIONAUTHOR)
    
register_clcmd("say /play""play")
    
register_clcmd("say /music""play_menu")
    
register_clcmd("say /stop""stop_sound")
}

public 
plugin_precache()
{
    for(new 
isizeof(SONIDO); i++)
        
precache_generic(SONIDO[i][RUTA])
}

public 
play(id)
{
    if(
get_user_flags(id) & ADMIN_LEVEL_H)
    {
        new 
random_num(0sizeof(SONIDO))
        
play_sound(idi)
    }

    return 
PLUGIN_HANDLED
}

public 
play_menu(id)
{
    if(~
get_user_flags(id) & ADMIN_LEVEL_H)
        return 
PLUGIN_HANDLED

    
new iMenu menu_create("\yMusic Menu""handlerMenu")

    for(new 
isizeof(SONIDO); i++)
        
menu_additem(iMenuSONIDO[i][NAME])

    
menu_display(idiMenu)

    return 
PLUGIN_HANDLED
}

public 
handlerMenu(idiMenuitem)
{
    if(
item == MENU_EXIT)
    {
        
menu_destroy(iMenu)
        return 
PLUGIN_HANDLED
    
}

    
play_sound(iditem)
    
menu_destroy(iMenu)

    return 
PLUGIN_HANDLED
}

play_sound(id, const iSound)
{
    
client_cmd(0"Mp3 play %s"SONIDO[iSound][RUTA])
    
client_print_color(idprint_team_grey"^3ADMIN ^4%n ^3has changed the song to ^4%s"idSONIDO[iSound][NAME])
}

public 
stop_sound(id)
{
    
client_cmd(0"Mp3 stop"

Last edited by JuanitoAlimana; 06-15-2022 at 17:12.
JuanitoAlimana is offline
lexzor
Veteran Member
Join Date: Nov 2020
Old 06-07-2022 , 08:14   Re: Improve this music menu plugin
Reply With Quote #2

try this one

PHP Code:
#include <amxmodx>
#include <amxmisc>

#define PLUGIN  "Random Sounds by Command and Menu"
#define VERSION "1.4"
#define AUTHOR  "[N]drs"

#define FILE_NAME "music.ini"
#define LOG_FILE "random_sounds"

enum _:DATA
{
    
NAME[64],
    
PATH[64]
}  

new const 
g_szFileData[][] =
{
    
"#You must put your music file one above another^n",
    
"#Model: ^"Name^" ^"path^"^n^n^n"
}

new Array:
g_aSongData;

public 
plugin_init()
{
    
register_plugin(PLUGINVERSIONAUTHOR)
    
register_clcmd("say /play""play")
    
register_clcmd("say /music""play_menu")
    
register_clcmd("say /stop""stop_sound")

    
register_clcmd("say_team /play""play")
    
register_clcmd("say_team /music""play_menu")
    
register_clcmd("say_team /stop""stop_sound")
}

public 
plugin_end()
{
    
ArrayDestroy(g_aSongData);
}

public 
plugin_precache()
{
    
g_aSongData ArrayCreate(DATA);
    new 
szFile[256], szFileDirector[124], iFilePointer;
    
    
get_configsdir(szFileDirectorcharsmax(szFileDirector));
    
formatex(szFilecharsmax(szFile), "%s/%s"szFileDirectorFILE_NAME);

    new 
bool:bFileExists bool:file_exists(szFile);

    if(!
bFileExists)
    {
        
iFilePointer fopen(szFile"w");

        for(new 
isizeof(g_szFileData); i++)
            
fputs(iFilePointerg_szFileData[i]);

        
fclose(iFilePointer);
        
set_fail_state("[MUSIC] File ^"%s^" has been created. Change map to load your new music files"szFile);
    }
    else 
    {
        
iFilePointer fopen(szFile"r");
        new 
szData[256];
        new 
eSongData[DATA];
        
        while(
fgets(iFilePointerszDatacharsmax(szData)))
        {
            
trim(szData);

            if(
szData[0] == ';' || szData[0] == '#' || szData[0] == EOS)
                continue;

            
parse(szDataeSongData[NAME], charsmax(eSongData[NAME]), eSongData[PATH], charsmax(eSongData[PATH]));
            
            if(
file_exists(eSongData[PATH]))
            {
                
precache_generic(eSongData[PATH]);
                
ArrayPushArray(g_aSongDataeSongData);
            } else 
log_to_file(LOG_FILE"Path song is wrong or the file doesn't exists ^"%s^""eSongData[PATH]);
        }

        
fclose(iFilePointer);
    }
}

public 
play(id)
{
    if(
get_user_flags(id) & ADMIN_LEVEL_H)
    {
        new 
random_num(0ArraySize(g_aSongData) - 1)
        
play_sound(idi)
    }

    return 
PLUGIN_HANDLED
}

public 
play_menu(id)
{
    if(~
get_user_flags(id) & ADMIN_LEVEL_H)
        return 
PLUGIN_HANDLED

    
new iMenu menu_create("\yMusic Menu""handlerMenu")

    new 
eSongData[DATA], iCount;

    for(new 
iArraySize(g_aSongData); i++)
    {
        
ArrayGetArray(g_aSongDataieSongData);
        
menu_additem(iMenueSongData[NAME]);

        
iCount++
    }

    if(
iCount == 0menu_additem(iMenu"\dNo songs to be shown""1234");


    if(
is_user_connected(id))
        
menu_display(idiMenu)

    return 
PLUGIN_HANDLED
}

public 
handlerMenu(idiMenuitem)
{
    if(
item == MENU_EXIT)
    {
        
menu_destroy(iMenu)
        return 
PLUGIN_HANDLED
    
}

    new 
szData[5];
    
menu_item_getinfo(iMenuitem_szDatacharsmax(szData), ___);

    if(
str_to_num(szData) == 1234)
        return 
PLUGIN_HANDLED;

    
play_sound(iditem)
    
menu_destroy(iMenu)

    return 
PLUGIN_HANDLED
}

play_sound(id, const iSound)
{
    static 
eSongData[DATA];
    
ArrayGetArray(g_aSongDataiSoundeSongData);

    
client_cmd(0"Mp3 play %s"eSongData[PATH]);
 
    
client_print_color(idprint_team_grey"^3ADMIN ^4%n ^3has changed the song to ^4%s"ideSongData[NAME]);
}

public 
stop_sound(id)
{
    
client_cmd(0"Mp3 stop"


Last edited by lexzor; 06-07-2022 at 08:17.
lexzor is offline
JuanitoAlimana
Senior Member
Join Date: Aug 2021
Old 06-15-2022 , 17:12   Re: Improve this music menu plugin
Reply With Quote #3

Brother, it works perfectly. Thank you so much!
JuanitoAlimana is offline
lexzor
Veteran Member
Join Date: Nov 2020
Old 06-15-2022 , 19:12   Re: Improve this music menu plugin
Reply With Quote #4

if you want more changes, just post here i like the idea of this plugin
lexzor is offline
Reply



Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT -4. The time now is 00:41.


Powered by vBulletin®
Copyright ©2000 - 2024, vBulletin Solutions, Inc.
Theme made by Freecode