Different approach to dark ImpromptuModular

Signed-off-by: falkTX <falktx@falktx.com>
This commit is contained in:
falkTX 2021-11-16 16:53:45 +00:00
parent 7a483fca89
commit 11182ef544
No known key found for this signature in database
GPG key ID: CDBAA37ABC74FBA0
3 changed files with 137 additions and 16 deletions

View file

@ -0,0 +1,131 @@
//***********************************************************************************************
//Impromptu Modular: Modules for VCV Rack by Marc Boulé
//
//See ./LICENSE.md for all licenses
//***********************************************************************************************
#include "../ImpromptuModular/src/comp/PanelTheme.hpp"
void loadThemeAndContrastFromDefault(int* panelTheme, float* panelContrast) {
*panelTheme = 1;
*panelContrast = panelContrastDefault;
}
void createPanelThemeMenu(ui::Menu* menu, int* panelTheme, float* panelContrast, SvgPanel* mainPanel) {
struct PanelThemeItem : MenuItem {
int* panelTheme = NULL;
float* panelContrast = NULL;
SvgPanel* mainPanel;
Menu *createChildMenu() override {
struct PanelThemeDarkItem : MenuItem {
int* panelTheme = NULL;
SvgPanel* mainPanel;
void onAction(const event::Action &e) override {
*panelTheme ^= 0x1;
mainPanel->fb->dirty = true;
e.unconsume();
}
};
struct PanelContrastQuantity : Quantity {
float* panelContrast;
SvgPanel* mainPanel;
PanelContrastQuantity(float* _panelContrast, SvgPanel* _mainPanel) {
panelContrast = _panelContrast;
mainPanel = _mainPanel;
}
void setValue(float value) override {
*panelContrast = math::clamp(value, getMinValue(), getMaxValue());
mainPanel->fb->dirty = true;
}
float getValue() override {
return *panelContrast;
}
float getMinValue() override {return panelContrastMin;}
float getMaxValue() override {return panelContrastMax;}
float getDefaultValue() override {return panelContrastDefault;}
float getDisplayValue() override {return *panelContrast;}
std::string getDisplayValueString() override {
return string::f("%.1f", rescale(*panelContrast, getMinValue(), getMaxValue(), 0.0f, 100.0f));
}
void setDisplayValue(float displayValue) override {setValue(displayValue);}
std::string getLabel() override {return "Panel contrast";}
std::string getUnit() override {return "";}
};
struct PanelContrastSlider : ui::Slider {
PanelContrastSlider(float* panelContrast, SvgPanel* mainPanel) {
quantity = new PanelContrastQuantity(panelContrast, mainPanel);
}
~PanelContrastSlider() {
delete quantity;
}
};
Menu *menu = new Menu;
PanelThemeDarkItem *ptdItem = createMenuItem<PanelThemeDarkItem>("Dark", CHECKMARK(*panelTheme));
ptdItem->panelTheme = panelTheme;
ptdItem->mainPanel = mainPanel;
menu->addChild(ptdItem);
PanelContrastSlider *cSlider = new PanelContrastSlider(panelContrast, mainPanel);
cSlider->box.size.x = 200.0f;
menu->addChild(cSlider);
return menu;
}
};
PanelThemeItem *ptItem = createMenuItem<PanelThemeItem>("Panel theme", RIGHT_ARROW);
ptItem->panelTheme = panelTheme;
ptItem->panelContrast = panelContrast;
ptItem->mainPanel = mainPanel;
menu->addChild(ptItem);
}
void PanelBaseWidget::draw(const DrawArgs& args) {
nvgBeginPath(args.vg);
NVGcolor baseColor;
if (panelContrastSrc) {
baseColor = nvgRGB(*panelContrastSrc, *panelContrastSrc, *panelContrastSrc);
}
else {
int themeDefault;
float contrastDefault;
loadThemeAndContrastFromDefault(&themeDefault, &contrastDefault);
baseColor = nvgRGB(contrastDefault, contrastDefault, contrastDefault);
}
nvgFillColor(args.vg, baseColor);
nvgRect(args.vg, 0, 0, box.size.x, box.size.y);
nvgFill(args.vg);
TransparentWidget::draw(args);
}
void InverterWidget::draw(const DrawArgs& args) {
TransparentWidget::draw(args);
if (isDark(panelThemeSrc)) {
// nvgSave(args.vg);
nvgBeginPath(args.vg);
nvgFillColor(args.vg, SCHEME_WHITE);// this is the source, the current framebuffer is the dest
nvgRect(args.vg, 0, 0, box.size.x, box.size.y);
nvgGlobalCompositeBlendFuncSeparate(args.vg,
NVG_ONE_MINUS_DST_COLOR,// srcRGB
NVG_ZERO,// dstRGB
NVG_ONE_MINUS_DST_COLOR,// srcAlpha
NVG_ONE);// dstAlpha
// blend factor: https://github.com/memononen/nanovg/blob/master/src/nanovg.h#L86
// OpenGL blend doc: https://www.khronos.org/opengl/wiki/Blending
nvgFill(args.vg);
nvgClosePath(args.vg);
// nvgRestore(args.vg);
}
}

