diff --git a/apps/showcases/FreeSurface/BubblyPoiseuille.prm b/apps/showcases/FreeSurface/BubblyPoiseuille.prm
index c6e7d413c5ef6b864f59f6c521542e6ff825a0e4..cfd43e2791bce37964e859f31a5848471e219c32 100644
--- a/apps/showcases/FreeSurface/BubblyPoiseuille.prm
+++ b/apps/showcases/FreeSurface/BubblyPoiseuille.prm
@@ -85,20 +85,22 @@ VTK
          normal;
          obstacle_normal;
          mapped_flag;
-        }
+      }
 
-        inclusion_filters
-        {
-            // only include liquid and interface cells in VTK output
-            //liquidInterfaceFilter;
-        }
+      inclusion_filters
+      {
+         // only include liquid and interface cells in VTK output
+         //liquidInterfaceFilter;
+      }
 
-        before_functions
-        {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
-        }
+      before_functions
+      {
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
+      }
 
    }
+
    domain_decomposition
    {
       writeFrequency 0;
diff --git a/apps/showcases/FreeSurface/CapillaryWave.prm b/apps/showcases/FreeSurface/CapillaryWave.prm
index 8d172cadd60e0b0ed616fb4c724c814a2ca23dde..b73208639ee28a8d65244a181d3f34fc01232084 100644
--- a/apps/showcases/FreeSurface/CapillaryWave.prm
+++ b/apps/showcases/FreeSurface/CapillaryWave.prm
@@ -95,9 +95,11 @@ VTK
 
       before_functions
       {
-         //ghost_layer_synchronization; // only needed if writing the ghost layer
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
       }
    }
+
    domain_decomposition
    {
       writeFrequency             100;
diff --git a/apps/showcases/FreeSurface/DamBreakCylindrical.prm b/apps/showcases/FreeSurface/DamBreakCylindrical.prm
index de81d688e114b52e226f3c0b42b3f599b31bf33b..aee8429824efd58e5dff7434b0c689bca8fe75b6 100644
--- a/apps/showcases/FreeSurface/DamBreakCylindrical.prm
+++ b/apps/showcases/FreeSurface/DamBreakCylindrical.prm
@@ -98,10 +98,12 @@ VTK
 
         before_functions
         {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
+            //ghost_layer_synchronization;   // only needed if writing the ghost layer
+            gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
         }
 
    }
+
    domain_decomposition
    {
       writeFrequency 248;
diff --git a/apps/showcases/FreeSurface/DamBreakRectangular.prm b/apps/showcases/FreeSurface/DamBreakRectangular.prm
index 34fdca4b018ce9af4e4f80cf285ee545845246d2..8c4bc96e76bf906072d09786afcac5e34ab3c09b 100644
--- a/apps/showcases/FreeSurface/DamBreakRectangular.prm
+++ b/apps/showcases/FreeSurface/DamBreakRectangular.prm
@@ -88,20 +88,21 @@ VTK
          normal;
          obstacle_normal;
          mapped_flag;
-        }
+      }
 
-        inclusion_filters
-        {
-            // only include liquid and interface cells in VTK output
-            //liquidInterfaceFilter;
-        }
-
-        before_functions
-        {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
-        }
+      inclusion_filters
+      {
+         // only include liquid and interface cells in VTK output
+         //liquidInterfaceFilter;
+      }
 
+      before_functions
+      {
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
+      }
    }
+
    domain_decomposition
    {
       writeFrequency 991;
diff --git a/apps/showcases/FreeSurface/DropImpact.prm b/apps/showcases/FreeSurface/DropImpact.prm
index 07afacce7480bf9a0307180e4f5da17c1deebbbe..76580d98f79c39163d38b89a83f9045b5d63c095 100644
--- a/apps/showcases/FreeSurface/DropImpact.prm
+++ b/apps/showcases/FreeSurface/DropImpact.prm
@@ -87,20 +87,21 @@ VTK
          normal;
          obstacle_normal;
          mapped_flag;
-        }
+      }
 
-        inclusion_filters
-        {
-            // only include liquid and interface cells in VTK output
-            //liquidInterfaceFilter;
-        }
-
-        before_functions
-        {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
-        }
+      inclusion_filters
+      {
+         // only include liquid and interface cells in VTK output
+         //liquidInterfaceFilter;
+      }
 
+      before_functions
+      {
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
+      }
    }
+
    domain_decomposition
    {
       writeFrequency 372;
diff --git a/apps/showcases/FreeSurface/DropWetting.prm b/apps/showcases/FreeSurface/DropWetting.prm
index bdfbe4e1ee632724634ad98b8ae2dfd5a8b1cd09..e10ae92738229e615ab22f8a5bcaf97a03787101 100644
--- a/apps/showcases/FreeSurface/DropWetting.prm
+++ b/apps/showcases/FreeSurface/DropWetting.prm
@@ -85,20 +85,21 @@ VTK
          normal;
          obstacle_normal;
          mapped_flag;
-        }
+      }
 
