Correct CellWidget & CellPrinter to be really WYSIWYG.
* Change: In Hurricane::CellWidget, new "isPrinter" attribute to know if the CellWidget is used as a device for printing. New function copyExtensionsGos() to duplicate the ExtensionGo drawing callbacks. This is a temporary hack until the ExtensionGo are made static to be shared by all CellWidgets. In _redraw(), the DrawingQuery flags were not correctly reset between different stage of the drawing. This was resulting of uneeded walkthough of the slicing tree, along with incorrect display of some of the layers (i.e. rubbers where diplayeds when ExtensionGos where active). * Change: In GraphicKatanaEngine, fine tune the display of GCells for printing CellWidget. * Change: In Hurricane::CellPrinter, copy all the settings from the palette of the reference (graphic) CellWidget into the printer CellWidget. Also copy the ExtensionGos callbacks so we can print them. Use the new CellWidget attribute "isPrinter" for the callbacks to be able to adapt to Printer settings. * Change: In Hurricane::Time::getStringTime(), only print two decimals for time durations.
This commit is contained in:
parent
6fd383ad51
commit
9f69230837
|
@ -403,7 +403,7 @@ stylesTable = \
|
||||||
, (Drawing, 'gmetalh' , { 'color':'128,255,200', 'pattern':'light_antihash0.8' , 'border':1 })
|
, (Drawing, 'gmetalh' , { 'color':'128,255,200', 'pattern':'light_antihash0.8' , 'border':1 })
|
||||||
, (Drawing, 'gmetalv' , { 'color':'200,200,255', 'pattern':'light_antihash1.8' , 'border':1 })
|
, (Drawing, 'gmetalv' , { 'color':'200,200,255', 'pattern':'light_antihash1.8' , 'border':1 })
|
||||||
, (Drawing, 'gcut' , { 'color':'255,255,190', 'border':1 })
|
, (Drawing, 'gcut' , { 'color':'255,255,190', 'border':1 })
|
||||||
, (Drawing, 'Anabatic::Edge' , { 'color':'255,255,190', 'pattern':'0000000000000000', 'border':4 })
|
, (Drawing, 'Anabatic::Edge' , { 'color':'255,255,190', 'pattern':'0000000000000000', 'border':2 })
|
||||||
, (Drawing, 'Anabatic::GCell', { 'color':'255,255,190', 'pattern':'0000000000000000', 'border':4 })
|
, (Drawing, 'Anabatic::GCell', { 'color':'Black' , 'pattern':'0000000000000000', 'border':2, 'threshold':0.80*scale })
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
|
@ -249,18 +249,19 @@ namespace Hurricane {
|
||||||
string s;
|
string s;
|
||||||
|
|
||||||
unsigned int hours = (unsigned int)duration / 3600;
|
unsigned int hours = (unsigned int)duration / 3600;
|
||||||
if ( hours )
|
if (hours)
|
||||||
s += getString(hours) + "h ";
|
s += getString(hours) + "h ";
|
||||||
|
|
||||||
unsigned int minutes = ((unsigned int)duration % 3600) / 60;
|
unsigned int minutes = ((unsigned int)duration % 3600) / 60;
|
||||||
if ( hours || minutes )
|
if (hours or minutes)
|
||||||
s += getString(minutes) + "m ";
|
s += getString(minutes) + "m ";
|
||||||
|
|
||||||
double seconds = duration;
|
double seconds = duration;
|
||||||
if ( hours || minutes ) {
|
if (hours or minutes) {
|
||||||
minutes = ((unsigned int)duration) / 60;
|
minutes = ((unsigned int)duration) / 60;
|
||||||
seconds = duration - ((float)minutes * 60.0);
|
seconds = duration - ((float)minutes * 60.0);
|
||||||
}
|
}
|
||||||
|
seconds = std::round(seconds * 100.0) / 100.0;
|
||||||
|
|
||||||
s += getString((float)seconds) + "s";
|
s += getString((float)seconds) + "s";
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,9 @@
|
||||||
#include <QPrinter>
|
#include <QPrinter>
|
||||||
#include "vlsisapd/configuration/Configuration.h"
|
#include "vlsisapd/configuration/Configuration.h"
|
||||||
#include "hurricane/DataBase.h"
|
#include "hurricane/DataBase.h"
|
||||||
|
#include "hurricane/BasicLayer.h"
|
||||||
|
#include "hurricane/Technology.h"
|
||||||
|
#include "hurricane/ExtensionSlice.h"
|
||||||
#include "hurricane/Cell.h"
|
#include "hurricane/Cell.h"
|
||||||
#include "hurricane/viewer/Graphics.h"
|
#include "hurricane/viewer/Graphics.h"
|
||||||
#include "hurricane/viewer/CellPrinter.h"
|
#include "hurricane/viewer/CellPrinter.h"
|
||||||
|
@ -79,6 +82,7 @@ namespace Hurricane {
|
||||||
setCentralWidget( _cellWidget );
|
setCentralWidget( _cellWidget );
|
||||||
_palette->readGraphics ();
|
_palette->readGraphics ();
|
||||||
|
|
||||||
|
_cellWidget->setPrinter( true );
|
||||||
_cellWidget->bindToPalette( _palette );
|
_cellWidget->bindToPalette( _palette );
|
||||||
_cellWidget->refresh();
|
_cellWidget->refresh();
|
||||||
}
|
}
|
||||||
|
@ -88,12 +92,38 @@ namespace Hurricane {
|
||||||
{
|
{
|
||||||
_screenCellWidget = cellWidget;
|
_screenCellWidget = cellWidget;
|
||||||
|
|
||||||
|
array<string,14> labels = { "fallback"
|
||||||
|
, "rubber"
|
||||||
|
, "phantom"
|
||||||
|
, "boundaries"
|
||||||
|
, "marker"
|
||||||
|
, "grid"
|
||||||
|
, "spot"
|
||||||
|
, "ghost"
|
||||||
|
, "text.ruler"
|
||||||
|
, "text.cell"
|
||||||
|
, "text.instance"
|
||||||
|
, "text.components"
|
||||||
|
, "text.references"
|
||||||
|
, "undef"
|
||||||
|
};
|
||||||
|
|
||||||
|
for ( string label : labels )
|
||||||
|
_cellWidget->setLayerVisible( label
|
||||||
|
, _screenCellWidget->isLayerVisible(label) );
|
||||||
|
|
||||||
|
for ( const BasicLayer* layer : DataBase::getDB()->getTechnology()->getBasicLayers() )
|
||||||
|
_cellWidget->setLayerVisible( layer->getName()
|
||||||
|
, _screenCellWidget->isLayerVisible( layer->getName() ));
|
||||||
|
|
||||||
shared_ptr<CellWidget::State> clone ( _screenCellWidget->getStateClone() );
|
shared_ptr<CellWidget::State> clone ( _screenCellWidget->getStateClone() );
|
||||||
_cellWidget->setState ( clone );
|
_cellWidget->setState( clone );
|
||||||
_cellWidget->setLayerVisible("grid" , _screenCellWidget->isLayerVisible("grid" ));
|
|
||||||
_cellWidget->setLayerVisible("text.instance" , _screenCellWidget->isLayerVisible("text.instance" ));
|
_cellWidget->copyDrawExtensionGos( _screenCellWidget );
|
||||||
_cellWidget->setLayerVisible("text.component", _screenCellWidget->isLayerVisible("text.component"));
|
|
||||||
_cellWidget->setLayerVisible("rubber" , _screenCellWidget->isLayerVisible("rubber" ));
|
for ( ExtensionSlice* extension : cellWidget->getCell()->getExtensionSlices() )
|
||||||
|
_cellWidget->setLayerVisible( extension->getName()
|
||||||
|
, _screenCellWidget->isLayerVisible( extension->getName() ));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1094,6 +1094,7 @@ namespace Hurricane {
|
||||||
, _mousePosition (0,0)
|
, _mousePosition (0,0)
|
||||||
, _spot (this)
|
, _spot (this)
|
||||||
, _state (new State(NULL))
|
, _state (new State(NULL))
|
||||||
|
, _isPrinter (false)
|
||||||
, _cellChanged (true)
|
, _cellChanged (true)
|
||||||
, _selectionHasChanged (false)
|
, _selectionHasChanged (false)
|
||||||
, _delaySelectionChanged(0)
|
, _delaySelectionChanged(0)
|
||||||
|
@ -1312,10 +1313,10 @@ namespace Hurricane {
|
||||||
//static bool timedout;
|
//static bool timedout;
|
||||||
//static Timer timer;
|
//static Timer timer;
|
||||||
|
|
||||||
if ( not isVisible() ) return;
|
if (not isVisible()) return;
|
||||||
|
|
||||||
DataBase* database = DataBase::getDB();
|
DataBase* database = DataBase::getDB();
|
||||||
if ( database ) _technology = database->getTechnology ();
|
if (database) _technology = database->getTechnology();
|
||||||
|
|
||||||
//timer.start ();
|
//timer.start ();
|
||||||
//timedout = false;
|
//timedout = false;
|
||||||
|
@ -1323,22 +1324,22 @@ namespace Hurricane {
|
||||||
_cellChanged = false;
|
_cellChanged = false;
|
||||||
_redrawRectCount = 0;
|
_redrawRectCount = 0;
|
||||||
|
|
||||||
pushCursor ( Qt::BusyCursor );
|
pushCursor( Qt::BusyCursor );
|
||||||
|
|
||||||
if ( not ( _selectionHasChanged and _state->showSelection() ) or _cellModificated ) {
|
if ( not (_selectionHasChanged and _state->showSelection()) or _cellModificated ) {
|
||||||
_spot.setRestore ( false );
|
_spot.setRestore( false );
|
||||||
//_drawingPlanes.copyToSelect ( redrawArea );
|
//_drawingPlanes.copyToSelect ( redrawArea );
|
||||||
_drawingPlanes.select ( PlaneId::Normal );
|
_drawingPlanes.select ( PlaneId::Normal );
|
||||||
_drawingPlanes.begin ();
|
_drawingPlanes.begin ();
|
||||||
_drawingPlanes.painter().setPen ( Qt::NoPen );
|
_drawingPlanes.painter().setPen ( Qt::NoPen );
|
||||||
_drawingPlanes.painter().setBackground ( Graphics::getBrush("background") );
|
_drawingPlanes.painter().setBackground( Graphics::getBrush("background") );
|
||||||
_drawingPlanes.painter().setClipRect ( redrawArea );
|
_drawingPlanes.painter().setClipRect ( redrawArea );
|
||||||
_drawingPlanes.painter().eraseRect ( redrawArea );
|
_drawingPlanes.painter().eraseRect ( redrawArea );
|
||||||
|
|
||||||
setDarkening ( (_state->showSelection()) ? Graphics::getDarkening() : DisplayStyle::HSVr() );
|
setDarkening( (_state->showSelection()) ? Graphics::getDarkening() : DisplayStyle::HSVr() );
|
||||||
|
|
||||||
if ( getCell() ) {
|
if (getCell()) {
|
||||||
Box redrawBox = screenToDbuBox ( redrawArea );
|
Box redrawBox = screenToDbuBox( redrawArea );
|
||||||
|
|
||||||
_drawingQuery.resetGoCount ();
|
_drawingQuery.resetGoCount ();
|
||||||
_drawingQuery.resetExtensionGoCount();
|
_drawingQuery.resetExtensionGoCount();
|
||||||
|
@ -1347,32 +1348,32 @@ namespace Hurricane {
|
||||||
_drawingQuery.setArea ( redrawBox );
|
_drawingQuery.setArea ( redrawBox );
|
||||||
_drawingQuery.setTransformation ( Transformation() );
|
_drawingQuery.setTransformation ( Transformation() );
|
||||||
|
|
||||||
forEach ( BasicLayer*, iLayer, _technology->getBasicLayers() ) {
|
for ( BasicLayer* layer : _technology->getBasicLayers() ) {
|
||||||
_drawingPlanes.setPen ( Graphics::getPen ((*iLayer)->getName(),getDarkening()) );
|
_drawingPlanes.setPen ( Graphics::getPen (layer->getName(),getDarkening()) );
|
||||||
_drawingPlanes.setBrush ( Graphics::getBrush((*iLayer)->getName(),getDarkening()) );
|
_drawingPlanes.setBrush( Graphics::getBrush(layer->getName(),getDarkening()) );
|
||||||
|
|
||||||
if ( isDrawable((*iLayer)->getName()) ) {
|
if ( isDrawable(layer->getName()) ) {
|
||||||
_drawingQuery.setBasicLayer ( *iLayer );
|
_drawingQuery.setBasicLayer( layer );
|
||||||
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoMasterCells
|
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoMasterCells
|
||||||
|Query::DoRubbers
|
|Query::DoRubbers
|
||||||
|Query::DoMarkers
|
|Query::DoMarkers
|
||||||
|Query::DoExtensionGos) );
|
|Query::DoExtensionGos) );
|
||||||
_drawingQuery.doQuery ();
|
_drawingQuery.doQuery ();
|
||||||
}
|
}
|
||||||
if ( _enableRedrawInterrupt ) QApplication::processEvents();
|
if (_enableRedrawInterrupt) QApplication::processEvents();
|
||||||
if ( _redrawManager.interrupted() ) {
|
if (_redrawManager.interrupted()) {
|
||||||
//cerr << "CellWidget::redraw() - interrupt after " << (*iLayer)->getName() << endl;
|
//cerr << "CellWidget::redraw() - interrupt after " << layer->getName() << endl;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
//if ( timeout("redraw [layer]",timer,10.0,timedout) ) break;
|
//if ( timeout("redraw [layer]",timer,10.0,timedout) ) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( /*not timeout("redraw [boundaries]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
if ( /*not timeout("redraw [boundaries]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
||||||
if ( isDrawable("boundaries") ) {
|
if (isDrawable("boundaries")) {
|
||||||
_drawingPlanes.setPen ( Graphics::getPen ("boundaries",getDarkening()) );
|
_drawingPlanes.setPen ( Graphics::getPen ("boundaries",getDarkening()) );
|
||||||
_drawingPlanes.setBrush ( Graphics::getBrush("boundaries",getDarkening()) );
|
_drawingPlanes.setBrush( Graphics::getBrush("boundaries",getDarkening()) );
|
||||||
|
|
||||||
_drawingQuery.setBasicLayer ( NULL );
|
_drawingQuery.setBasicLayer( NULL );
|
||||||
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
||||||
|Query::DoRubbers
|
|Query::DoRubbers
|
||||||
|Query::DoMarkers
|
|Query::DoMarkers
|
||||||
|
@ -1384,10 +1385,12 @@ namespace Hurricane {
|
||||||
if ( /*not timeout("redraw [markers]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
if ( /*not timeout("redraw [markers]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
||||||
if ( isDrawable("text.reference") ) {
|
if ( isDrawable("text.reference") ) {
|
||||||
_drawingPlanes.setPen ( Graphics::getPen ("text.reference",getDarkening()) );
|
_drawingPlanes.setPen ( Graphics::getPen ("text.reference",getDarkening()) );
|
||||||
_drawingPlanes.setBrush ( Graphics::getBrush("text.reference",getDarkening()) );
|
_drawingPlanes.setBrush( Graphics::getBrush("text.reference",getDarkening()) );
|
||||||
|
|
||||||
_drawingQuery.setBasicLayer ( NULL );
|
_drawingQuery.setBasicLayer( NULL );
|
||||||
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
||||||
|
|Query::DoRubbers
|
||||||
|
|Query::DoMarkers
|
||||||
|Query::DoExtensionGos
|
|Query::DoExtensionGos
|
||||||
|Query::DoMasterCells) );
|
|Query::DoMasterCells) );
|
||||||
_drawingQuery.doQuery ();
|
_drawingQuery.doQuery ();
|
||||||
|
@ -1395,58 +1398,62 @@ namespace Hurricane {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( /*not timeout("redraw [rubbers]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
if ( /*not timeout("redraw [rubbers]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
||||||
if ( isDrawable("rubber") ) {
|
if (isDrawable("rubber")) {
|
||||||
_drawingPlanes.setPen ( Graphics::getPen ("rubber",getDarkening()) );
|
_drawingPlanes.setPen ( Graphics::getPen ("rubber",getDarkening()) );
|
||||||
_drawingPlanes.setBrush ( Graphics::getBrush("rubber",getDarkening()) );
|
_drawingPlanes.setBrush( Graphics::getBrush("rubber",getDarkening()) );
|
||||||
|
|
||||||
_drawingQuery.setBasicLayer ( NULL );
|
_drawingQuery.setBasicLayer( NULL );
|
||||||
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
_drawingQuery.setFilter ( getQueryFilter().unset(Query::DoComponents
|
||||||
|
|Query::DoMarkers
|
||||||
|Query::DoExtensionGos
|
|Query::DoExtensionGos
|
||||||
|Query::DoMasterCells
|
|Query::DoMasterCells) );
|
||||||
|Query::DoMarkers) );
|
|
||||||
_drawingQuery.doQuery ();
|
_drawingQuery.doQuery ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( _enableRedrawInterrupt ) QApplication::processEvents();
|
if (_enableRedrawInterrupt) QApplication::processEvents();
|
||||||
if ( /*not timeout("redraw [text.instances]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
if ( /*not timeout("redraw [text.instances]",timer,10.0,timedout) and*/ (not _redrawManager.interrupted()) ) {
|
||||||
if ( isDrawable("text.instance") ) {
|
if (isDrawable("text.instance")) {
|
||||||
_drawingPlanes.setPen ( Graphics::getPen ("text.instance",getDarkening()) );
|
_drawingPlanes.setPen ( Graphics::getPen ("text.instance",getDarkening()) );
|
||||||
_drawingPlanes.setBrush ( Graphics::getBrush("text.instance",getDarkening()) );
|
_drawingPlanes.setBrush ( Graphics::getBrush("text.instance",getDarkening()) );
|
||||||
_drawingPlanes.setBackground ( Graphics::getBrush("boundaries" ,getDarkening()) );
|
_drawingPlanes.setBackground ( Graphics::getBrush("boundaries" ,getDarkening()) );
|
||||||
_textDrawingQuery.setArea ( redrawBox );
|
_textDrawingQuery.setArea ( redrawBox );
|
||||||
_textDrawingQuery.setTransformation ( Transformation() );
|
_textDrawingQuery.setTransformation( Transformation() );
|
||||||
_textDrawingQuery.doQuery ();
|
_textDrawingQuery.doQuery ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//_drawingQuery.setFilter ( getQueryFilter() & ~Query::DoMasterCells );
|
//_drawingQuery.setFilter ( getQueryFilter() & ~Query::DoMasterCells );
|
||||||
forEach ( ExtensionSlice*, islice, getCell()->getExtensionSlices() ) {
|
for ( ExtensionSlice* slice : getCell()->getExtensionSlices() ) {
|
||||||
if ( _enableRedrawInterrupt ) QApplication::processEvents();
|
if (_enableRedrawInterrupt) QApplication::processEvents();
|
||||||
if ( /*timeout("redraw [extension]",timer,10.0,timedout) or*/ (_redrawManager.interrupted()) ) break;
|
if ( /*timeout("redraw [extension]",timer,10.0,timedout) or*/ (_redrawManager.interrupted()) ) break;
|
||||||
|
|
||||||
if ( isDrawableExtension((*islice)->getName()) ) {
|
if (isDrawableExtension(slice->getName())) {
|
||||||
_drawingQuery.setExtensionMask ( (*islice)->getMask() );
|
_drawingQuery.setExtensionMask ( slice->getMask() );
|
||||||
_drawingQuery.setDrawExtensionGo ( (*islice)->getName() );
|
_drawingQuery.setDrawExtensionGo( slice->getName() );
|
||||||
_drawingQuery.setFilter ( getQueryFilter().set(Query::DoExtensionGos).unset(Query::DoMasterCells) );
|
_drawingQuery.setFilter ( getQueryFilter().set (Query::DoExtensionGos)
|
||||||
|
.unset(Query::DoComponents
|
||||||
|
|Query::DoRubbers
|
||||||
|
|Query::DoMarkers
|
||||||
|
|Query::DoMasterCells) );
|
||||||
_drawingQuery.doQuery ();
|
_drawingQuery.doQuery ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_drawingPlanes.end ();
|
_drawingPlanes.end();
|
||||||
_cellModificated = false;
|
_cellModificated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( isDrawable("grid") ) drawGrid ( redrawArea );
|
if (isDrawable("grid")) drawGrid ( redrawArea );
|
||||||
if ( isDrawable("text.ruler") ) drawRulers ( redrawArea );
|
if (isDrawable("text.ruler")) drawRulers( redrawArea );
|
||||||
|
|
||||||
setDarkening ( 100 );
|
setDarkening( 100 );
|
||||||
if ( _state->showSelection() )
|
if (_state->showSelection())
|
||||||
redrawSelection ( redrawArea );
|
redrawSelection( redrawArea );
|
||||||
|
|
||||||
popCursor ();
|
popCursor();
|
||||||
repaint ();
|
repaint();
|
||||||
|
|
||||||
//timer.stop ();
|
//timer.stop ();
|
||||||
//cerr << "CellWidget::redraw() - " << _redrawRectCount
|
//cerr << "CellWidget::redraw() - " << _redrawRectCount
|
||||||
|
@ -1568,8 +1575,8 @@ namespace Hurricane {
|
||||||
|
|
||||||
void CellWidget::setLayerVisible ( const Name& layer, bool visible )
|
void CellWidget::setLayerVisible ( const Name& layer, bool visible )
|
||||||
{
|
{
|
||||||
if ( !_palette ) return;
|
if (not _palette) return;
|
||||||
_palette->setItemVisible ( layer, visible );
|
_palette->setItemVisible( layer, visible );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1586,8 +1593,8 @@ namespace Hurricane {
|
||||||
//DbU::Unit unity = symbolicMode() ? DbU::lambda(1.0) : DbU::grid(10.0);
|
//DbU::Unit unity = symbolicMode() ? DbU::lambda(1.0) : DbU::grid(10.0);
|
||||||
DbU::Unit unity = DbU::lambda(1.0);
|
DbU::Unit unity = DbU::lambda(1.0);
|
||||||
|
|
||||||
return (!item || item->isItemVisible())
|
if (not item) return false;
|
||||||
&& ( Graphics::getThreshold(name) < getScale()*unity );
|
return item->isItemVisible() and (Graphics::getThreshold(name) < getScale()*unity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1595,7 +1602,8 @@ namespace Hurricane {
|
||||||
{
|
{
|
||||||
PaletteItem* item = (_palette) ? _palette->find(layerName) : NULL;
|
PaletteItem* item = (_palette) ? _palette->find(layerName) : NULL;
|
||||||
|
|
||||||
return !item || item->isItemVisible();
|
if (not item) return false;
|
||||||
|
return item->isItemVisible();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1604,8 +1612,8 @@ namespace Hurricane {
|
||||||
PaletteItem* item = (_palette) ? _palette->find(extensionName) : NULL;
|
PaletteItem* item = (_palette) ? _palette->find(extensionName) : NULL;
|
||||||
DbU::Unit unity = DbU::lambda(1.0);
|
DbU::Unit unity = DbU::lambda(1.0);
|
||||||
|
|
||||||
return (not item or item->isItemVisible())
|
if (not item) return false;
|
||||||
and ( Graphics::getThreshold(extensionName) < getScale()*unity );
|
return item->isItemVisible() and (Graphics::getThreshold(extensionName) < getScale()*unity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -162,6 +162,7 @@ namespace Hurricane {
|
||||||
// Painter control & Hurricane objects drawing primitives.
|
// Painter control & Hurricane objects drawing primitives.
|
||||||
inline void setEnableRedrawInterrupt ( bool );
|
inline void setEnableRedrawInterrupt ( bool );
|
||||||
inline void addDrawExtensionGo ( const Name&, InitExtensionGo_t*, DrawExtensionGo_t* );
|
inline void addDrawExtensionGo ( const Name&, InitExtensionGo_t*, DrawExtensionGo_t* );
|
||||||
|
inline void copyDrawExtensionGos ( const CellWidget* );
|
||||||
inline QPainter& getPainter ( size_t plane=PlaneId::Working );
|
inline QPainter& getPainter ( size_t plane=PlaneId::Working );
|
||||||
inline const DisplayStyle::HSVr& getDarkening () const;
|
inline const DisplayStyle::HSVr& getDarkening () const;
|
||||||
inline void copyToPrinter ( int xpaper, int ypaper, QPrinter*, PainterCb_t& );
|
inline void copyToPrinter ( int xpaper, int ypaper, QPrinter*, PainterCb_t& );
|
||||||
|
@ -176,6 +177,8 @@ namespace Hurricane {
|
||||||
bool isDrawableExtension ( const Name& );
|
bool isDrawableExtension ( const Name& );
|
||||||
bool isSelectable ( const Name& ) const;
|
bool isSelectable ( const Name& ) const;
|
||||||
bool isSelectable ( const Layer* ) const;
|
bool isSelectable ( const Layer* ) const;
|
||||||
|
bool isPrinter () const;
|
||||||
|
void setPrinter ( bool );
|
||||||
inline void setDarkening ( const DisplayStyle::HSVr& );
|
inline void setDarkening ( const DisplayStyle::HSVr& );
|
||||||
inline void setPen ( const QPen& , size_t plane=PlaneId::Working );
|
inline void setPen ( const QPen& , size_t plane=PlaneId::Working );
|
||||||
void drawBox ( DbU::Unit, DbU::Unit, DbU::Unit, DbU::Unit );
|
void drawBox ( DbU::Unit, DbU::Unit, DbU::Unit, DbU::Unit );
|
||||||
|
@ -452,6 +455,7 @@ namespace Hurricane {
|
||||||
, InitExtensionGo_t*
|
, InitExtensionGo_t*
|
||||||
, DrawExtensionGo_t*
|
, DrawExtensionGo_t*
|
||||||
);
|
);
|
||||||
|
inline void copyDrawExtensionGos ( const DrawingQuery& );
|
||||||
void setDrawExtensionGo ( const Name& );
|
void setDrawExtensionGo ( const Name& );
|
||||||
virtual bool hasMasterCellCallback () const;
|
virtual bool hasMasterCellCallback () const;
|
||||||
virtual bool hasGoCallback () const;
|
virtual bool hasGoCallback () const;
|
||||||
|
@ -647,6 +651,7 @@ namespace Hurricane {
|
||||||
QPoint _mousePosition;
|
QPoint _mousePosition;
|
||||||
Spot _spot;
|
Spot _spot;
|
||||||
shared_ptr<State> _state;
|
shared_ptr<State> _state;
|
||||||
|
bool _isPrinter;
|
||||||
bool _cellChanged;
|
bool _cellChanged;
|
||||||
bool _selectionHasChanged;
|
bool _selectionHasChanged;
|
||||||
int _delaySelectionChanged;
|
int _delaySelectionChanged;
|
||||||
|
@ -706,6 +711,10 @@ namespace Hurricane {
|
||||||
{ _drawExtensionGos[name] = make_pair(initExtensionGo,drawExtensionGo); }
|
{ _drawExtensionGos[name] = make_pair(initExtensionGo,drawExtensionGo); }
|
||||||
|
|
||||||
|
|
||||||
|
inline void CellWidget::DrawingQuery::copyDrawExtensionGos ( const CellWidget::DrawingQuery& other )
|
||||||
|
{ _drawExtensionGos = other._drawExtensionGos; }
|
||||||
|
|
||||||
|
|
||||||
inline void CellWidget::DrawingQuery::resetGoCount ()
|
inline void CellWidget::DrawingQuery::resetGoCount ()
|
||||||
{ _goCount = 0; }
|
{ _goCount = 0; }
|
||||||
|
|
||||||
|
@ -1145,7 +1154,11 @@ namespace Hurricane {
|
||||||
, InitExtensionGo_t* initExtensionGo
|
, InitExtensionGo_t* initExtensionGo
|
||||||
, DrawExtensionGo_t* drawExtensionGo
|
, DrawExtensionGo_t* drawExtensionGo
|
||||||
)
|
)
|
||||||
{ _drawingQuery.addDrawExtensionGo ( name, initExtensionGo, drawExtensionGo ); }
|
{ _drawingQuery.addDrawExtensionGo( name, initExtensionGo, drawExtensionGo ); }
|
||||||
|
|
||||||
|
|
||||||
|
inline void CellWidget::copyDrawExtensionGos ( const CellWidget* other )
|
||||||
|
{ _drawingQuery.copyDrawExtensionGos( other->_drawingQuery ); }
|
||||||
|
|
||||||
|
|
||||||
inline void CellWidget::setStartLevel ( int level )
|
inline void CellWidget::setStartLevel ( int level )
|
||||||
|
@ -1404,6 +1417,14 @@ namespace Hurricane {
|
||||||
{ _darkening = darkening; }
|
{ _darkening = darkening; }
|
||||||
|
|
||||||
|
|
||||||
|
inline bool CellWidget::isPrinter () const
|
||||||
|
{ return _isPrinter; }
|
||||||
|
|
||||||
|
|
||||||
|
inline void CellWidget::setPrinter ( bool state )
|
||||||
|
{ _isPrinter = state; }
|
||||||
|
|
||||||
|
|
||||||
inline bool CellWidget::timeout ( const char* fname, const Timer& timer, double timeout, bool& timedout ) const
|
inline bool CellWidget::timeout ( const char* fname, const Timer& timer, double timeout, bool& timedout ) const
|
||||||
{
|
{
|
||||||
if ( timedout ) return true;
|
if ( timedout ) return true;
|
||||||
|
|
|
@ -92,14 +92,23 @@ namespace Katana {
|
||||||
painter.setBrush( Graphics::getColorScale( ColorScale::Fire ).getBrush( density, widget->getDarkening() ) );
|
painter.setBrush( Graphics::getColorScale( ColorScale::Fire ).getBrush( density, widget->getDarkening() ) );
|
||||||
painter.drawRect( pixelBb );
|
painter.drawRect( pixelBb );
|
||||||
} else {
|
} else {
|
||||||
if ( (pixelBb.width() > 150) or (pixelBb.height() > 150) ) {
|
int fontScale = 0;
|
||||||
|
int halfHeight = 20;
|
||||||
|
int halfWidth = 80;
|
||||||
|
if (widget->isPrinter()) {
|
||||||
|
fontScale = -5;
|
||||||
|
halfHeight = 9;
|
||||||
|
halfWidth = 39;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
painter.setPen ( pen );
|
painter.setPen ( pen );
|
||||||
painter.setBrush( Graphics::getBrush("Anabatic::GCell",widget->getDarkening()) );
|
painter.setBrush( Graphics::getBrush("Anabatic::GCell",widget->getDarkening()) );
|
||||||
painter.drawRect( pixelBb );
|
painter.drawRect( pixelBb );
|
||||||
|
|
||||||
if ( (pixelBb.width() > 300) and (pixelBb.height() > 100) ) {
|
if ( (pixelBb.width() > 2*halfWidth) and (pixelBb.height() > 2*halfHeight) ) {
|
||||||
QString text = QString("id:%1").arg(gcell->getId());
|
QString text = QString("%1").arg(gcell->getId());
|
||||||
QFont font = Graphics::getFixedFont( QFont::Bold );
|
QFont font = Graphics::getFixedFont( QFont::Normal, false, false, fontScale );
|
||||||
painter.setFont(font);
|
painter.setFont(font);
|
||||||
|
|
||||||
pen.setWidth( 1 );
|
pen.setWidth( 1 );
|
||||||
|
@ -107,8 +116,8 @@ namespace Katana {
|
||||||
|
|
||||||
painter.save ();
|
painter.save ();
|
||||||
painter.translate( widget->dbuToScreenPoint(bb.getCenter().getX(), bb.getCenter().getY()) );
|
painter.translate( widget->dbuToScreenPoint(bb.getCenter().getX(), bb.getCenter().getY()) );
|
||||||
painter.drawRect ( QRect( -80, -25, 160, 50 ) );
|
painter.drawRect ( QRect( -halfWidth, -halfHeight, 2*halfWidth, 2*halfHeight ) );
|
||||||
painter.drawText ( QRect( -80, -25, 160, 50 )
|
painter.drawText ( QRect( -halfWidth, -halfHeight, 2*halfWidth, 2*halfHeight )
|
||||||
, text
|
, text
|
||||||
, QTextOption(Qt::AlignCenter)
|
, QTextOption(Qt::AlignCenter)
|
||||||
);
|
);
|
||||||
|
@ -116,7 +125,6 @@ namespace Katana {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void GraphicKatanaEngine::initEdge ( CellWidget* widget )
|
void GraphicKatanaEngine::initEdge ( CellWidget* widget )
|
||||||
|
@ -140,11 +148,16 @@ namespace Katana {
|
||||||
if (edge) {
|
if (edge) {
|
||||||
Box bb = edge->getBoundingBox();
|
Box bb = edge->getBoundingBox();
|
||||||
uint32_t occupancy = 255;
|
uint32_t occupancy = 255;
|
||||||
if (edge->getRealOccupancy() < edge->getCapacity())
|
//if (edge->getRealOccupancy() < edge->getCapacity())
|
||||||
occupancy = (uint32_t)( 255.0 * ( (float)edge->getRealOccupancy() / (float)edge->getCapacity() ) );
|
// occupancy = (uint32_t)( 255.0 * ( (float)edge->getRealOccupancy() / (float)edge->getCapacity() ) );
|
||||||
|
|
||||||
|
float edgeOccupancy = edge->getEstimateOccupancy() + (float)edge->getRealOccupancy();
|
||||||
|
|
||||||
|
if ((unsigned int)edgeOccupancy < edge->getCapacity())
|
||||||
|
occupancy = (uint32_t)( 255.0 * (edgeOccupancy / (float)edge->getCapacity()) );
|
||||||
|
|
||||||
QPainter& painter = widget->getPainter();
|
QPainter& painter = widget->getPainter();
|
||||||
if (edge->getRealOccupancy() > edge->getCapacity()) {
|
if ((unsigned int)edgeOccupancy > edge->getCapacity()) {
|
||||||
QColor color ( Qt::cyan );
|
QColor color ( Qt::cyan );
|
||||||
painter.setPen( DisplayStyle::darken(color,widget->getDarkening()) );
|
painter.setPen( DisplayStyle::darken(color,widget->getDarkening()) );
|
||||||
}
|
}
|
||||||
|
@ -160,7 +173,10 @@ namespace Katana {
|
||||||
|
|
||||||
if (fontHeight > ((edge->isHorizontal()) ? pixelBb.height() : pixelBb.width()) + 4) return;
|
if (fontHeight > ((edge->isHorizontal()) ? pixelBb.height() : pixelBb.width()) + 4) return;
|
||||||
|
|
||||||
QString text = QString("%1/%2").arg(edge->getRealOccupancy()).arg(edge->getCapacity());
|
//QString text = QString("%1/%2").arg(edge->getRealOccupancy()).arg(edge->getCapacity());
|
||||||
|
QString text = QString("%1/%2")
|
||||||
|
.arg( edgeOccupancy )
|
||||||
|
.arg( edge->getCapacity() );
|
||||||
QColor color ( (occupancy > 170) ? Qt::black : Qt::white );
|
QColor color ( (occupancy > 170) ? Qt::black : Qt::white );
|
||||||
painter.setPen (DisplayStyle::darken(color,widget->getDarkening()));
|
painter.setPen (DisplayStyle::darken(color,widget->getDarkening()));
|
||||||
painter.setFont(font);
|
painter.setFont(font);
|
||||||
|
|
Loading…
Reference in New Issue