mirror of
https://github.com/clangen/musikcube.git
synced 2025-01-16 04:14:05 +00:00
Ensure visualizers are sorted by name.
This commit is contained in:
parent
f822bc0162
commit
b2673a9c35
@ -37,39 +37,70 @@
|
||||
#include <core/plugin/PluginFactory.h>
|
||||
|
||||
#include <atomic>
|
||||
#include <algorithm>
|
||||
|
||||
using namespace musik::core::audio;
|
||||
|
||||
static std::vector<std::shared_ptr<ISpectrumVisualizer> > spectrumVisualizers;
|
||||
static std::vector<std::shared_ptr<IPcmVisualizer> > pcmVisualizers;
|
||||
static std::vector<std::shared_ptr<IVisualizer > > visualizers;
|
||||
static std::atomic<bool> initialized;
|
||||
|
||||
static std::shared_ptr<IVisualizer> selectedVisualizer;
|
||||
static ISpectrumVisualizer* spectrumVisualizer = nullptr;
|
||||
static IPcmVisualizer* pcmVisualizer = nullptr;
|
||||
|
||||
#define LOWER(x) std::transform(x.begin(), x.end(), x.begin(), tolower);
|
||||
|
||||
namespace musik {
|
||||
namespace core {
|
||||
namespace audio {
|
||||
namespace vis {
|
||||
static void init() {
|
||||
{
|
||||
typedef PluginFactory::DestroyDeleter<ISpectrumVisualizer> Deleter;
|
||||
/* spectrum visualizers */
|
||||
typedef PluginFactory::DestroyDeleter<ISpectrumVisualizer> SpectrumDeleter;
|
||||
std::vector<std::shared_ptr<ISpectrumVisualizer> > spectrum;
|
||||
|
||||
spectrumVisualizers = PluginFactory::Instance()
|
||||
.QueryInterface<ISpectrumVisualizer, Deleter>("GetSpectrumVisualizer");
|
||||
spectrum = PluginFactory::Instance()
|
||||
.QueryInterface<ISpectrumVisualizer, SpectrumDeleter>("GetSpectrumVisualizer");
|
||||
|
||||
for (auto it = spectrum.begin(); it != spectrum.end(); it++) {
|
||||
visualizers.push_back(*it);
|
||||
}
|
||||
|
||||
{
|
||||
typedef PluginFactory::DestroyDeleter<IPcmVisualizer> Deleter;
|
||||
/* pcm visualizers */
|
||||
typedef PluginFactory::DestroyDeleter<IPcmVisualizer> PcmDeleter;
|
||||
std::vector<std::shared_ptr<IPcmVisualizer> > pcm;
|
||||
|
||||
pcmVisualizers = PluginFactory::Instance()
|
||||
.QueryInterface<IPcmVisualizer, Deleter>("GetPcmVisualizer");
|
||||
pcm = PluginFactory::Instance()
|
||||
.QueryInterface<IPcmVisualizer, PcmDeleter>("GetPcmVisualizer");
|
||||
|
||||
for (auto it = pcm.begin(); it != pcm.end(); it++) {
|
||||
visualizers.push_back(*it);
|
||||
}
|
||||
|
||||
/* sort 'em by name */
|
||||
using V = std::shared_ptr<IVisualizer>;
|
||||
|
||||
std::sort(
|
||||
visualizers.begin(),
|
||||
visualizers.end(),
|
||||
[](V left, V right) -> bool {
|
||||
std::string l = left->Name();
|
||||
LOWER(l);
|
||||
std::string r = right->Name();
|
||||
LOWER(r);
|
||||
return l < r;
|
||||
});
|
||||
|
||||
initialized = true;
|
||||
}
|
||||
|
||||
void HideSelectedVisualizer() {
|
||||
if (selectedVisualizer) {
|
||||
selectedVisualizer->Hide();
|
||||
SetSelectedVisualizer(std::shared_ptr<IVisualizer>());
|
||||
}
|
||||
}
|
||||
|
||||
ISpectrumVisualizer* SpectrumVisualizer() {
|
||||
return spectrumVisualizer;
|
||||
}
|
||||
@ -79,11 +110,7 @@ namespace musik {
|
||||
}
|
||||
|
||||
std::shared_ptr<IVisualizer> GetVisualizer(size_t index) {
|
||||
if (index < pcmVisualizers.size()) {
|
||||
return pcmVisualizers.at(index);
|
||||
}
|
||||
|
||||
return spectrumVisualizers.at(index - pcmVisualizers.size());
|
||||
return visualizers.at(index);
|
||||
}
|
||||
|
||||
size_t VisualizerCount() {
|
||||
@ -91,7 +118,7 @@ namespace musik {
|
||||
init();
|
||||
}
|
||||
|
||||
return pcmVisualizers.size() + spectrumVisualizers.size();
|
||||
return visualizers.size();
|
||||
}
|
||||
|
||||
void SetSelectedVisualizer(std::shared_ptr<IVisualizer> visualizer) {
|
||||
|
@ -47,5 +47,6 @@ namespace musik { namespace core { namespace audio { namespace vis {
|
||||
size_t VisualizerCount();
|
||||
void SetSelectedVisualizer(std::shared_ptr<IVisualizer> visualizer);
|
||||
std::shared_ptr<IVisualizer> SelectedVisualizer();
|
||||
void HideSelectedVisualizer();
|
||||
|
||||
} } } }
|
||||
|
@ -79,8 +79,6 @@ PluginFactory::~PluginFactory(void){
|
||||
loadedDlls.clear();
|
||||
}
|
||||
|
||||
#include <iostream>
|
||||
|
||||
void PluginFactory::LoadPlugins(){
|
||||
boost::mutex::scoped_lock lock(this->mutex);
|
||||
|
||||
|
@ -49,6 +49,7 @@
|
||||
#include <core/library/LibraryFactory.h>
|
||||
#include <core/audio/GaplessTransport.h>
|
||||
#include <core/support/PreferenceKeys.h>
|
||||
#include <core/audio/Visualizer.h>
|
||||
|
||||
#include <cstdio>
|
||||
|
||||
@ -148,6 +149,8 @@ int main(int argc, char* argv[])
|
||||
app.Run(mainLayout);
|
||||
}
|
||||
|
||||
musik::core::audio::vis::HideSelectedVisualizer();
|
||||
|
||||
LibraryFactory::Instance().Shutdown();
|
||||
musik::debug::deinit();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user