-        inclusion_filters
-        {
-            // only include liquid and interface cells in VTK output
-            //liquidInterfaceFilter;
-        }
-
-        before_functions
-        {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
-        }
+      inclusion_filters
+      {
+         // only include liquid and interface cells in VTK output
+         //liquidInterfaceFilter;
+      }
 
+      before_functions
+      {
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
+      }
    }
+
    domain_decomposition
    {
       writeFrequency 100;
diff --git a/apps/showcases/FreeSurface/GravityWave.prm b/apps/showcases/FreeSurface/GravityWave.prm
index 363a59c84abbc665dde520ebe4c1c1c89136874e..0400d62da919924847d344523f17fd32f3323d92 100644
--- a/apps/showcases/FreeSurface/GravityWave.prm
+++ b/apps/showcases/FreeSurface/GravityWave.prm
@@ -95,9 +95,11 @@ VTK
 
       before_functions
       {
-         //ghost_layer_synchronization; // only needed if writing the ghost layer
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
       }
    }
+
    domain_decomposition
    {
       writeFrequency             0;
diff --git a/apps/showcases/FreeSurface/MovingDrop.prm b/apps/showcases/FreeSurface/MovingDrop.prm
index 184963db1f00e71bb9a3557987d5415a076de5b4..dff95569f3a87410a6a22a46467ad920d67c169e 100644
--- a/apps/showcases/FreeSurface/MovingDrop.prm
+++ b/apps/showcases/FreeSurface/MovingDrop.prm
@@ -85,20 +85,21 @@ VTK
          normal;
          obstacle_normal;
          mapped_flag;
-        }
+      }
 
-        inclusion_filters
-        {
-            // only include liquid and interface cells in VTK output
-            //liquidInterfaceFilter;
-        }
-
-        before_functions
-        {
-            //ghost_layer_synchronization; // only needed if writing the ghost layer
-        }
+      inclusion_filters
+      {
+         // only include liquid and interface cells in VTK output
+         //liquidInterfaceFilter;
+      }
 
+      before_functions
+      {
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
+      }
    }
+
    domain_decomposition
    {
       writeFrequency 0;
diff --git a/apps/showcases/FreeSurface/RisingBubble.prm b/apps/showcases/FreeSurface/RisingBubble.prm
index 5d483426beb659bfe93db4ee94fe595e29c67255..62f1053d208f5b444173b3146932f1425ee6d07d 100644
--- a/apps/showcases/FreeSurface/RisingBubble.prm
+++ b/apps/showcases/FreeSurface/RisingBubble.prm
@@ -96,9 +96,11 @@ VTK
 
       before_functions
       {
-         //ghost_layer_synchronization; // only needed if writing the ghost layer
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
       }
    }
+
    domain_decomposition
    {
       writeFrequency             445;
diff --git a/apps/showcases/FreeSurface/TaylorBubble.prm b/apps/showcases/FreeSurface/TaylorBubble.prm
index ee3d8c9f56179798028ebe4e074988a36515549d..e413afc7f856b1cfb44d6c15395dbab171281b97 100644
--- a/apps/showcases/FreeSurface/TaylorBubble.prm
+++ b/apps/showcases/FreeSurface/TaylorBubble.prm
@@ -98,7 +98,8 @@ VTK
 
       before_functions
       {
-         //ghost_layer_synchronization; // only needed if writing the ghost layer
+         //ghost_layer_synchronization;   // only needed if writing the ghost layer
+         gas_cell_zero_setter;            // sets velocity=0 and density=1 all gas cells before writing VTK output
       }
    }
    domain_decomposition
diff --git a/src/lbm/free_surface/VtkWriter.h b/src/lbm/free_surface/VtkWriter.h
index f1ff2b93c6e3fdde748c1cf2b579837f37542cc1..f98549a8ff1b6110d3e128af4424eeaf13e0d0ab 100644
--- a/src/lbm/free_surface/VtkWriter.h
+++ b/src/lbm/free_surface/VtkWriter.h
@@ -120,6 +120,60 @@ void addVTKOutput(const std::weak_ptr< StructuredBlockForest >& blockForestPtr,
          std::make_shared< field::communication::PackInfo< VectorField_T > >(obstacleNormalFieldID));
 
       beforeFuncs["ghost_layer_synchronization"] = preVTKComm;
