diff --git a/samples/webgl/WasmOcctView.cpp b/samples/webgl/WasmOcctView.cpp index 53e0096030..8aa88568b9 100644 --- a/samples/webgl/WasmOcctView.cpp +++ b/samples/webgl/WasmOcctView.cpp @@ -114,7 +114,7 @@ WasmOcctView& WasmOcctView::Instance() // ================================================================ WasmOcctView::WasmOcctView() : myDevicePixelRatio (1.0f), - myUpdateRequests (0) + myNbUpdateRequests (0) { addActionHotKeys (Aspect_VKey_NavForward, Aspect_VKey_W, Aspect_VKey_W | Aspect_VKeyFlags_SHIFT); addActionHotKeys (Aspect_VKey_NavBackward , Aspect_VKey_S, Aspect_VKey_S | Aspect_VKeyFlags_SHIFT); @@ -395,9 +395,11 @@ void WasmOcctView::ProcessInput() // Queue onRedrawView()/redrawView callback to redraw canvas after all user input is flushed by browser. // Redrawing viewer on every single message would be a pointless waste of resources, // as user will see only the last drawn frame due to WebGL implementation details. - if (++myUpdateRequests == 1) + // -1 in emscripten_async_call() redirects to requestAnimationFrame(); + // requestPostAnimationFrame() is a better under development alternative. + if (++myNbUpdateRequests == 1) { - emscripten_async_call (onRedrawView, this, 0); + emscripten_async_call (onRedrawView, this, -1); } } } @@ -424,6 +426,7 @@ void WasmOcctView::redrawView() { if (!myView.IsNull()) { + myNbUpdateRequests = 0; FlushViewEvents (myContext, myView, true); } } @@ -435,13 +438,14 @@ void WasmOcctView::redrawView() void WasmOcctView::handleViewRedraw (const Handle(AIS_InteractiveContext)& theCtx, const Handle(V3d_View)& theView) { - myUpdateRequests = 0; AIS_ViewController::handleViewRedraw (theCtx, theView); if (myToAskNextFrame) { // ask more frames - ++myUpdateRequests; - emscripten_async_call (onRedrawView, this, 0); + if (++myNbUpdateRequests == 1) + { + emscripten_async_call (onRedrawView, this, -1); + } } } diff --git a/samples/webgl/WasmOcctView.h b/samples/webgl/WasmOcctView.h index 58921a6bed..e5be3c6cb3 100644 --- a/samples/webgl/WasmOcctView.h +++ b/samples/webgl/WasmOcctView.h @@ -249,7 +249,7 @@ private: TCollection_AsciiString myCanvasId; //!< canvas element id on HTML page Graphic3d_Vec2i myWinSizeOld; float myDevicePixelRatio; //!< device pixel ratio for handling high DPI displays - unsigned int myUpdateRequests; //!< counter for unhandled update requests + unsigned int myNbUpdateRequests; //!< counter for unhandled update requests }; diff --git a/src/RWGltf/RWGltf_TriangulationReader.cxx b/src/RWGltf/RWGltf_TriangulationReader.cxx index 16ad9b9fa6..c528ae6134 100644 --- a/src/RWGltf/RWGltf_TriangulationReader.cxx +++ b/src/RWGltf/RWGltf_TriangulationReader.cxx @@ -224,7 +224,7 @@ bool RWGltf_TriangulationReader::readDracoBuffer (const Handle(RWGltf_GltfLatePr #ifdef HAVE_DRACO std::vector aReadData; - aReadData.resize (theGltfData.StreamLength); + aReadData.resize ((size_t )theGltfData.StreamLength); aSharedStream->read (aReadData.data(), (std::streamsize )theGltfData.StreamLength); if (!aSharedStream->good()) { diff --git a/src/Standard/Standard_WarningsDisable.hxx b/src/Standard/Standard_WarningsDisable.hxx index ca47a76d8e..25000d5991 100644 --- a/src/Standard/Standard_WarningsDisable.hxx +++ b/src/Standard/Standard_WarningsDisable.hxx @@ -31,6 +31,7 @@ #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wall" #pragma clang diagnostic ignored "-Wextra" + #pragma clang diagnostic ignored "-Wshorten-64-to-32" #elif defined(_MSC_VER) #pragma warning(push, 0) #elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) diff --git a/src/ViewerTest/ViewerTest_EventManager.cxx b/src/ViewerTest/ViewerTest_EventManager.cxx index 3335af811f..772dd1f984 100644 --- a/src/ViewerTest/ViewerTest_EventManager.cxx +++ b/src/ViewerTest/ViewerTest_EventManager.cxx @@ -38,17 +38,25 @@ #include #include - //! Callback flushing events and redrawing the WebGL canvas. - static void onWasmRedrawView (void* ) +//======================================================================= +//function : onWasmRedrawView +//purpose : +//======================================================================= +void ViewerTest_EventManager::onWasmRedrawView (void* ) +{ + Handle(ViewerTest_EventManager) aViewCtrl = ViewerTest::CurrentEventManager(); + if (!aViewCtrl.IsNull()) { - Handle(ViewerTest_EventManager) aViewCtrl = ViewerTest::CurrentEventManager(); + aViewCtrl->myNbUpdateRequests = 0; + const Handle(V3d_View)& aView = ViewerTest::CurrentView(); const Handle(AIS_InteractiveContext)& aCtx = ViewerTest::GetAISContext(); - if (!aViewCtrl.IsNull() && !aView.IsNull() && !aCtx.IsNull()) + if (!aView.IsNull() && !aCtx.IsNull()) { aViewCtrl->ProcessExpose(); } } +} #endif Standard_IMPORT Standard_Boolean Draw_Interprete (const char* theCommand); @@ -76,7 +84,7 @@ ViewerTest_EventManager::ViewerTest_EventManager (const Handle(V3d_View)& myView (theView), myToPickPnt (Standard_False), myIsTmpContRedraw (Standard_False), - myUpdateRequests (0) + myNbUpdateRequests (0) { myViewAnimation = GlobalViewAnimation(); @@ -183,7 +191,6 @@ void ViewerTest_EventManager::ProcessExpose() void ViewerTest_EventManager::handleViewRedraw (const Handle(AIS_InteractiveContext)& theCtx, const Handle(V3d_View)& theView) { - myUpdateRequests = 0; AIS_ViewController::handleViewRedraw (theCtx, theView); // On non-Windows platforms Aspect_Window::InvalidateContent() from rendering thread does not work as expected @@ -202,10 +209,12 @@ void ViewerTest_EventManager::handleViewRedraw (const Handle(AIS_InteractiveCont } // ask more frames - ++myUpdateRequests; - #if defined(__EMSCRIPTEN__) - emscripten_async_call (onWasmRedrawView, this, 0); - #endif + if (++myNbUpdateRequests == 1) + { + #if defined(__EMSCRIPTEN__) + emscripten_async_call (onWasmRedrawView, this, -1); + #endif + } } else if (myIsTmpContRedraw) { @@ -256,11 +265,11 @@ void ViewerTest_EventManager::ProcessInput() // Queue onWasmRedrawView() callback to redraw canvas after all user input is flushed by browser. // Redrawing viewer on every single message would be a pointless waste of resources, // as user will see only the last drawn frame due to WebGL implementation details. - if (++myUpdateRequests == 1) + // -1 in emscripten_async_call() redirects to requestAnimationFrame(); + // requestPostAnimationFrame() is a better under development alternative. + if (++myNbUpdateRequests == 1) { - #if defined(__EMSCRIPTEN__) - emscripten_async_call (onWasmRedrawView, this, 0); - #endif + emscripten_async_call (onWasmRedrawView, this, -1); } #else // handle synchronously diff --git a/src/ViewerTest/ViewerTest_EventManager.hxx b/src/ViewerTest/ViewerTest_EventManager.hxx index 23dfe7dcee..0bfbe32727 100644 --- a/src/ViewerTest/ViewerTest_EventManager.hxx +++ b/src/ViewerTest/ViewerTest_EventManager.hxx @@ -138,6 +138,13 @@ protected: unsigned int theModifNew, double theTimeStamp); +private: + +#if defined(__EMSCRIPTEN__) + //! Callback flushing events and redrawing the WebGL canvas. + static void onWasmRedrawView (void* ); +#endif + private: Handle(AIS_InteractiveContext) myCtx; @@ -148,7 +155,7 @@ private: Standard_Boolean myToPickPnt; Standard_Boolean myIsTmpContRedraw; - unsigned int myUpdateRequests; //!< counter for unhandled update requests + unsigned int myNbUpdateRequests; //!< counter for unhandled update requests };