| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530 |
- //--player --editor-resource-paths "/Users/josh/Dev/atomic/AtomicGameEngine/Data/AtomicPlayer/Resources/CoreData!/Users/josh/Dev/atomic/AtomicGameEngine/Data/AtomicPlayer/Resources/PlayerData!/Users/josh/Dev/atomic/AtomicExamples/UIExample/Resources"
- #include "../IO/Log.h"
- #include "UIEvents.h"
- #include "UI.h"
- #include "UIWidget.h"
- #include "UILayout.h"
- #include "UIFontDescription.h"
- using namespace tb;
- namespace Atomic
- {
- UIWidget::UIWidget(Context* context, bool createWidget) : Object(context),
- widget_(0),
- preferredSize_(new UIPreferredSize())
- {
- AddRef();
- if (createWidget)
- {
- widget_ = new TBWidget();
- widget_->SetDelegate(this);
- GetSubsystem<UI>()->WrapWidget(this, widget_);
- }
- }
- UIWidget::~UIWidget()
- {
- }
- void UIWidget::SetIsFocusable(bool value)
- {
- if (!widget_)
- return;
- widget_->SetIsFocusable(value);
- }
- bool UIWidget::Load(const String& filename)
- {
- UI* ui = GetSubsystem<UI>();
- if (!ui->LoadResourceFile(widget_ , filename))
- return false;
- VariantMap eventData;
- eventData[WidgetLoaded::P_WIDGET] = this;
- SendEvent(E_WIDGETLOADED, eventData);
- return true;
- }
- UIPreferredSize* UIWidget::GetPreferredSize()
- {
- // error
- if (!widget_)
- return preferredSize_;
- preferredSize_->SetFromTBPreferredSize(widget_->GetPreferredSize());
- return preferredSize_;
- }
- UIWidget* UIWidget::GetWidget(const String& id)
- {
- if (!widget_)
- return 0;
- TBWidget* child = widget_->GetWidgetByID(TBID(id.CString()));
- if (!child)
- return 0;
- UI* ui = GetSubsystem<UI>();
- return ui->WrapWidget(child);
- }
- void UIWidget::SetWidget(tb::TBWidget* widget)
- {
- widget_ = widget;
- widget_->SetDelegate(this);
- }
- void UIWidget::ConvertEvent(UIWidget *handler, UIWidget* target, const tb::TBWidgetEvent &ev, VariantMap& data)
- {
- UI* ui = GetSubsystem<UI>();
- String id;
- ui->GetTBIDString(ev.ref_id, id);
- using namespace WidgetEvent;
- data[P_HANDLER] = handler;
- data[P_TARGET] = target;
- data[P_TYPE] = (unsigned) ev.type;
- data[P_X] = ev.target_x;
- data[P_Y] = ev.target_y;
- data[P_DELTAX] = ev.delta_x;
- data[P_DELTAY] = ev.delta_y;
- data[P_COUNT] = ev.count;
- data[P_KEY] = ev.key;
- data[P_SPECIALKEY] = (unsigned) ev.special_key;
- data[P_MODIFIERKEYS] = (unsigned) ev.modifierkeys;
- data[P_REFID] = id;
- data[P_TOUCH] = (unsigned) ev.touch;
- }
- void UIWidget::OnDelete()
- {
- if (widget_)
- {
- // if we don't have a UI subsystem, we are exiting
- UI* ui = GetSubsystem<UI>();
- if (ui)
- ui->UnwrapWidget(widget_);
- }
- widget_ = 0;
- VariantMap eventData;
- eventData[WidgetDeleted::P_WIDGET] = this;
- SendEvent(E_WIDGETDELETED, eventData);
- ReleaseRef();
- }
- void UIWidget::AddChild(UIWidget* child)
- {
- if (!widget_ || !child->widget_)
- return;
- widget_->AddChild(child->widget_);
- }
- void UIWidget::SetText(const String& text)
- {
- if (!widget_)
- return;
- widget_->SetText(text.CString());
- }
- void UIWidget::SetGravity(UI_GRAVITY gravity)
- {
- if (!widget_)
- return;
- widget_->SetGravity((WIDGET_GRAVITY) gravity);
- }
- void UIWidget::SetPosition(int x, int y)
- {
- if (!widget_)
- return;
- widget_->SetPosition(TBPoint(x, y));
- }
- IntRect UIWidget::GetRect()
- {
- IntRect rect(0, 0, 0, 0);
- if (!widget_)
- return rect;
- tb::TBRect tbrect = widget_->GetRect();
- rect.top_ = tbrect.y;
- rect.left_ = tbrect.x;
- rect.right_ = tbrect.x + tbrect.w;
- rect.bottom_ = tbrect.y + tbrect.h;
- return rect;
- }
- void UIWidget::SetRect(IntRect rect)
- {
- if (!widget_)
- return;
- tb::TBRect tbrect;
- tbrect.y = rect.top_;
- tbrect.x = rect.left_;
- tbrect.w = rect.right_ - rect.left_;
- tbrect.h = rect.bottom_ - rect.top_;
- widget_->SetRect(tbrect);
- }
- void UIWidget::SetSize(int width, int height)
- {
- if (!widget_)
- return;
- widget_->SetSize(width, height);
- }
- void UIWidget::Invalidate()
- {
- if (!widget_)
- return;
- widget_->Invalidate();
- }
- void UIWidget::Center()
- {
- if (!widget_)
- return;
- // this should center on parent widget, not root
- UI* ui = GetSubsystem<UI>();
- TBRect rect = widget_->GetRect();
- TBWidget* root = ui->GetRootWidget();
- TBRect bounds(0, 0, root->GetRect().w, root->GetRect().h);
- widget_->SetRect(rect.CenterIn(bounds).MoveIn(bounds).Clip(bounds));
- }
- UIWidget* UIWidget::GetParent()
- {
- if (!widget_)
- return 0;
- TBWidget* parent = widget_->GetParent();
- if (!parent)
- return 0;
- UI* ui = GetSubsystem<UI>();
- return ui->WrapWidget(parent);
- }
- UIWidget* UIWidget::GetContentRoot()
- {
- if (!widget_)
- return 0;
- TBWidget* root = widget_->GetContentRoot();
- if (!root)
- return 0;
- UI* ui = GetSubsystem<UI>();
- return ui->WrapWidget(root);
- }
- void UIWidget::Die()
- {
- if (!widget_)
- return;
- // clear delegate
- widget_->SetDelegate(NULL);
- // explictly die (can trigger an animation)
- widget_->Die();
- // call OnDelete, which unwraps the widget and does some bookkeeping
- OnDelete();
- }
- void UIWidget::SetLayoutParams(UILayoutParams* params)
- {
- if (!widget_)
- return;
- widget_->SetLayoutParams(*(params->GetTBLayoutParams()));
- }
- void UIWidget::SetFontDescription(UIFontDescription* fd)
- {
- if (!widget_)
- return;
- widget_->SetFontDescription(*(fd->GetTBFontDescription()));
- }
- void UIWidget::DeleteAllChildren()
- {
- if (!widget_)
- return;
- widget_->DeleteAllChildren();
- }
- void UIWidget::SetSkinBg(const String& id)
- {
- if (!widget_)
- return;
- widget_->SetSkinBg(TBIDC(id.CString()));
- }
- void UIWidget::RemoveChild(UIWidget* child, bool cleanup)
- {
- if (!widget_ || !child)
- return;
- TBWidget* childw = child->GetInternalWidget();
- if (!childw)
- return;
- widget_->RemoveChild(childw);
- if (cleanup)
- delete childw;
- }
- const String& UIWidget::GetId()
- {
- if (!widget_ || !widget_->GetID())
- {
- if (id_.Length())
- id_.Clear();
- return id_;
- }
- if (id_.Length())
- return id_;
- UI* ui = GetSubsystem<UI>();
- ui->GetTBIDString(widget_->GetID(), id_);
- return id_;
- }
- void UIWidget::SetId(const String& id)
- {
- if (!widget_)
- {
- if (id_.Length())
- id_.Clear();
- return;
- }
- id_ = id;
- widget_->SetID(TBIDC(id.CString()));
- }
- void UIWidget::SetState(/*WIDGET_STATE*/ unsigned state, bool on)
- {
- if (!widget_)
- return;
- widget_->SetState((WIDGET_STATE) state, on);
- }
- void UIWidget::SetFocus()
- {
- if (!widget_)
- return;
- widget_->SetFocus(WIDGET_FOCUS_REASON_UNKNOWN);
- }
- void UIWidget::SetVisibility(UI_WIDGET_VISIBILITY visibility)
- {
- if (!widget_)
- return;
- widget_->SetVisibilility((WIDGET_VISIBILITY) visibility);
- }
- UI_WIDGET_VISIBILITY UIWidget::GetVisibility()
- {
- if (!widget_)
- return UI_WIDGET_VISIBILITY_GONE;
- return (UI_WIDGET_VISIBILITY) widget_->GetVisibility();
- }
- UIWidget* UIWidget::GetFirstChild()
- {
- if (!widget_)
- return NULL;
- return GetSubsystem<UI>()->WrapWidget(widget_->GetFirstChild());
- }
- UIWidget* UIWidget::GetNext()
- {
- if (!widget_)
- return NULL;
- return GetSubsystem<UI>()->WrapWidget(widget_->GetNext());
- }
- void UIWidget::SetValue(double value)
- {
- if (!widget_)
- return;
- widget_->SetValueDouble(value);
- }
- double UIWidget::GetValue()
- {
- if (!widget_)
- return 0.0;
- return widget_->GetValueDouble();
- }
- bool UIWidget::GetState(/*WIDGET_STATE*/ unsigned state)
- {
- if (!widget_)
- return false;
- return widget_->GetState((WIDGET_STATE) state);
- }
- void UIWidget::SetStateRaw(/*WIDGET_STATE*/ unsigned state)
- {
- if (!widget_)
- return;
- widget_->SetStateRaw((WIDGET_STATE) state);
- }
- /*WIDGET_STATE*/ unsigned UIWidget::GetStateRaw()
- {
- if (!widget_)
- return false;
- return (unsigned) widget_->GetStateRaw();
- }
- bool UIWidget::OnEvent(const tb::TBWidgetEvent &ev)
- {
- UI* ui = GetSubsystem<UI>();
- if (ev.type == EVENT_TYPE_CHANGED)
- {
- if (!ev.target || ui->IsWidgetWrapped(ev.target))
- {
- VariantMap eventData;
- ConvertEvent(this, ui->WrapWidget(ev.target), ev, eventData);
- SendEvent(E_WIDGETEVENT, eventData);
- if (eventData[WidgetEvent::P_HANDLED].GetBool())
- return true;
- }
- }
- else if (ev.type == EVENT_TYPE_TAB_CHANGED)
- {
- if (!ev.target || ui->IsWidgetWrapped(ev.target))
- {
- VariantMap eventData;
- ConvertEvent(this, ui->WrapWidget(ev.target), ev, eventData);
- SendEvent(E_WIDGETEVENT, eventData);
- if (eventData[WidgetEvent::P_HANDLED].GetBool())
- return true;
- }
- }
- else if (ev.type == EVENT_TYPE_CLICK)
- {
- if (ev.target && ev.target->GetID() == TBID("__popup-menu"))
- {
- // popup menu
- if (JSGetHeapPtr())
- {
- VariantMap eventData;
- eventData[PopupMenuSelect::P_BUTTON] = this;
- String id;
- ui->GetTBIDString(ev.ref_id, id);
- eventData[PopupMenuSelect::P_REFID] = id;
- SendEvent(E_POPUPMENUSELECT, eventData);
- }
- return true;
- }
- else
- {
- if (!ev.target || ui->IsWidgetWrapped(ev.target))
- {
- VariantMap eventData;
- ConvertEvent(this, ui->WrapWidget(ev.target), ev, eventData);
- SendEvent(E_WIDGETEVENT, eventData);
- if (eventData[WidgetEvent::P_HANDLED].GetBool())
- return true;
- }
- }
- }
- return false;
- }
- }
|