winamp/Src/Plugins/Visualization/vis_milk2/defines.h

223 lines
12 KiB
C

/*
LICENSE
-------
Copyright 2005-2012 Nullsoft, Inc.
All rights reserved.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the name of Nullsoft nor the names of its contributors may be used to
endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef __NULLSOFT_DX8_PLUGIN_SHELL_DEFINES_H__
#define __NULLSOFT_DX8_PLUGIN_SHELL_DEFINES_H__ 1
// APPNAME should be something like "MyPlugin 1.0".
// This is the name that will appear in Winamp's list of installed plugins.
// Try to include the version number with the name.
// Note: to change the name of the *file* (DLL) that the plugin is
// compiled to, go to Project Settings -> Link tab -> and change the
// 'output file name'. Don't forget to do it for both Debug AND
// Release builds!
#define SHORTNAME "MilkDrop 2" // used as window caption for both MilkDrop and the config panel. avoid numbers or punctuation; when 'integrate with winamp' option is enabled, these characters don't always work with all skins.
#define LONGNAME "MilkDrop v2.25d" // appears at bottom of config panel
#define LONGNAMEW L"MilkDrop v2.25d" // appears at bottom of config panel
// INT_VERSION is the major version #, multipled by 100 (ie. version 1.02
// would be 102). If the app goes to read in the INI file and sees that
// the INI file is from an older version of your plugin, it will ignore
// their old settings and reset them to the defaults for the new version;
// but that only works if you keep this value up-to-date. ***To disable this
// behavior, just always leave this at 100. ***
#define INT_VERSION 200
// INT_SUBVERSION is the minor version #, counting up from 0 as you do
// mini-releases. If the plugin goes to read the old INI file and sees that
// the major version # is the same but the minor version # is not, it will,
// again, ignore their old settings and reset them to the defaults for the
// new version. ***To disable this behavior, just always leave this at 0. ***
#define INT_SUBVERSION 5 //straight=0, a=1, b=2, ...
// SUBDIR puts milkdrop's documentation, INI file, presets folder, etc.
// in a subdir underneath Winamp\Plugins.
#define SUBDIR L"Milkdrop2\\" //""
// INIFILE is the name of the .INI file that will save the user's
// config panel settings. Do not include a path; just give the filename.
// The actual file will be stored in the WINAMP\PLUGINS directory,
// OR POSSIBLY c:\application data\...(user)...\winamp\plugins!!! - if
// they have sep. settings for each user!
#define INIFILE L"milk2.ini" //*** DO NOT PUT IN A SUBDIR because on save, if dir doesn't already exist,
// it won't be able to save the INI file.
#define MSG_INIFILE L"milk2_msg.ini" //*** could be in c:\program files\winamp\plugins, or in
#define IMG_INIFILE L"milk2_img.ini" // c:\application data\...user...\winamp\plugins !!
#define ADAPTERSFILE L"milk2_adapters.txt"
// DOCFILE is the name of the documentation file that you'll write
// for your users. Do not include a path; just give the filename.
// When a user clicks the 'View Docs' button on the config panel,
// the plugin will try to display this file, located in the
// WINAMP\PLUGINS directory.
//
// ***Note that the button will be invisible (on the config panel)
// at runtime if this string is empty.***
#define DOCFILE SUBDIR L"docs\\milkdrop.html" // set this to something like "myplugin.html"
// PLUGIN_WEB_URL is the web address of the homepage for your plugin.
// It should be a well-formed URL (http://...). When a user clicks
// the 'View Webpage' button on the config panel, the plugin will
// launch their default browser to display this page.
//
// ***Note that the button will be invisible (on the config panel)
// at runtime if this string is empty.***
#define PLUGIN_WEB_URL L"http://www.geisswerks.com/milkdrop/" // set this to something like "http://www.myplugin.com/"
// The following two strings - AUTHOR_NAME and COPYRIGHT - will be used
// in a little box in the config panel, to identify the author & copyright
// holder of the plugin. Keep them short so they fit in the box.
#define AUTHOR_NAME L"Ryan Geiss"
#define COPYRIGHT L"(c) 2001-2023 Winamp SA"
// CLASSNAME is the name of the window class that the plugin will
// use. You don't want this to overlap with any other plugins
// or applications that are running, so change this to something
// that will probably be unique. For example, if your plugin was
// called Libido, then "LibidoClass" would probably be a safe bet.
#define CLASSNAME L"MilkDrop2"
// Here you can give names to the buttons (~tabs) along the top
// of the config panel. Each button, when clicked, will bring
// up the corresponding 'property page' (embedded dialog),
// IDD_PROPPAGE_1 through IDD_PROPPAGE_8. If you want less than
// 8 buttons to show up, just leave their names as blank. For
// full instructions on how to add a new tab/page, see
// DOCUMENTATION.TXT.
//#define CONFIG_PANEL_BUTTON_1 " Common Settings " // nPage==1
//#define CONFIG_PANEL_BUTTON_2 " MORE SETTINGS " // nPage==2
//#define CONFIG_PANEL_BUTTON_3 " Artist Tools " // nPage==3
//#define CONFIG_PANEL_BUTTON_4 " Transitions " // nPage==4
//#define CONFIG_PANEL_BUTTON_5 "" // nPage==5
//#define CONFIG_PANEL_BUTTON_6 "" // nPage==6
//#define CONFIG_PANEL_BUTTON_7 "" // nPage==7
//#define CONFIG_PANEL_BUTTON_8 "" // nPage==8
// As if 2.0e, these strings are defined in the stringtable of the dll
// and otherwise work the same as these header defines.
// (The equivelent of "" in these is a single space now)
// adjust the defaults for the 4 built-in fonts here.
// (note: if you want the font to be available on 98 + ME + 2k + XP, use one of the following...)
// arial
// courier 10-12-15
// courier new
// comic san[s] ms
// lucida console
// ms sans serif
// ms serif
// small fonts
// symbol 8-10-12-14-18-24
// tahoma
// times new roman
// verdana
// webdings
#define SIMPLE_FONT_DEFAULT_FACE L"Courier" //"MS Sans Serif" - changed to Courier because menus + code FAR more legible!
#define SIMPLE_FONT_DEFAULT_SIZE 12 //16
#define SIMPLE_FONT_DEFAULT_BOLD 0
#define SIMPLE_FONT_DEFAULT_ITAL 0
#define SIMPLE_FONT_DEFAULT_AA 0
#define DECORATIVE_FONT_DEFAULT_FACE L"Times New Roman"
#define DECORATIVE_FONT_DEFAULT_SIZE 24
#define DECORATIVE_FONT_DEFAULT_BOLD 0
#define DECORATIVE_FONT_DEFAULT_ITAL 1
#define DECORATIVE_FONT_DEFAULT_AA 1
#define HELPSCREEN_FONT_DEFAULT_FACE L"MS Sans Serif"
#define HELPSCREEN_FONT_DEFAULT_SIZE 14 // NOTE: should fit on 640x480 screen!
#define HELPSCREEN_FONT_DEFAULT_BOLD 1
#define HELPSCREEN_FONT_DEFAULT_ITAL 0
#define HELPSCREEN_FONT_DEFAULT_AA 0
#define PLAYLIST_FONT_DEFAULT_FACE L"Arial"
#define PLAYLIST_FONT_DEFAULT_SIZE 16
#define PLAYLIST_FONT_DEFAULT_BOLD 0
#define PLAYLIST_FONT_DEFAULT_ITAL 0
#define PLAYLIST_FONT_DEFAULT_AA 0
// automatically add extra fonts to the config panel
// by simply #defining them here, UP TO A MAX OF 5 EXTRA FONTS.
// access the font by calling GetFont(EXTRA_1) for extra font #1,
// GetExtraFont(EXTRA_2) for extra font #2, and so on.
#define NUM_EXTRA_FONTS 2 // <- don't exceed 5 here!
#define TOOLTIP_FONT EXTRA_1
//#define EXTRA_FONT_1_NAME "Tooltips"
// defined in the stringtable resources now since 2.0e
#define EXTRA_FONT_1_DEFAULT_FACE L"Arial"
#define EXTRA_FONT_1_DEFAULT_SIZE 14
#define EXTRA_FONT_1_DEFAULT_BOLD 0
#define EXTRA_FONT_1_DEFAULT_ITAL 0
#define EXTRA_FONT_1_DEFAULT_AA 0
#define SONGTITLE_FONT EXTRA_2
//#define EXTRA_FONT_2_NAME "Animated Songtitles"
// defined in the stringtable resources now since 2.0e
#define EXTRA_FONT_2_DEFAULT_FACE L"Times New Roman"
#define EXTRA_FONT_2_DEFAULT_SIZE 18
#define EXTRA_FONT_2_DEFAULT_BOLD 0
#define EXTRA_FONT_2_DEFAULT_ITAL 1
#define EXTRA_FONT_2_DEFAULT_AA 1
#define WINDOWCAPTION SHORTNAME // the caption that will appear on the plugin window
#define DLLDESC LONGNAME // the desc. of this DLL, as it appears in Winamp's list of viz plugins
#define MODULEDESC LONGNAME // the desc. of this viz module within the DLL (..this framework is set up for just 1 module per DLL)
// Finally, a few parameters that will control how things are done
// inside the plugin shell:
#define NUM_WAVEFORM_SAMPLES 480 // RANGE: 32-576. This is the # of samples of waveform data that you want.
// Note that if it is less than 576, then VMS will do its best
// to line up the waveforms from frame to frame for you, using
// the extra samples as 'squish' space.
// Note: the more 'slush' samples you leave, the better the alignment
// will be. 512 samples gives you decent alignment; 400 samples
// leaves room for fantastic alignment.
// Observe that if you specify a value here (say 400) and then only
// render a sub-portion of that in some cases (say, 200 samples),
// make sure you render the *middle* 200 samples (#100-300), because
// the alignment happens *mostly at the center*.
#define NUM_FREQUENCIES 512 // # of freq. samples you want *out* of the FFT, for 0-11kHz range.
// ** this must be a power of 2!
// ** the actual FFT will use twice this many frequencies **
#define TEXT_MARGIN 10 // the # of pixels of margin to leave between text and the edge of the screen
#define PLAYLIST_INNER_MARGIN 4 // the extra margin between the playlist box and the text inside
#define PLAYLIST_COLOR_PLAYING_TRACK 0xFFCCFF00 // alpha|red|green|blue
#define PLAYLIST_COLOR_HILITE_TRACK 0xFFFF5050
#define PLAYLIST_COLOR_BOTH 0xFFFFCC22
#define PLAYLIST_COLOR_NORMAL 0xFFCCCCCC
#define MENU_COLOR 0xFFCCCCCC
#define MENU_HILITE_COLOR 0xFFFF4400
#define DIR_COLOR 0xFF88CCFF
#define TOOLTIP_COLOR 0xFFBBBBCC
#define MAX_PRESETS_PER_PAGE 32
//#define PRESS_F1_MSG "Press F1 for Help " // leave extra space @ end, so italicized fonts don't get clipped
// defined in the stringtable resources now since 2.0e
#define PRESS_F1_DUR 3.0f // in seconds
#define PRESS_F1_EXP 10.0f // exponent for how quickly it accelerates to leave the screen. 1 = linear; >1 = stays & then dashes off @ end
#endif