mirror of
https://bitbucket.org/mfeemster/fractorium.git
synced 2025-06-30 13:26:02 -04:00
Remove ReadMe.txt from all project files.
Add Curves.h, and CurvesGraphicsView.h/cpp to support bezier color curves. Add Curves member to Ember. Add curves capability to EmberCL. Remove some unused variables in the kernel created in RendererCL::CreateFinalAccumKernelString(). Use glm namespace for vec classes if GLM_VERSION >= 96, else use glm::detail. As a result of using glm namespace, all instances of min and max had to be qualified with std:: Split ComputeCamera into that and ComputeQuality(). Reduce the amount of ComputeCamera() and MakeDmap() calls on each incremental iter that doesn't use temporal samples. Fix clamping bug with DE filter widths. Provide functions to return the kernels from RendererCL to assist with diagnostics and debugging. Prevent extra newline in EmberRender when only rendering a single image. Add the ability to delete an ember at a given index in EmberFile. Allow deleting/focusing ember in library tab with delete and enter keys. Reorder some code in Fractorium.h to match the tabs order. Add and call ClearFinalImages() to clear buffers in controller to fix bug where previous CPU render would be shown for a split second when switching from OpenCL back to CPU. Refactor ember library pointer syncing to a function SyncPointers(). Add the ability to save ember Xmls to an unique automatically generated name after the first time the user has specified a name.
This commit is contained in:
@ -67,11 +67,22 @@ void FractoriumEmberControllerBase::StopRenderTimer(bool wait)
|
||||
void FractoriumEmberControllerBase::Shutdown()
|
||||
{
|
||||
StopRenderTimer(true);
|
||||
ClearFinalImages();
|
||||
|
||||
while(m_Fractorium->ui.GLDisplay->Drawing())
|
||||
QApplication::processEvents();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Clear the output image buffers.
|
||||
/// </summary>
|
||||
void FractoriumEmberControllerBase::ClearFinalImages()
|
||||
{
|
||||
Memset(m_FinalImage[0]);
|
||||
Memset(m_FinalImage[1]);
|
||||
//Unsure if we should also call RendererCL::ClearFinal() as well. At the moment it seems unnecessary.
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Update the state of the renderer.
|
||||
/// Upon changing values, some intelligence is used to avoid blindly restarting the
|
||||
@ -442,7 +453,11 @@ bool FractoriumEmberController<T>::Render()
|
||||
//Uncomment for debugging kernel build and execution errors.
|
||||
//m_Fractorium->ui.InfoRenderingTextEdit->setText(QString::fromStdString(m_Fractorium->m_Wrapper.DumpInfo()));
|
||||
//if (rendererCL)
|
||||
// m_Fractorium->ui.InfoRenderingTextEdit->setText(QString::fromStdString(rendererCL->IterKernel()));
|
||||
//{
|
||||
// string s = "OpenCL Kernels: \r\n" + rendererCL->IterKernel() + "\r\n" + rendererCL->DEKernel() + "\r\n" + rendererCL->FinalAccumKernel();
|
||||
//
|
||||
// QMetaObject::invokeMethod(m_Fractorium->ui.InfoRenderingTextEdit, "setText", Qt::QueuedConnection, Q_ARG(const QString&, QString::fromStdString(s)));
|
||||
//}
|
||||
}
|
||||
}
|
||||
else//Something went very wrong, show error report.
|
||||
@ -460,12 +475,16 @@ bool FractoriumEmberController<T>::Render()
|
||||
m_Rendering = false;
|
||||
StopRenderTimer(true);
|
||||
m_Fractorium->m_RenderStatusLabel->setText("Rendering failed 3 or more times, stopping all rendering, see info tab. Try changing renderer types.");
|
||||
Memset(m_FinalImage[m_FinalImageIndex]);
|
||||
|
||||
if (rendererCL)
|
||||
rendererCL->ClearFinal();
|
||||
|
||||
ClearFinalImages();
|
||||
m_GLController->ClearWindow();
|
||||
|
||||
if (rendererCL)
|
||||
{
|
||||
//string s = "OpenCL Kernels: \r\n" + rendererCL->IterKernel() + "\r\n" + rendererCL->DEKernel() + "\r\n" + rendererCL->FinalAccumKernel();
|
||||
|
||||
rendererCL->ClearFinal();
|
||||
//QMetaObject::invokeMethod(m_Fractorium->ui.InfoRenderingTextEdit, "setText", Qt::QueuedConnection, Q_ARG(const QString&, QString::fromStdString(s)));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user