From ced4a481967adc085e94d37d9bb555c78ad1cfed Mon Sep 17 00:00:00 2001 From: Rodney Date: Mar 14 2022 18:44:12 +0000 Subject: Merge pull request #4322 from shun-iwasawa/g/fix_bounding_box_handling Fix tile fxs & bounding box handling --- diff --git a/toonz/sources/stdfx/iwa_tilefx.cpp b/toonz/sources/stdfx/iwa_tilefx.cpp index 0fcdfb9..5daa1cc 100644 --- a/toonz/sources/stdfx/iwa_tilefx.cpp +++ b/toonz/sources/stdfx/iwa_tilefx.cpp @@ -134,6 +134,11 @@ void Iwa_TileFx::transform(double frame, int port, const TRectD &rectOnOutput, TRectD &rectOnInput, TRenderSettings &infoOnInput) { infoOnInput = infoOnOutput; + if (!m_input.isConnected()) { + rectOnInput.empty(); + return; + } + TRectD inputBox; m_input->getBBox(frame, inputBox, infoOnOutput); @@ -161,6 +166,8 @@ void Iwa_TileFx::transform(double frame, int port, const TRectD &rectOnOutput, int Iwa_TileFx::getMemoryRequirement(const TRectD &rect, double frame, const TRenderSettings &info) { + if (!m_input.isConnected()) return 0; + TRectD inputBox; m_input->getBBox(frame, inputBox, info); diff --git a/toonz/sources/stdfx/tilefx.cpp b/toonz/sources/stdfx/tilefx.cpp index 58bd91c..262fe79 100644 --- a/toonz/sources/stdfx/tilefx.cpp +++ b/toonz/sources/stdfx/tilefx.cpp @@ -90,6 +90,11 @@ void TileFx::transform(double frame, int port, const TRectD &rectOnOutput, TRenderSettings &infoOnInput) { infoOnInput = infoOnOutput; + if (!m_input.isConnected()) { + rectOnInput.empty(); + return; + } + TRectD inputBox; m_input->getBBox(frame, inputBox, infoOnOutput); @@ -116,6 +121,8 @@ void TileFx::transform(double frame, int port, const TRectD &rectOnOutput, int TileFx::getMemoryRequirement(const TRectD &rect, double frame, const TRenderSettings &info) { + if (!m_input.isConnected()) return 0; + TRectD inputBox; m_input->getBBox(frame, inputBox, info); @@ -157,7 +164,7 @@ void TileFx::doCompute(TTile &tile, double frame, const TRenderSettings &ri) { //------------------------------------------------------------------------------ //! Make the tile of the image contained in \b inputTile in \b tile /* -*/ + */ void TileFx::makeTile(const TTile &inputTile, const TTile &tile) const { // Build the mirroring pattern. It obviously repeats itself out of 2x2 tile // blocks. diff --git a/toonz/sources/tnzbase/trasterfx.cpp b/toonz/sources/tnzbase/trasterfx.cpp index 29f7ee5..6af8fab 100644 --- a/toonz/sources/tnzbase/trasterfx.cpp +++ b/toonz/sources/tnzbase/trasterfx.cpp @@ -541,8 +541,11 @@ TAffine TRasterFx::handledAffine(const TRenderSettings &info, double frame) { bool TRasterFx::getBBox(double frame, TRectD &bBox, const TRenderSettings &info) { bool ret = doGetBBox(frame, bBox, info); - bBox = info.m_affine * bBox; - enlargeToI(bBox); + if (!bBox.isEmpty()) { // TODO: check if bbox can always be empty when ret == + // false + bBox = info.m_affine * bBox; + enlargeToI(bBox); + } return ret; }