+
+      // set velocity and density to zero in obstacle and gas cells (only for visualization purposes); the PDF values in
+      // these cells are not important and thus not set during the simulation;
+      // only enable this functionality if the non-liquid and non-interface cells are not excluded anyway
+      const auto vtkConfigBlock        = config->getOneBlock("VTK");
+      const auto fluidFieldConfigBlock = vtkConfigBlock.getBlock("fluid_field");
+      if (fluidFieldConfigBlock)
+      {
+         auto inclusionFiltersConfigBlock = fluidFieldConfigBlock.getBlock("inclusion_filters");
+
+         // liquidInterfaceFilter limits VTK-output to only liquid and interface cells
+         if (!inclusionFiltersConfigBlock.isDefined("liquidInterfaceFilter"))
+         {
+            class ZeroSetter
+            {
+             public:
+               ZeroSetter(const weak_ptr< StructuredBlockForest >& blockForest, const BlockDataID& pdfFieldID,
+                          const ConstBlockDataID& flagFieldID,
+                          const typename FreeSurfaceBoundaryHandling_T::FlagInfo_T& flagInfo)
+                  : blockForest_(blockForest), pdfFieldID_(pdfFieldID), flagFieldID_(flagFieldID), flagInfo_(flagInfo)
+               {}
+
+               void operator()()
+               {
+                  auto blockForest = blockForest_.lock();
+                  WALBERLA_CHECK_NOT_NULLPTR(blockForest);
+
+                  for (auto blockIt = blockForest->begin(); blockIt != blockForest->end(); ++blockIt)
+                  {
+                     PdfField_T* const pdfField         = blockIt->template getData< PdfField_T >(pdfFieldID_);
+                     const FlagField_T* const flagField = blockIt->template getData< const FlagField_T >(flagFieldID_);
+                     WALBERLA_FOR_ALL_CELLS_INCLUDING_GHOST_LAYER_XYZ(pdfField, uint_c(1), {
+                        const typename PdfField_T::Ptr pdfFieldPtr(*pdfField, x, y, z);
+                        const typename FlagField_T::ConstPtr flagFieldPtr(*flagField, x, y, z);
+
+                        if (flagInfo_.isGas(*flagFieldPtr) || flagInfo_.isObstacle(*flagFieldPtr))
+                        {
+                           pdfField->setDensityAndVelocity(pdfFieldPtr.cell(), Vector3< real_t >(real_c(0)),
+                                                           real_c(1.0));
+                        }
+                     }) // WALBERLA_FOR_ALL_CELLS_INCLUDING_GHOST_LAYER_XYZ
+                  }
+               }
+
+             private:
+               weak_ptr< StructuredBlockForest > blockForest_;
+               BlockDataID pdfFieldID_;
+               ConstBlockDataID flagFieldID_;
+               typename FreeSurfaceBoundaryHandling_T::FlagInfo_T flagInfo_;
+            };
+
+            beforeFuncs["gas_cell_zero_setter"] = ZeroSetter(blockForest, pdfFieldID, flagFieldID, flagInfo);
+         }
+      }
    };
 
    // add VTK output to timeloop
@@ -130,42 +184,6 @@ void addVTKOutput(const std::weak_ptr< StructuredBlockForest >& blockForestPtr,
       timeloop.addFuncBeforeTimeStep(output->second.outputFunction, std::string("VTK: ") + output->first,
                                      output->second.requiredGlobalStates, output->second.incompatibleGlobalStates);
    }
-
-   // only enable the zerosetter (see below) if the non-liquid and non-interface cells are not excluded anyway
-   bool enableZeroSetter            = true;
-   const auto vtkConfigBlock        = config->getOneBlock("VTK");
-   const auto fluidFieldConfigBlock = vtkConfigBlock.getBlock("fluid_field");
-   if (fluidFieldConfigBlock)
-   {
-      auto inclusionFiltersConfigBlock = fluidFieldConfigBlock.getBlock("inclusion_filters");
-
-      if (inclusionFiltersConfigBlock.isDefined("liquidInterfaceFilter"))
-      {
-         // liquidInterfaceFilter is defined which limits VTK-output to only liquid and interface cells
-         enableZeroSetter = false;
-      }
-   }
-
-   // set velocity and density to zero in obstacle and gas cells (only for visualization purposes); the PDF values in
-   // these cells are not important and thus not set during the simulation
-   if (enableZeroSetter)
-   {
-      const auto function = [&](IBlock* block) {
-         using namespace free_surface;
-         PdfField_T* const pdfField         = block->getData< PdfField_T >(pdfFieldID);
-         const FlagField_T* const flagField = block->getData< const FlagField_T >(flagFieldID);
-         WALBERLA_FOR_ALL_CELLS_INCLUDING_GHOST_LAYER_XYZ(pdfField, uint_c(1), {
-            const typename PdfField_T::Ptr pdfFieldPtr(*pdfField, x, y, z);
-            const typename FlagField_T::ConstPtr flagFieldPtr(*flagField, x, y, z);
-
-            if (flagInfo.isGas(*flagFieldPtr) || flagInfo.isObstacle(*flagFieldPtr))
-            {
-               pdfField->setDensityAndVelocity(pdfFieldPtr.cell(), Vector3< real_t >(0), real_c(1.0));
-            }
-         }) // WALBERLA_FOR_ALL_CELLS_INCLUDING_GHOST_LAYER_XYZ
-      };
-      timeloop.add() << Sweep(function, "VTK: zero-setting");
-   }
 }
 
 } // namespace free_surface