Skip to content

Commit

Permalink
Merge branch 'master' into orbit
Browse files Browse the repository at this point in the history
  • Loading branch information
Unreal-Dan committed Dec 10, 2023
2 parents 128a888 + 8a4e266 commit 24872b5
Show file tree
Hide file tree
Showing 2 changed files with 74 additions and 71 deletions.
134 changes: 67 additions & 67 deletions VortexEngine/src/Menus/MenuList/Randomizer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,56 @@ void Randomizer::onLongClick()
leaveMenu(true);
}

bool Randomizer::reRoll()
{
MAP_FOREACH_LED(m_targetLeds) {
// grab local reference to the target random context
Random &ctx = m_singlesRandCtx[pos];
if (m_flags & RANDOMIZE_PATTERN) {
// roll a new pattern
if (m_advanced) {
if (!rollCustomPattern(ctx, &m_previewMode, pos)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
} else {
if (!m_previewMode.setPattern(rollSingleLedPatternID(ctx), pos)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
}
}
if (m_flags & RANDOMIZE_COLORSET) {
// roll a new colorset
if (!m_previewMode.setColorset(rollColorset(ctx), pos)) {
ERROR_LOG("Failed to roll new colorset");
return false;
}
}
}
if (m_targetLeds == MAP_LED(LED_MULTI)) {
if (m_flags & RANDOMIZE_PATTERN) {
// TODO: Advanced multi led patterns?
if (!m_previewMode.setPattern(rollMultiPatternID(m_multiRandCtx), LED_MULTI)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
}
if (m_flags & RANDOMIZE_COLORSET) {
// roll a new colorset
if (!m_previewMode.setColorset(rollColorset(m_multiRandCtx), LED_MULTI)) {
ERROR_LOG("Failed to roll new colorset");
return false;
}
}
}
// initialize the mode with the new pattern and colorset
m_previewMode.init();
//DEBUG_LOGF("Randomized Led %u set with randomization technique %u, %u colors, and Pattern number %u",
// pos, randType, randomSet.numColors(), newPat);
return true;
}

void Randomizer::showRandomizationSelect()
{
// show iterating rainbow if they are randomizing color, otherwise 0 sat if they
Expand All @@ -145,6 +195,22 @@ void Randomizer::showRandomizationSelect()
Menus::showSelection();
}

PatternID Randomizer::rollSingleLedPatternID(Random &ctx)
{
PatternID newPat;
// the random range begin/end
do {
// continuously re-randomize the pattern so we don't get undesirable patterns
newPat = (PatternID)ctx.next8(PATTERN_SINGLE_FIRST, PATTERN_SINGLE_LAST);
} while (newPat == PATTERN_SOLID || newPat == PATTERN_RIBBON || newPat == PATTERN_MINIRIBBON);
return newPat;
}

PatternID Randomizer::rollMultiPatternID(Random &ctx)
{
return (PatternID)ctx.next8(PATTERN_MULTI_FIRST, PATTERN_MULTI_LAST);
}

Colorset Randomizer::rollColorset(Random &ctx)
{
Colorset randomSet;
Expand Down Expand Up @@ -194,7 +260,7 @@ Colorset Randomizer::rollColorset(Random &ctx)
return randomSet;
}

bool Randomizer::rollPattern(Random &ctx, Mode *pMode, LedPos pos)
bool Randomizer::rollCustomPattern(Random &ctx, Mode *pMode, LedPos pos)
{
PatternArgs args;
// pick a random type of randomizer to use then use
Expand Down Expand Up @@ -281,69 +347,3 @@ void Randomizer::crushPattern(Random &ctx, PatternArgs &outArgs)
uint8_t on = ctx.next8(1, 10); // on duration 1 -> 10
outArgs.init(on, off, gap, dash, group);
}

PatternID Randomizer::rollPatternID(Random &ctx)
{
PatternID newPat;
// the random range begin/end
do {
// continuously re-randomize the pattern so we don't get undesirable patterns
newPat = (PatternID)ctx.next8(PATTERN_SINGLE_FIRST, PATTERN_SINGLE_LAST);
} while (newPat == PATTERN_SOLID || newPat == PATTERN_RIBBON || newPat == PATTERN_MINIRIBBON);
return newPat;
}

PatternID Randomizer::rollMultiPatternID(Random &ctx)
{
return (PatternID)ctx.next8(PATTERN_MULTI_FIRST, PATTERN_MULTI_LAST);
}

bool Randomizer::reRoll()
{
MAP_FOREACH_LED(m_targetLeds) {
// grab local reference to the target random context
Random &ctx = m_singlesRandCtx[pos];
if (m_flags & RANDOMIZE_PATTERN) {
// roll a new pattern
if (m_advanced) {
if (!rollPattern(ctx, &m_previewMode, pos)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
} else {
if (!m_previewMode.setPattern(rollPatternID(ctx), pos)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
}
}
if (m_flags & RANDOMIZE_COLORSET) {
// roll a new colorset
if (!m_previewMode.setColorset(rollColorset(ctx), pos)) {
ERROR_LOG("Failed to roll new colorset");
return false;
}
}
}
if (m_targetLeds == MAP_LED(LED_MULTI)) {
if (m_flags & RANDOMIZE_PATTERN) {
// TODO: Advanced multi led patterns?
if (!m_previewMode.setPattern(rollMultiPatternID(m_multiRandCtx), LED_MULTI)) {
ERROR_LOG("Failed to roll new pattern");
return false;
}
}
if (m_flags & RANDOMIZE_COLORSET) {
// roll a new colorset
if (!m_previewMode.setColorset(rollColorset(m_multiRandCtx), LED_MULTI)) {
ERROR_LOG("Failed to roll new colorset");
return false;
}
}
}
// initialize the mode with the new pattern and colorset
m_previewMode.init();
//DEBUG_LOGF("Randomized Led %u set with randomization technique %u, %u colors, and Pattern number %u",
// pos, randType, randomSet.numColors(), newPat);
return true;
}
11 changes: 7 additions & 4 deletions VortexEngine/src/Menus/MenuList/Randomizer.h
Original file line number Diff line number Diff line change
Expand Up @@ -59,13 +59,16 @@ class Randomizer : public Menu
// show the randomization type selection
void showRandomizationSelect();

// generate a random colorset with a random context
bool rollPattern(Random &ctx, Mode *pMode, LedPos pos);
PatternID rollPatternID(Random &ctx);
PatternID rollSingleLedPatternID(Random &ctx);
PatternID rollMultiPatternID(Random &ctx);

// generate a random colorset with a random context
Colorset rollColorset(Random &ctx);

// random pattern generators
// roll a custom pattern by generating random arguments
bool rollCustomPattern(Random &ctx, Mode *pMode, LedPos pos);

// more specific random pattern generators that just generate patternargs
void traditionalPattern(Random &ctx, PatternArgs &outArgs);
void gapPattern(Random &ctx, PatternArgs &outArgs);
void dashPattern(Random &ctx, PatternArgs &outArgs);
Expand Down

0 comments on commit 24872b5

Please sign in to comment.