View file

@ -404,7 +404,8 @@ PLUGIN_FILES += $(filter-out GrandeModular/src/plugin.cpp,$(wildcard GrandeModul
# ImpromptuModular
PLUGIN_FILES += $(wildcard ImpromptuModular/src/*.cpp)
PLUGIN_FILES += $(wildcard ImpromptuModular/src/comp/*.cpp)
PLUGIN_FILES += $(filter-out ImpromptuModular/src/comp/PanelTheme.cpp,$(wildcard ImpromptuModular/src/comp/*.cpp))
PLUGIN_FILES += ImpromptuModularDark/PanelTheme.cpp
# modules/types which are present in other plugins
IMPROMPTUMODULAR_CUSTOM = RefreshCounter
@ -872,27 +873,18 @@ $(BUILD_DIR)/ImpromptuModular/src/Foundr%.cpp.o: ImpromptuModular/src/Foundr%.cp
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@ \
$(foreach m,$(IMPROMPTUMODULAR_CUSTOM),$(call custom_module_names,$(m),ImpromptuModular)) \
-DpluginInstance=pluginInstance__ImpromptuModular \
-DStepAttributes=StepAttributesKernel
$(BUILD_DIR)/ImpromptuModular/src/comp/Components.cpp.o: ImpromptuModular/src/comp/Components.cpp
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)"
@echo "Compiling $<"
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@ \
$(foreach m,$(IMPROMPTUMODULAR_CUSTOM),$(call custom_module_names,$(m),ImpromptuModular)) \
-DpluginInstance=pluginInstance__ImpromptuModular \
-DsaveDarkAsDefault=ImpromptuModularIgnore1 \
-DloadDarkAsDefault=ImpromptuModularIgonre2
-DStepAttributes=StepAttributesKernel \
# FIXME -DsetNextCableColor=isComplete shouldn't be here
$(BUILD_DIR)/ImpromptuModular/%.cpp.o: ImpromptuModular/%.cpp
$(BUILD_DIR)/ImpromptuModular%.cpp.o: ImpromptuModular%.cpp
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)"
@echo "Compiling $<"
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@ \
$(foreach m,$(IMPROMPTUMODULAR_CUSTOM),$(call custom_module_names,$(m),ImpromptuModular)) \
$(foreach m,$(IMPROMPTUMODULAR_CUSTOM_PER_FILE),$(call custom_per_file_names,$(m),ImpromptuModular_$(shell basename $*))) \
-DpluginInstance=pluginInstance__ImpromptuModular \
-DsetNextCableColor=isComplete \
-Dinit=init__ImpromptuModular
-Dinit=init__ImpromptuModular \
-DsetNextCableColor=isComplete
$(BUILD_DIR)/JW-Modules/%.cpp.o: JW-Modules/%.cpp
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)"

View file

@ -295,8 +295,6 @@ extern Model *modelMaude_221;
// stuff that reads config files, we dont want that
int loadConsoleType() { return 0; }
int loadDirectOutMode() { return 0; }
bool loadDarkAsDefault() { return true; }
bool loadQuality() { return false; }
void saveConsoleType(int) {}
void saveDarkAsDefault(bool) {}
void saveDirectOutMode(bool) {}