the go back commit
This commit is contained in:
parent
2869533db9
commit
ebfb6e239a
7
Makefile
7
Makefile
|
@ -58,8 +58,15 @@ CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/quantize/wsmeans.cpp)
|
||||||
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/quantize/wu.cpp)
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/quantize/wu.cpp)
|
||||||
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/quantize/lab.cpp)
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/quantize/lab.cpp)
|
||||||
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/utils/utils.cpp)
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/utils/utils.cpp)
|
||||||
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/cam/cam.cpp)
|
||||||
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/cam/hct.cpp)
|
||||||
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/cam/hct_solver.cpp)
|
||||||
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/cam/viewing_conditions.cpp)
|
||||||
|
CPP_SRC += $(wildcard $(SRC_DIR)/material-colors/cpp/score/score.cpp)
|
||||||
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/quantize
|
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/quantize
|
||||||
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/utils
|
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/utils
|
||||||
|
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/score
|
||||||
|
EXTRA_DIRS += $(OBJ_DIR)/material-colors/cpp/cam
|
||||||
|
|
||||||
ifeq ($(IMGUI_MODE), BUILD)
|
ifeq ($(IMGUI_MODE), BUILD)
|
||||||
CPP_SRC += $(wildcard $(SRC_DIR)/imgui/*.cpp) #GET LIST OF ALL CPP FILES
|
CPP_SRC += $(wildcard $(SRC_DIR)/imgui/*.cpp) #GET LIST OF ALL CPP FILES
|
||||||
|
|
84
src/main.cpp
84
src/main.cpp
|
@ -7,8 +7,8 @@
|
||||||
#include <sdbus-c++/Types.h>
|
#include <sdbus-c++/Types.h>
|
||||||
#define IMGUI_DEFINE_MATH_OPERATORS
|
#define IMGUI_DEFINE_MATH_OPERATORS
|
||||||
#include "raylib.h"
|
#include "raylib.h"
|
||||||
#include "rlgl.h"
|
|
||||||
#include "raymath.h"
|
#include "raymath.h"
|
||||||
|
#include "rlgl.h"
|
||||||
#include <optional>
|
#include <optional>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -233,18 +233,22 @@ float ScaleToFit(Vector2 src, Vector2 dst) {
|
||||||
// return Vector2Scale(src, ratio);
|
// return Vector2Scale(src, ratio);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GenCircleOverlay(RenderTexture tex, bool trans) {
|
void GenCircleOverlay(MprisPlayer *current_player, RenderTexture tex, bool trans, bool accent) {
|
||||||
BeginTextureMode(tex);
|
BeginTextureMode(tex);
|
||||||
if (trans) {
|
if (trans) {
|
||||||
ClearBackground(WHITE);
|
ClearBackground(WHITE);
|
||||||
} else {
|
} else {
|
||||||
ClearBackground(BLACK);
|
if (accent) {
|
||||||
|
ClearBackground(current_player->GetPrimaryColor());
|
||||||
|
} else {
|
||||||
|
ClearBackground(BLACK);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
BeginBlendMode(BLEND_SUBTRACT_COLORS);
|
BeginBlendMode(BLEND_SUBTRACT_COLORS);
|
||||||
if (trans) {
|
if (trans) {
|
||||||
DrawCircle(GetScreenWidth()/2, GetScreenHeight()/2, std::min(GetScreenWidth()/2, GetScreenHeight()/2), WHITE);
|
DrawCircle(GetScreenWidth() / 2, GetScreenHeight() / 2, std::min(GetScreenWidth() / 2, GetScreenHeight() / 2), WHITE);
|
||||||
} else {
|
} else {
|
||||||
DrawCircle(GetScreenWidth()/2, GetScreenHeight()/2, std::min(GetScreenWidth()/2, GetScreenHeight()/2), (Color{0,0,0,0}));
|
DrawCircle(GetScreenWidth() / 2, GetScreenHeight() / 2, std::min(GetScreenWidth() / 2, GetScreenHeight() / 2), (Color{0, 0, 0, 0}));
|
||||||
}
|
}
|
||||||
EndBlendMode();
|
EndBlendMode();
|
||||||
EndTextureMode();
|
EndTextureMode();
|
||||||
|
@ -257,13 +261,13 @@ int main(int argc, char *argv[]) {
|
||||||
int screenHeight = 800;
|
int screenHeight = 800;
|
||||||
|
|
||||||
// SetConfigFlags(FLAG_MSAA_4X_HINT | FLAG_WINDOW_RESIZABLE);
|
// SetConfigFlags(FLAG_MSAA_4X_HINT | FLAG_WINDOW_RESIZABLE);
|
||||||
//SetConfigFlags(FLAG_MSAA_4X_HINT | FLAG_VSYNC_HINT | FLAG_WINDOW_RESIZABLE);
|
// SetConfigFlags(FLAG_MSAA_4X_HINT | FLAG_VSYNC_HINT | FLAG_WINDOW_RESIZABLE);
|
||||||
SetConfigFlags(FLAG_WINDOW_TRANSPARENT | FLAG_MSAA_4X_HINT | FLAG_WINDOW_RESIZABLE);
|
SetConfigFlags(FLAG_WINDOW_TRANSPARENT | FLAG_MSAA_4X_HINT | FLAG_WINDOW_RESIZABLE | FLAG_VSYNC_HINT);
|
||||||
InitWindow(screenWidth, screenHeight, "raylib-Extras [ImGui] example - Docking");
|
InitWindow(screenWidth, screenHeight, "raylib-Extras [ImGui] example - Docking");
|
||||||
SetTargetFPS(244);
|
SetTargetFPS(244);
|
||||||
rlImGuiSetup(true);
|
rlImGuiSetup(true);
|
||||||
ImGui::GetStyle().AntiAliasedLinesUseTex = false;
|
ImGui::GetStyle().AntiAliasedLinesUseTex = false;
|
||||||
//SetWindowState(FLAG_WINDOW_UNDECORATED);
|
// SetWindowState(FLAG_WINDOW_UNDECORATED);
|
||||||
|
|
||||||
TestC();
|
TestC();
|
||||||
TestCPPFunc();
|
TestCPPFunc();
|
||||||
|
@ -284,17 +288,28 @@ int main(int argc, char *argv[]) {
|
||||||
// Main game loop
|
// Main game loop
|
||||||
bool goodstate = false;
|
bool goodstate = false;
|
||||||
bool trans = false;
|
bool trans = false;
|
||||||
|
bool accent = true;
|
||||||
|
|
||||||
|
long imagecount = -1;
|
||||||
|
|
||||||
|
bool showMetricsWindow = false;
|
||||||
|
|
||||||
RenderTexture recordoverlay = LoadRenderTexture(screenWidth, screenHeight);
|
RenderTexture recordoverlay = LoadRenderTexture(screenWidth, screenHeight);
|
||||||
GenCircleOverlay(recordoverlay, trans);
|
GenCircleOverlay(¤t_player, recordoverlay, trans, accent);
|
||||||
|
|
||||||
while (!WindowShouldClose() && run) // Detect window close button or ESC key, or a quit from the menu
|
while (!WindowShouldClose() && run) // Detect window close button or ESC key, or a quit from the menu
|
||||||
{
|
{
|
||||||
if (IsWindowResized()) {
|
if (IsWindowResized()) {
|
||||||
UnloadRenderTexture(recordoverlay);
|
UnloadRenderTexture(recordoverlay);
|
||||||
recordoverlay = LoadRenderTexture(GetScreenWidth(), GetScreenHeight());
|
recordoverlay = LoadRenderTexture(GetScreenWidth(), GetScreenHeight());
|
||||||
GenCircleOverlay(recordoverlay, trans);
|
GenCircleOverlay(¤t_player, recordoverlay, trans, accent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (current_player.imagecount > imagecount) {
|
||||||
|
imagecount = current_player.imagecount;
|
||||||
|
GenCircleOverlay(¤t_player, recordoverlay, trans, accent);
|
||||||
|
}
|
||||||
|
|
||||||
if (GetTime() > lasttime + 3) {
|
if (GetTime() > lasttime + 3) {
|
||||||
lasttime = GetTime();
|
lasttime = GetTime();
|
||||||
current_player.Refresh();
|
current_player.Refresh();
|
||||||
|
@ -302,7 +317,7 @@ int main(int argc, char *argv[]) {
|
||||||
|
|
||||||
BeginDrawing();
|
BeginDrawing();
|
||||||
if (trans) {
|
if (trans) {
|
||||||
ClearBackground((Color) {0,0,0,0});
|
ClearBackground((Color){0, 0, 0, 0});
|
||||||
} else {
|
} else {
|
||||||
ClearBackground(BLACK);
|
ClearBackground(BLACK);
|
||||||
}
|
}
|
||||||
|
@ -353,7 +368,7 @@ int main(int argc, char *argv[]) {
|
||||||
} else if (IsMouseButtonPressed(MOUSE_BUTTON_LEFT) && CheckCollisionPointCircle(GetMousePosition(), back, 0.05 * GetScreenWidth())) {
|
} else if (IsMouseButtonPressed(MOUSE_BUTTON_LEFT) && CheckCollisionPointCircle(GetMousePosition(), back, 0.05 * GetScreenWidth())) {
|
||||||
current_player.Prev();
|
current_player.Prev();
|
||||||
current_player.playstate = current_player.playstate == "Playing" ? "Paused" : "Playing";
|
current_player.playstate = current_player.playstate == "Playing" ? "Paused" : "Playing";
|
||||||
} else if (IsMouseButtonDown(MOUSE_BUTTON_LEFT)) {
|
} else if (IsMouseButtonDown(MOUSE_BUTTON_LEFT) && disc.enabled) {
|
||||||
float initmouserot;
|
float initmouserot;
|
||||||
Vector2 initmousepos;
|
Vector2 initmousepos;
|
||||||
if (IsMouseButtonPressed(MOUSE_BUTTON_LEFT)) {
|
if (IsMouseButtonPressed(MOUSE_BUTTON_LEFT)) {
|
||||||
|
@ -380,16 +395,16 @@ int main(int argc, char *argv[]) {
|
||||||
}
|
}
|
||||||
disc.accel = disc.target - disc.velo;
|
disc.accel = disc.target - disc.velo;
|
||||||
}
|
}
|
||||||
if (IsMouseButtonReleased(MOUSE_BUTTON_LEFT)) {
|
if (IsMouseButtonReleased(MOUSE_BUTTON_LEFT)) {
|
||||||
goodstate = false;
|
goodstate = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (disc.active) {
|
if (disc.active) {
|
||||||
if (trans) {
|
if (trans) {
|
||||||
rlSetBlendFactors(1,1, 0x800B);
|
rlSetBlendFactors(1, 1, 0x800B);
|
||||||
BeginBlendMode(BLEND_CUSTOM);
|
BeginBlendMode(BLEND_CUSTOM);
|
||||||
}
|
}
|
||||||
DrawTexture(recordoverlay.texture, 0, 0 , WHITE);
|
DrawTexture(recordoverlay.texture, 0, 0, WHITE);
|
||||||
if (trans) {
|
if (trans) {
|
||||||
EndBlendMode();
|
EndBlendMode();
|
||||||
}
|
}
|
||||||
|
@ -402,6 +417,7 @@ int main(int argc, char *argv[]) {
|
||||||
// start ImGui content
|
// start ImGui content
|
||||||
|
|
||||||
if (showIMgui) {
|
if (showIMgui) {
|
||||||
|
disc.enabled = false;
|
||||||
rlImGuiBegin();
|
rlImGuiBegin();
|
||||||
|
|
||||||
// if you want windows to dock to the viewport, call this.
|
// if you want windows to dock to the viewport, call this.
|
||||||
|
@ -421,6 +437,9 @@ int main(int argc, char *argv[]) {
|
||||||
current_player = MprisPlayer(item);
|
current_player = MprisPlayer(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (ImGui::MenuItem("Refresh")) {
|
||||||
|
serviceList = GetMprisServices();
|
||||||
|
}
|
||||||
ImGui::EndMenu();
|
ImGui::EndMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -432,11 +451,26 @@ int main(int argc, char *argv[]) {
|
||||||
}
|
}
|
||||||
if (ImGui::MenuItem("Trans Mode !!", nullptr, trans)) {
|
if (ImGui::MenuItem("Trans Mode !!", nullptr, trans)) {
|
||||||
trans = !trans;
|
trans = !trans;
|
||||||
GenCircleOverlay(recordoverlay, trans);
|
GenCircleOverlay(¤t_player, recordoverlay, trans, accent);
|
||||||
|
}
|
||||||
|
if (ImGui::MenuItem("Accent Mode !!", nullptr, accent)) {
|
||||||
|
accent = !accent;
|
||||||
|
GenCircleOverlay(¤t_player, recordoverlay, trans, accent);
|
||||||
}
|
}
|
||||||
ImGui::EndMenu();
|
ImGui::EndMenu();
|
||||||
}
|
}
|
||||||
|
if (ImGui::BeginMenu("Tools")) {
|
||||||
|
if (ImGui::MenuItem("Debug Window", nullptr, showMetricsWindow)) {
|
||||||
|
showMetricsWindow = !showMetricsWindow;
|
||||||
|
}
|
||||||
|
ImGui::EndMenu();
|
||||||
|
}
|
||||||
|
|
||||||
ImGui::EndMainMenuBar();
|
ImGui::EndMainMenuBar();
|
||||||
|
|
||||||
|
if (showMetricsWindow) {
|
||||||
|
ImGui::ShowMetricsWindow();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// show some windows
|
// show some windows
|
||||||
|
@ -466,6 +500,18 @@ int main(int argc, char *argv[]) {
|
||||||
ImGui::Separator();
|
ImGui::Separator();
|
||||||
ImGui::LabelText("Disc Info", "P: %f, V: %f, A: %f", disc.pos, disc.velo, disc.accel);
|
ImGui::LabelText("Disc Info", "P: %f, V: %f, A: %f", disc.pos, disc.velo, disc.accel);
|
||||||
rlImGuiImageSize(¤t_player.tex.tex, 300, 300);
|
rlImGuiImageSize(¤t_player.tex.tex, 300, 300);
|
||||||
|
|
||||||
|
ImGui::Separator();
|
||||||
|
int inc = 0;
|
||||||
|
for (auto obj : current_player.accent_colors) {
|
||||||
|
|
||||||
|
float col[3] = {0, 0, 0};
|
||||||
|
col[0] = ((float)obj.r) / 255;
|
||||||
|
col[1] = ((float)obj.g) / 255;
|
||||||
|
col[2] = ((float)obj.b) / 255;
|
||||||
|
ImGui::ColorEdit3(("lf" + std::to_string(inc)).c_str(), col);
|
||||||
|
inc++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
ImGui::End();
|
ImGui::End();
|
||||||
|
|
||||||
|
@ -474,6 +520,8 @@ int main(int argc, char *argv[]) {
|
||||||
|
|
||||||
// end ImGui Content
|
// end ImGui Content
|
||||||
rlImGuiEnd();
|
rlImGuiEnd();
|
||||||
|
} else {
|
||||||
|
disc.enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
EndDrawing();
|
EndDrawing();
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#define IMGUI_DEFINE_MATH_OPERATORS
|
#define IMGUI_DEFINE_MATH_OPERATORS
|
||||||
#include "imgui.h"
|
#include "imgui.h"
|
||||||
|
|
||||||
|
#include <cpp/score/score.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
@ -19,6 +20,7 @@ MprisPlayer::MprisPlayer(std::string servicename) {
|
||||||
image_path_cache = "NULL";
|
image_path_cache = "NULL";
|
||||||
PlayerProxy = sdbus::createProxy(dest, objec);
|
PlayerProxy = sdbus::createProxy(dest, objec);
|
||||||
mp2 = "org.mpris.MediaPlayer2.Player";
|
mp2 = "org.mpris.MediaPlayer2.Player";
|
||||||
|
imagecount = 0;
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,6 +64,33 @@ void MprisPlayer::Refresh() {
|
||||||
if (current_metadata["mpris:artUrl"].get<std::string>() != image_path_cache) {
|
if (current_metadata["mpris:artUrl"].get<std::string>() != image_path_cache) {
|
||||||
image_path_cache = current_metadata["mpris:artUrl"].get<std::string>();
|
image_path_cache = current_metadata["mpris:artUrl"].get<std::string>();
|
||||||
UpdateTexture();
|
UpdateTexture();
|
||||||
|
auto img = LoadImageFromTexture(tex.tex);
|
||||||
|
|
||||||
|
std::vector <material_color_utilities::Argb> argbs;
|
||||||
|
material_color_utilities::QuantizerResult res;
|
||||||
|
if (img.format == PIXELFORMAT_UNCOMPRESSED_R8G8B8A8) {
|
||||||
|
auto data = (char*) img.data;
|
||||||
|
for (int i = 0; i < img.width * img.height * 4; i += 4) {
|
||||||
|
material_color_utilities::Argb color = (data[i] << 16) | (data[i + 1] << 8) | (data[i + 2]) | (data[i + 3] << 24);
|
||||||
|
argbs.push_back(color);
|
||||||
|
}
|
||||||
|
res = material_color_utilities::QuantizeCelebi(argbs, 16);
|
||||||
|
} else if (img.format == PIXELFORMAT_UNCOMPRESSED_R8G8B8) {
|
||||||
|
auto data = (char*) img.data;
|
||||||
|
for (int i = 0; i < img.width * img.height * 3; i += 3) {
|
||||||
|
material_color_utilities::Argb color = (data[i] << 16) | (data[i + 1] << 8) | (data[i + 2] | (0xFF << 24));
|
||||||
|
argbs.push_back(color);
|
||||||
|
}
|
||||||
|
res = material_color_utilities::QuantizeCelebi(argbs, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto colors = material_color_utilities::RankedSuggestions(res.color_to_count, material_color_utilities::ScoreOptions());
|
||||||
|
accent_colors.clear();
|
||||||
|
for (auto obj : colors) {
|
||||||
|
accent_colors.push_back((Color) {.r=(unsigned char) ((obj >> 16) & 0xFF), .g=(unsigned char)( (obj >> 8) & 0xFF ), .b=(unsigned char)((obj >> 0) & 0xFF), .a=(unsigned char)((obj>>24) & 0xFF) });
|
||||||
|
}
|
||||||
|
imagecount = imagecount + 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
} catch (const std::exception& e) {}
|
} catch (const std::exception& e) {}
|
||||||
return;
|
return;
|
||||||
|
@ -177,6 +206,16 @@ void MprisPlayer::UpdateTexture() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Color MprisPlayer::GetPrimaryColor() {
|
||||||
|
if (accent_colors.empty()) {
|
||||||
|
return BLACK;
|
||||||
|
} else {
|
||||||
|
std::cout << "here" << std::endl;
|
||||||
|
return accent_colors[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
DiscObject::DiscObject(float ia) {
|
DiscObject::DiscObject(float ia) {
|
||||||
pos = 0;
|
pos = 0;
|
||||||
prevouspos = 0;
|
prevouspos = 0;
|
||||||
|
@ -184,6 +223,7 @@ DiscObject::DiscObject(float ia) {
|
||||||
accel = 0;
|
accel = 0;
|
||||||
target = ia;
|
target = ia;
|
||||||
active = true;
|
active = true;
|
||||||
|
enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DiscObject::Activate() {
|
void DiscObject::Activate() {
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#include <sdbus-c++/IConnection.h>
|
#include <sdbus-c++/IConnection.h>
|
||||||
#include <sdbus-c++/IProxy.h>
|
#include <sdbus-c++/IProxy.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include "cpp/quantize/celebi.h"
|
||||||
|
|
||||||
class RayTexture {
|
class RayTexture {
|
||||||
public:
|
public:
|
||||||
|
@ -30,6 +31,7 @@ public:
|
||||||
float accel;
|
float accel;
|
||||||
float target;
|
float target;
|
||||||
bool active;
|
bool active;
|
||||||
|
bool enabled;
|
||||||
DiscObject(float ia);
|
DiscObject(float ia);
|
||||||
void UpdatePos(float dtime);
|
void UpdatePos(float dtime);
|
||||||
void UpdatePos(float pos, float dtime);
|
void UpdatePos(float pos, float dtime);
|
||||||
|
@ -45,7 +47,9 @@ class MprisPlayer {
|
||||||
sdbus::InterfaceName mp2;
|
sdbus::InterfaceName mp2;
|
||||||
sdbus::MethodName playpause;
|
sdbus::MethodName playpause;
|
||||||
RayTexture tex;
|
RayTexture tex;
|
||||||
|
std::vector<Color> accent_colors;
|
||||||
std::string image_path_cache;
|
std::string image_path_cache;
|
||||||
|
long imagecount;
|
||||||
explicit MprisPlayer(std::string servicename);
|
explicit MprisPlayer(std::string servicename);
|
||||||
void PausePlay();
|
void PausePlay();
|
||||||
void Refresh();
|
void Refresh();
|
||||||
|
@ -57,6 +61,7 @@ class MprisPlayer {
|
||||||
std::string GetIdentity();
|
std::string GetIdentity();
|
||||||
std::unordered_map<std::string, sdbus::Variant> current_metadata;
|
std::unordered_map<std::string, sdbus::Variant> current_metadata;
|
||||||
std::unordered_map<std::string, sdbus::Variant> GetCurrentMetadata();
|
std::unordered_map<std::string, sdbus::Variant> GetCurrentMetadata();
|
||||||
|
Color GetPrimaryColor();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue