2014-07-08 03:11:14 -04:00
# pragma once
# include "FractoriumPch.h"
2022-02-22 22:54:29 -05:00
template < typename T > class FractoriumEmberController ;
2014-07-08 03:11:14 -04:00
/// <summary>
/// EmberTreeWidgetItem
/// </summary>
/// <summary>
/// A thin derivation of QTreeWidgetItem for a tree of embers in an open file.
/// The tree is intended to contain one open ember file at a time.
/// This is a non-templated base for casting purposes.
/// </summary>
class EmberTreeWidgetItemBase : public QTreeWidgetItem
{
public :
2022-02-22 22:54:29 -05:00
friend FractoriumEmberController < float > ;
# ifdef DO_DOUBLE
friend FractoriumEmberController < double > ;
# endif
2014-07-08 03:11:14 -04:00
/// <summary>
/// Constructor that takes a pointer to a QTreeWidget as a parent widget.
/// This is meant to be a root level item.
/// </summary>
2014-12-11 00:50:15 -05:00
/// <param name="p">The parent widget of this item</param>
2016-02-13 20:24:51 -05:00
explicit EmberTreeWidgetItemBase ( QTreeWidget * p )
2014-12-11 00:50:15 -05:00
: QTreeWidgetItem ( p )
2014-07-08 03:11:14 -04:00
{
}
/// <summary>
/// Constructor that takes a pointer to a QTreeWidgetItem as a parent widget.
/// This is meant to be the child of a root level item.
/// </summary>
2014-12-11 00:50:15 -05:00
/// <param name="p">The parent widget of this item</param>
2016-02-13 20:24:51 -05:00
explicit EmberTreeWidgetItemBase ( QTreeWidgetItem * p )
2014-12-11 00:50:15 -05:00
: QTreeWidgetItem ( p )
2014-07-08 03:11:14 -04:00
{
}
2016-02-13 20:24:51 -05:00
2017-07-22 16:43:35 -04:00
~ EmberTreeWidgetItemBase ( )
{
//qDebug() << "~EmberTreeWidgetItemBase()";
}
2017-03-02 23:04:47 -05:00
2014-07-08 03:11:14 -04:00
/// <summary>
/// Set the preview image for the tree widget item.
/// </summary>
/// <param name="v">The vector containing the RGB pixels [0..255] which will make up the preview image</param>
/// <param name="width">The width of the image in pixels</param>
/// <param name="height">The height of the image in pixels</param>
2014-12-06 00:05:09 -05:00
void SetImage ( vector < byte > & v , uint width , uint height )
2014-07-08 03:11:14 -04:00
{
2022-02-12 21:51:42 -05:00
constexpr auto size = PREVIEW_SIZE ;
2014-07-08 03:11:14 -04:00
m_Image = QImage ( width , height , QImage : : Format_RGBA8888 ) ;
2016-04-03 21:55:12 -04:00
memcpy ( m_Image . scanLine ( 0 ) , v . data ( ) , SizeOf ( v ) ) ; //Memcpy the data in.
2014-07-08 03:11:14 -04:00
m_Pixmap = QPixmap : : fromImage ( m_Image ) . scaled ( QSize ( size , size ) , Qt : : IgnoreAspectRatio , Qt : : SmoothTransformation ) ; //Create a QPixmap out of the QImage, scaled to size.
setData ( 0 , Qt : : DecorationRole , m_Pixmap ) ;
}
2022-02-22 22:54:29 -05:00
void SetRendered ( )
{
m_Rendered = true ;
}
2014-07-08 03:11:14 -04:00
protected :
QImage m_Image ;
QPixmap m_Pixmap ;
2022-02-22 22:54:29 -05:00
bool m_Rendered ;
2014-07-08 03:11:14 -04:00
} ;
/// <summary>
/// A thin derivation of QTreeWidgetItem for a tree of embers in an open file.
/// The tree is intended to contain one open ember file at a time.
/// </summary>
template < typename T >
class EmberTreeWidgetItem : public EmberTreeWidgetItemBase
{
public :
/// <summary>
/// Constructor that takes a pointer to an ember and a QTreeWidget as a parent widget.
/// This is meant to be a root level item.
/// </summary>
/// <param name="ember">A pointer to the ember this item will represent</param>
2014-12-11 00:50:15 -05:00
/// <param name="p">The parent widget of this item</param>
2016-04-03 21:55:12 -04:00
explicit EmberTreeWidgetItem ( Ember < T > * ember , QTreeWidget * p = nullptr )
: EmberTreeWidgetItemBase ( p ) ,
m_Ember ( ember )
2014-07-08 03:11:14 -04:00
{
2016-04-03 21:55:12 -04:00
setFlags ( Qt : : ItemIsEnabled | Qt : : ItemIsEditable | Qt : : ItemIsSelectable | Qt : : ItemIsDragEnabled ) ;
2016-12-05 22:04:33 -05:00
setCheckState ( 0 , Qt : : Unchecked ) ;
2014-07-08 03:11:14 -04:00
}
/// <summary>
/// Constructor that takes a pointer to an ember and a QTreeWidgetItem as a parent widget.
/// This is meant to be the child of a root level item.
/// </summary>
/// <param name="ember">A pointer to the ember this item will represent</param>
2014-12-11 00:50:15 -05:00
/// <param name="p">The parent widget of this item</param>
2016-04-03 21:55:12 -04:00
explicit EmberTreeWidgetItem ( Ember < T > * ember , QTreeWidgetItem * p = nullptr )
: EmberTreeWidgetItemBase ( p ) ,
m_Ember ( ember )
2014-07-08 03:11:14 -04:00
{
2016-04-03 21:55:12 -04:00
setFlags ( Qt : : ItemIsEnabled | Qt : : ItemIsEditable | Qt : : ItemIsSelectable | Qt : : ItemIsDragEnabled ) ;
2016-12-05 22:04:33 -05:00
setCheckState ( 0 , Qt : : Unchecked ) ;
2014-07-08 03:11:14 -04:00
}
/// <summary>
/// Copy the text of the tree item to the name of the ember.
/// </summary>
void UpdateEmberName ( ) { m_Ember - > m_Name = text ( 0 ) . toStdString ( ) ; }
/// <summary>
/// Set the text of the tree item.
/// </summary>
void UpdateEditText ( ) { setText ( 0 , QString : : fromStdString ( m_Ember - > m_Name ) ) ; }
/// <summary>
/// Get a pointer to the ember held by the tree item.
/// </summary>
Ember < T > * GetEmber ( ) const { return m_Ember ; }
/// <summary>
/// Perform a deep copy from the passed in ember to the dereferenced
/// ember pointer of the tree item.
/// </summary>
/// <param name="ember">The ember to copy</param>
void SetEmber ( Ember < T > & ember ) { * m_Ember = ember ; }
/// <summary>
/// Set the ember pointer member to point to the passed in ember pointer.
/// </summary>
/// <param name="ember">The ember to point to</param>
void SetEmberPointer ( Ember < T > * ember ) { m_Ember = ember ; }
private :
Ember < T > * m_Ember ;
} ;