Merge branch 'hotfix-1.4.1' into develop

This commit is contained in:
Jinhao 2017-04-12 07:35:05 +08:00
commit 74898dcc01
2 changed files with 78 additions and 45 deletions

View File

@ -95,8 +95,11 @@ namespace nana
void range(double begin, double last, double step); void range(double begin, double last, double step);
/// Sets the string spin values. /// Sets the string spin values.
void range(std::initializer_list<std::string> values_utf8); void range(std::vector<std::string> values_utf8);
void range(std::initializer_list<std::wstring> values);
std::vector<std::string> range_string() const;
std::pair<int, int> range_int() const;
std::pair<double, double> range_double() const;
/// Gets the spined value /// Gets the spined value
::std::string value() const; ::std::string value() const;

View File

@ -25,25 +25,6 @@ namespace nana
{ {
namespace spinbox namespace spinbox
{ {
class event_agent
: public widgets::skeletons::textbase_event_agent_interface
{
public:
event_agent(::nana::spinbox& wdg)
: widget_(wdg)
{}
void first_change() override{} //empty, because spinbox does not have this event.
void text_changed() override
{
widget_.events().text_changed.emit(::nana::arg_spinbox{ widget_ }, widget_.handle());
}
private:
::nana::spinbox & widget_;
};
enum class buttons enum class buttons
{ {
none, increase, decrease none, increase, decrease
@ -73,6 +54,11 @@ namespace nana
: begin_{ vbegin }, last_{ vlast }, step_{ step }, value_{ vbegin } : begin_{ vbegin }, last_{ vlast }, step_{ step }, value_{ vbegin }
{} {}
std::pair<T, T> range() const
{
return std::make_pair(begin_, last_);
}
std::string value() const override std::string value() const override
{ {
return std::to_string(value_); return std::to_string(value_);
@ -85,7 +71,8 @@ namespace nana
T v; T v;
ss >> v; ss >> v;
if (v < begin_ || last_ < v)
if (ss.fail() || v < begin_ || last_ < v)
return false; return false;
diff = (value_ != v); diff = (value_ != v);
@ -157,19 +144,14 @@ namespace nana
: public range_interface : public range_interface
{ {
public: public:
range_text(std::initializer_list<std::string> & initlist) range_text(std::vector<std::string>&& texts):
: texts_(initlist) texts_(std::move(texts))
{ {
for (auto & s : initlist)
{
texts_.emplace_back(std::string{ s });
}
} }
range_text(std::initializer_list<std::wstring>& initlist) const std::vector<std::string>& range() const
{ {
for (auto & s : initlist) return texts_;
texts_.emplace_back(to_utf8(s));
} }
std::string value() const override std::string value() const override
@ -229,6 +211,29 @@ namespace nana
class implementation class implementation
{ {
class event_agent
: public widgets::skeletons::textbase_event_agent_interface
{
public:
event_agent(implementation* impl)
: impl_(impl)
{}
void first_change() override {} //empty, because spinbox does not have this event.
void text_changed() override
{
auto wdg = static_cast<nana::spinbox*>(API::get_widget(impl_->editor_->window_handle()));
if (!impl_->value(to_utf8(impl_->editor_->text()), false))
API::refresh_window(wdg->handle());
wdg->events().text_changed.emit(*wdg, wdg->handle());
}
private:
implementation* const impl_;
};
public: public:
implementation() implementation()
{ {
@ -269,7 +274,7 @@ namespace nana
return range_->check_value(to_utf8(str)); return range_->check_value(to_utf8(str));
}); });
evt_agent_.reset(new event_agent(static_cast<nana::spinbox&>(wdg))); evt_agent_.reset(new event_agent{this});
editor_->textbase().set_event_agent(evt_agent_.get()); editor_->textbase().set_event_agent(evt_agent_.get());
if (!range_) if (!range_)
@ -313,6 +318,11 @@ namespace nana
reset_text(); reset_text();
} }
const range_interface* range() const
{
return range_.get();
}
void modifier(std::string&& prefix, std::string&& suffix) void modifier(std::string&& prefix, std::string&& suffix)
{ {
modifier_.prefix = std::move(prefix); modifier_.prefix = std::move(prefix);
@ -423,10 +433,15 @@ namespace nana
if (!editor_) if (!editor_)
return; return;
std::wstring text;
if (API::is_focus_ready(editor_->window_handle())) if (API::is_focus_ready(editor_->window_handle()))
editor_->text(to_wstring(range_->value()), false); text = to_wstring(range_->value());
else else
editor_->text(to_wstring(modifier_.prefix + range_->value() + modifier_.suffix), false); text = to_wstring(modifier_.prefix + range_->value() + modifier_.suffix);
if (editor_->text() != text)
editor_->text(text, false);
_m_draw_spins(spin_stated_); _m_draw_spins(spin_stated_);
} }
@ -574,13 +589,8 @@ namespace nana
{ {
impl_->editor()->respond_char(arg); impl_->editor()->respond_char(arg);
if (impl_->editor()->try_refresh()) if (impl_->editor()->try_refresh())
{
impl_->value(to_utf8(impl_->editor()->text()), false);
impl_->draw_spins();
API::dev::lazy_refresh(); API::dev::lazy_refresh();
} }
}
void drawer::resized(graph_reference, const arg_resized&) void drawer::resized(graph_reference, const arg_resized&)
{ {
@ -633,18 +643,38 @@ namespace nana
API::refresh_window(handle()); API::refresh_window(handle());
} }
void spinbox::range(std::initializer_list<std::string> steps_utf8) void spinbox::range(std::vector<std::string> values)
{ {
using namespace drawerbase::spinbox; using namespace drawerbase::spinbox;
get_drawer_trigger().impl()->set_range(std::unique_ptr<range_interface>(new range_text(steps_utf8))); get_drawer_trigger().impl()->set_range(std::unique_ptr<range_interface>(new range_text(std::move(values))));
API::refresh_window(handle()); API::refresh_window(handle());
} }
void spinbox::range(std::initializer_list<std::wstring> steps) std::vector<std::string> spinbox::range_string() const
{ {
using namespace drawerbase::spinbox; auto range = dynamic_cast<const drawerbase::spinbox::range_text*>(get_drawer_trigger().impl()->range());
get_drawer_trigger().impl()->set_range(std::unique_ptr<range_interface>(new range_text(steps))); if (nullptr == range)
API::refresh_window(handle()); throw std::runtime_error("the type of spinbox range is not string");
return range->range();
}
std::pair<int, int> spinbox::range_int() const
{
auto range = dynamic_cast<const drawerbase::spinbox::range_numeric<int>*>(get_drawer_trigger().impl()->range());
if (nullptr == range)
throw std::runtime_error("the type of spinbox range is not integer");
return range->range();
}
std::pair<double, double> spinbox::range_double() const
{
auto range = dynamic_cast<const drawerbase::spinbox::range_numeric<double>*>(get_drawer_trigger().impl()->range());
if (nullptr == range)
throw std::runtime_error("the type of spinbox range is not double");
return range->range();
} }
::std::string spinbox::value() const ::std::string spinbox::value() const