UIWebView.cpp 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. //
  2. // Copyright (c) 2014-2015, THUNDERBEAST GAMES LLC All rights reserved
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to deal
  6. // in the Software without restriction, including without limitation the rights
  7. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. // copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20. // THE SOFTWARE.
  21. //
  22. #include <Atomic/IO/Log.h>
  23. #include <Atomic/Input/InputEvents.h>
  24. #include <Atomic/Input/Input.h>
  25. #include <Atomic/UI/UIRenderer.h>
  26. #include "WebClient.h"
  27. #include "WebTexture2D.h"
  28. #include "WebBrowserHost.h"
  29. #include "UIWebView.h"
  30. using namespace tb;
  31. namespace Atomic
  32. {
  33. class WebViewWidget : public tb::TBWidget
  34. {
  35. friend class UIWebView;
  36. public:
  37. // For safe typecasting
  38. TBOBJECT_SUBCLASS(WebViewWidget, tb::TBWidget);
  39. WebViewWidget() : browserCreated_(false)
  40. {
  41. vertexData_.Resize(6 * UI_VERTEX_SIZE);
  42. float color;
  43. ((unsigned&)color) = 0xFFFFFFFF;
  44. float* data = &vertexData_[0];
  45. data[2] = 0; data[3] = color; data[4] = 0; data[5] = 0;
  46. data[8] = 0; data[9] = color; data[10] = 1; data[11] = 0;
  47. data[14] = 0; data[15] = color; data[16] = 1; data[17] = 1;
  48. data[20] = 0; data[21] = color; data[22] = 0; data[23] = 0;
  49. data[26] = 0; data[27] = color; data[28] = 1; data[29] = 1;
  50. data[32] = 0; data[33] = color; data[34] = 0; data[35] = 1;
  51. }
  52. void OnProcess()
  53. {
  54. TBWidget::OnProcess();
  55. if (webView_.Null())
  56. return;
  57. if (!browserCreated_)
  58. {
  59. browserCreated_ = true;
  60. TBRect rect = GetRect();
  61. webView_->webClient_->CreateBrowser(webView_->initialURL_, rect.w, rect.h);
  62. }
  63. }
  64. void OnResized(int oldW, int oldH)
  65. {
  66. if (webView_.Null())
  67. return;
  68. TBRect rect = GetRect();
  69. if ((rect.w < 0 || rect.h < 0) || (rect.w == rect.h == 0))
  70. return;
  71. webView_->webClient_->SetSize(rect.w, rect.h);
  72. }
  73. void OnPaint(const PaintProps &paint_props)
  74. {
  75. if (webView_.Null())
  76. return;
  77. TBRect rect = GetRect();
  78. rect.x = rect.y = 0;
  79. ConvertToRoot(rect.x, rect.y);
  80. float* data = &vertexData_[0];
  81. UI* ui = webView_->GetSubsystem<UI>();
  82. float color;
  83. float fopacity = GetOpacity() * ui->GetRenderer()->GetOpacity();
  84. unsigned char opacity = (unsigned char) (fopacity* 255.0f);
  85. ((unsigned&)color) = (0x00FFFFFF + (((uint32)opacity) << 24));
  86. data[3] = color;
  87. data[9] = color;
  88. data[15] = color;
  89. data[21] = color;
  90. data[27] = color;
  91. data[33] = color;
  92. data[0] = rect.x;
  93. data[1] = rect.y;
  94. data[6] = rect.x + rect.w;
  95. data[7] = rect.y;
  96. data[12] = rect.x + rect.w;
  97. data[13] = rect.y + rect.h;
  98. data[18] = rect.x;
  99. data[19] = rect.y;
  100. data[24] = rect.x + rect.w;
  101. data[25] = rect.y + rect.h;
  102. data[30] = rect.x;
  103. data[31] = rect.y + rect.h;
  104. ui->SubmitBatchVertexData(webView_->GetWebTexture2D()->GetTexture2D(), vertexData_);
  105. }
  106. private:
  107. bool browserCreated_;
  108. WeakPtr<UIWebView> webView_;
  109. PODVector<float> vertexData_;
  110. };
  111. UIWebView::UIWebView(Context* context, const String &initialURL) : UIWidget(context, false)
  112. {
  113. widget_ = new WebViewWidget();
  114. widget_->SetDelegate(this);
  115. widget_->SetGravity(WIDGET_GRAVITY_ALL);
  116. widget_->SetIsFocusable(true);
  117. ((WebViewWidget*)widget_)->webView_ = this;
  118. UI* ui = GetSubsystem<UI>();
  119. ui->WrapWidget(this, widget_);
  120. webClient_ = new WebClient(context);
  121. webTexture_ = new WebTexture2D(context);
  122. webClient_->SetWebRenderHandler(webTexture_);
  123. initialURL_ = initialURL;
  124. SubscribeToEvent(E_KEYDOWN, HANDLER(UIWebView, HandleKeyDown));
  125. SubscribeToEvent(E_KEYUP, HANDLER(UIWebView, HandleKeyUp));
  126. SubscribeToEvent(E_TEXTINPUT, HANDLER(UIWebView, HandleTextInput));
  127. }
  128. UIWebView::~UIWebView()
  129. {
  130. }
  131. void UIWebView::HandleKeyDown(StringHash eventType, VariantMap& eventData)
  132. {
  133. if (!widget_ || !widget_->GetIsFocused())
  134. return;
  135. webClient_->SendKeyEvent(eventType, eventData);
  136. }
  137. void UIWebView::HandleKeyUp(StringHash eventType, VariantMap& eventData)
  138. {
  139. if (!widget_ || !widget_->GetIsFocused())
  140. return;
  141. webClient_->SendKeyEvent(eventType, eventData);
  142. }
  143. void UIWebView::HandleTextInput(StringHash eventType, VariantMap& eventData)
  144. {
  145. if (!widget_ || !widget_->GetIsFocused())
  146. return;
  147. webClient_->SendTextInputEvent(eventType, eventData);
  148. }
  149. bool UIWebView::OnEvent(const TBWidgetEvent &ev)
  150. {
  151. if (ev.type == EVENT_TYPE_POINTER_DOWN || ev.type == EVENT_TYPE_POINTER_UP)
  152. {
  153. webClient_->SendMouseClickEvent(ev.target_x, ev.target_y, 0, ev.type == EVENT_TYPE_POINTER_UP, 0);
  154. return true;
  155. }
  156. else if (ev.type == EVENT_TYPE_POINTER_MOVE)
  157. {
  158. webClient_->SendMouseMoveEvent(ev.target_x, ev.target_y, 0);
  159. return true;
  160. }
  161. else if (ev.type == EVENT_TYPE_WHEEL)
  162. {
  163. webClient_->SendMouseWheelEvent(ev.target_x, ev.target_y, 0, ev.delta_x, ev.delta_y);
  164. return true;
  165. }
  166. else if (ev.type == EVENT_TYPE_SHORTCUT)
  167. {
  168. if (ev.ref_id == TBIDC("copy"))
  169. {
  170. webClient_->ShortcutCopy();
  171. return true;
  172. }
  173. else if (ev.ref_id == TBIDC("paste"))
  174. {
  175. webClient_->ShortcutPaste();
  176. return true;
  177. }
  178. if (ev.ref_id == TBIDC("cut"))
  179. {
  180. webClient_->ShortcutCut();
  181. return true;
  182. }
  183. else if (ev.ref_id == TBIDC("selectall"))
  184. {
  185. webClient_->ShortcutSelectAll();
  186. return true;
  187. }
  188. else if (ev.ref_id == TBIDC("undo"))
  189. {
  190. webClient_->ShortcutUndo();
  191. return true;
  192. }
  193. else if (ev.ref_id == TBIDC("redo"))
  194. {
  195. webClient_->ShortcutRedo();
  196. return true;
  197. }
  198. }
  199. return UIWidget::OnEvent(ev);
  200. }
  201. void UIWebView::OnFocusChanged(bool focused)
  202. {
  203. webClient_->SendFocusEvent(focused);
  204. }
  205. WebTexture2D* UIWebView::GetWebTexture2D() const
  206. {
  207. return webTexture_;
  208. }
  209. }