X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Fselection.h;h=89f7100e3e6e854945219bf074ad7f4ff3388e4f;hb=dfeb2d2896fe18e55b1f6c4a8028b7cfb878dede;hp=acf8bf6bf09131a415a6a3a8b56037c86d2e9b22;hpb=d15ac13f2e170f155b4bbd124df48400c339b644;p=r2c2.git diff --git a/source/designer/selection.h b/source/designer/selection.h index acf8bf6..89f7100 100644 --- a/source/designer/selection.h +++ b/source/designer/selection.h @@ -3,7 +3,7 @@ #include #include -#include "3d/track.h" +#include "libr2c2/object.h" class Selection { @@ -11,27 +11,47 @@ public: sigc::signal signal_changed; private: - std::set tracks; + std::set objects; public: - const std::set &get_tracks() const { return tracks; } - R2C2::Track *get_track() const; - unsigned size() const { return tracks.size(); } - bool empty() const { return tracks.empty(); } + const std::set &get_objects() const { return objects; } + R2C2::Object *get_object() const; + + template + std::set get_objects() const + { + std::set result; + for(std::set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + if(T *to = dynamic_cast(*i)) + result.insert(to); + return result; + } + + template + T *get_object() const + { + for(std::set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + if(T *to = dynamic_cast(*i)) + return to; + return 0; + } + + unsigned size() const { return objects.size(); } + bool empty() const { return objects.empty(); } void clear(); template void replace(Iter begin, Iter end) { - tracks.clear(); - tracks.insert(begin, end); + objects.clear(); + objects.insert(begin, end); signal_changed.emit(); } - void add_track(R2C2::Track *); - void remove_track(R2C2::Track *); - void toggle_track(R2C2::Track *); + void add_object(R2C2::Object *); + void remove_object(R2C2::Object *); + void toggle_object(R2C2::Object *); void select_more(); void select_linked();