master
lanxingxing 2024-08-31 12:05:45 +08:00
parent 0d72b07729
commit 1e39f4e01b
11 changed files with 170 additions and 13 deletions

View File

@ -248,6 +248,11 @@ void BoundarySetting::setBoundarySettingStatus(int type)
m_picker->setSelectModel(type);
}
void BoundarySetting::set3DType(bool is3DType)
{
m_picker->set3DType(is3DType);
}
int BoundarySetting::getFaceNum()
{
return m_faceNum;

View File

@ -134,6 +134,9 @@ public:
int getFaceIdToGridId(int id);
int getPointIdToGridId(int id);
vtkSmartPointer<vtkActor> getPointActor();
//false 2D true 3D
void set3DType(bool is3DType);
//GridPoint
//0-ux,1-uy,2-uz

View File

@ -91,6 +91,9 @@ void DisplacementLimitSettingWidget::showEvent(QShowEvent *event)
m_boundarySetting->setStructure(m_preProcessingService->getGridStructure(),m_preProcessingService->getPointStructure());
m_boundarySetting->setFaceToPoint(m_preProcessingService->getFaceToPoint());
m_boundarySetting->set3DType(m_preProcessingService->is3DType());
m_visualWidgetService->addActor(m_preProcessingService->getPointActor());
m_sphereSource = m_preProcessingService->getSphereSource();

View File

@ -104,6 +104,7 @@ void DistributedLoadSettingWidget::showEvent(QShowEvent *event)
}
qDebug()<<QStringLiteral("开始设置均布载荷");
//----------------------更新颜色
@ -112,6 +113,9 @@ void DistributedLoadSettingWidget::showEvent(QShowEvent *event)
m_boundarySetting->setCellToGridMap(m_preProcessingService->getCellIdToGridIdMap());
m_boundarySetting->setBoundarySettingStatus(2);
//3D 1 2D 2
m_boundarySetting->set3DType(m_preProcessingService->is3DType());
ui->comboBox->clear();
for(int i=1;i<m_preProcessingService->getFaceToCell().size();i++)
@ -121,7 +125,7 @@ void DistributedLoadSettingWidget::showEvent(QShowEvent *event)
// connect(ui->comboBox, SIGNAL(currentIndexChanged(int)), this, SLOT(onBoxIndexChanged(int)));
ui->allShowRadio->setChecked(true); // 再次选中
ui->allShowRadio->toggled(true);
ui->clickSelectionCheckBox->setChecked(true);
}

View File

@ -16,6 +16,7 @@
#include<vtkDataSetMapper.h>
#include <QToolButton>
#include <vtkCellPicker.h>
#include <vtkPointPicker.h>
#include <vtkVertexGlyphFilter.h>
#include <vtkSphereSource.h>
#include <set>
@ -50,6 +51,7 @@ PropPickerInteractionStyle::PropPickerInteractionStyle(BoundarySetting *boundary
{
m_boundarySetting = boundarySetting;
m_visualWidgetService = ServiceRegistry<VisualWidgetService>::instance().getService();
m_is3DType = true;
}
void PropPickerInteractionStyle::Execute(vtkObject *caller, unsigned long eventId, void *callData)
@ -120,6 +122,11 @@ void PropPickerInteractionStyle::clearSelectedFace()
m_selectedFace.clear();
}
void PropPickerInteractionStyle::set3DType(bool is3DType)
{
m_is3DType = is3DType;
}
void PropPickerInteractionStyle::setPointColor(QSet<int>point,double color[3])
{
vtkDataArray *pointColor = m_boundarySetting->getPointStructure()->GetPointData()->GetScalars();
@ -188,15 +195,25 @@ void PropPickerInteractionStyle::clearPointColor()
void PropPickerInteractionStyle::clearFaceColor()
{
vtkDataArray *faceColor = m_boundarySetting->getCellStructure()->GetCellData()->GetScalars();
faceColor->FillComponent(0, 255);
faceColor->FillComponent(1, 255);
faceColor->FillComponent(2, 255);
if(m_is3DType)
{
faceColor->FillComponent(0, 255);
faceColor->FillComponent(1, 255);
faceColor->FillComponent(2, 255);
}
else
{
faceColor->FillComponent(0, 0);
faceColor->FillComponent(1, 0);
faceColor->FillComponent(2, 0);
}
faceColor->Modified();
m_visualWidgetService->getrenderWindow()->Render();
}
void PropPickerInteractionStyle::selectGridNode(vtkObject *caller, unsigned long eventId, void *callData)
{
if(m_is3DType==0){
vtkRenderWindowInteractor* interactor = vtkRenderWindowInteractor::SafeDownCast(caller);
if (!interactor)
return;
@ -278,6 +295,69 @@ void PropPickerInteractionStyle::selectGridNode(vtkObject *caller, unsigned long
m_boundarySetting->showPointData(closestPointIdInPolyData);
}
}}
else{
vtkRenderWindowInteractor* interactor = vtkRenderWindowInteractor::SafeDownCast(caller);
if (!interactor)
return;
// ??????????
int* clickPos = interactor->GetEventPosition();
// ??
vtkSmartPointer<vtkPointPicker> picker = vtkSmartPointer<vtkPointPicker>::New();
picker->SetTolerance(0.001);
picker->Pick(clickPos[0], clickPos[1], 0, interactor->GetRenderWindow()->GetRenderers()->GetFirstRenderer());
vtkUnstructuredGrid *polyData = m_boundarySetting->getPointStructure();
vtkIdType closestPointIdInPolyData = picker->GetPointId();
std::cout<<"111111111111111111111111111111"<<std::endl;
qDebug()<<"cellid "<<(int)(closestPointIdInPolyData);
//qDebug()<<"cellid "<<cellId;
//if (cellId != -1) {
if (closestPointIdInPolyData != -1) {
double closestPoint[3];
polyData->GetPoints()->GetPoint(closestPointIdInPolyData, closestPoint);
qDebug() <<"point: "<<closestPointIdInPolyData+1;
qDebug() << "Closest point coordinates: ("
<< closestPoint[0] << ", "
<< closestPoint[1] << ", "
<< closestPoint[2] << ")";
vtkDataArray *pointColor = polyData->GetPointData()->GetScalars();
//???????????????
if(m_selectedPoint.contains(closestPointIdInPolyData))
{
m_selectedPoint.remove(closestPointIdInPolyData);
if(m_boundarySetting->isSelectedPoint(closestPointIdInPolyData))//?????
{
pointColor->SetComponent(closestPointIdInPolyData, 0, 255);
pointColor->SetComponent(closestPointIdInPolyData, 1, 0);
pointColor->SetComponent(closestPointIdInPolyData, 2, 255);
pointColor->Modified();
}
else //??????
{
pointColor->SetComponent(closestPointIdInPolyData, 0, 255);
pointColor->SetComponent(closestPointIdInPolyData, 1, 255);
pointColor->SetComponent(closestPointIdInPolyData, 2, 255);
pointColor->Modified();
}
}
else
{
m_selectedPoint.insert(closestPointIdInPolyData);
pointColor->SetComponent(closestPointIdInPolyData, 0, 255);
pointColor->SetComponent(closestPointIdInPolyData, 1, 0);
pointColor->SetComponent(closestPointIdInPolyData, 2, 0);
pointColor->Modified();
}
m_boundarySetting->showPointData(closestPointIdInPolyData);
//}
}
}
}
@ -329,9 +409,19 @@ void PropPickerInteractionStyle::selectGridFace(vtkObject *caller, unsigned long
}
else //??????
{
cellcolor->SetComponent(cellId, 0, 255);
cellcolor->SetComponent(cellId, 1, 255);
cellcolor->SetComponent(cellId, 2, 255);
if(m_is3DType)
{
cellcolor->SetComponent(cellId, 0, 255);
cellcolor->SetComponent(cellId, 1, 255);
cellcolor->SetComponent(cellId, 2, 255);
}
else
{
cellcolor->SetComponent(cellId, 0, 0);
cellcolor->SetComponent(cellId, 1, 0);
cellcolor->SetComponent(cellId, 2, 0);
}
cellcolor->Modified();
}
}

View File

@ -39,6 +39,7 @@ public:
void faceRefresh();
void setFaceColor(int faceId, double color[]);
void addSelectedFace(int faceId);
void set3DType(bool is3DType);
private:
void selectGridNode(vtkObject *caller, unsigned long eventId, void *callData);
void selectGridFace(vtkObject *caller, unsigned long eventId, void *callData);
@ -47,6 +48,8 @@ private:
QSet<int>m_selectedPoint;
QSet<int>m_selectedFace;
VisualWidgetService *m_visualWidgetService;
bool m_is3DType;
};
#endif // PROPPICKERINTERACTIONSTYLE_H

View File

@ -310,6 +310,13 @@ bool PreProcessing::isHaveStructured()
return false;
}
bool PreProcessing::is3DType()
{
if(m_modelType == 1)
return false;
else
return true;
}
vtkSmartPointer<vtkUnstructuredGrid> PreProcessing::getPointStructure()
{
@ -1067,6 +1074,7 @@ void PreProcessing::generateGrid(float maxgrid)
read->genProcess();
m_gridStructure = read->getStructure();
m_gridStructure_origin = read->getStructureOrigin();
m_pointStructure = vtkSmartPointer<vtkUnstructuredGrid>::New();
m_pointStructure->DeepCopy(m_gridStructure);
@ -1079,22 +1087,52 @@ void PreProcessing::generateGrid(float maxgrid)
//------------------------------------整体
vtkSmartPointer<vtkDataSetMapper> mapper = vtkSmartPointer<vtkDataSetMapper>::New();
mapper->SetInputData(m_gridStructure);
mapper->SetRelativeCoincidentTopologyPolygonOffsetParameters(-500.0,-500.0);
mapper->SetRelativeCoincidentTopologyLineOffsetParameters(-500.0,-500.0);
mapper->SetRelativeCoincidentTopologyPointOffsetParameter(-500.0);
//设置颜色
vtkDataArray *cellcolor = vtkUnsignedCharArray::New();
cellcolor->SetNumberOfComponents(3);
//m_gridStructure->GetCellData()->SetScalars(cellcolor);
m_gridStructure->GetCellData()->SetScalars(cellcolor);
cellcolor->SetNumberOfTuples(m_gridStructure->GetNumberOfCells());
cellcolor->FillComponent(0, 255);
cellcolor->FillComponent(0, 0);
cellcolor->FillComponent(1, 0);
cellcolor->FillComponent(2, 0);
m_cellActor = vtkSmartPointer<vtkActor>::New();
m_cellActor->SetMapper(mapper);
m_cellActor->GetProperty()->EdgeVisibilityOn();
m_cellActor->GetProperty()->SetLineWidth(5);
//m_cellActor->SetPickable(false);
vtkSmartPointer<vtkDataSetMapper> mapper2 = vtkSmartPointer<vtkDataSetMapper>::New();
mapper2->SetInputData(m_gridStructure_origin);
mapper2->SetRelativeCoincidentTopologyPolygonOffsetParameters(500.0,500.0);
mapper2->SetRelativeCoincidentTopologyLineOffsetParameters(500.0,500.0);
mapper2->SetRelativeCoincidentTopologyPointOffsetParameter(500.0);
//设置颜色
vtkDataArray *cellcolor2 = vtkUnsignedCharArray::New();
cellcolor2->SetNumberOfComponents(3);
//m_gridStructure->GetCellData()->SetScalars(cellcolor);
m_gridStructure->GetCellData()->SetScalars(cellcolor);
cellcolor2->SetNumberOfTuples(m_gridStructure_origin->GetNumberOfCells());
cellcolor2->FillComponent(0, 0);
cellcolor2->FillComponent(1, 0);
cellcolor2->FillComponent(2, 0);
m_cellActor2 = vtkSmartPointer<vtkActor>::New();
m_cellActor2->SetMapper(mapper2);
m_cellActor2->GetProperty()->EdgeVisibilityOn();
m_cellActor2->SetPickable(false);
m_visualWidgetService->removeAllActor();
m_visualWidgetService->addActor(m_cellActor);
m_visualWidgetService->addActor(m_cellActor2);
m_visualWidgetService->getRender()->ResetCamera();
m_visualWidgetService->getrenderWindow()->Render();
@ -1112,11 +1150,14 @@ void PreProcessing::generateGrid(float maxgrid)
glyphMapper->SetInputConnection(glyphFilter->GetOutputPort());
glyphMapper->ScalarVisibilityOn(); // Ensure colors are visible
glyphMapper->SetScalarModeToUsePointData();
glyphMapper->SetRelativeCoincidentTopologyPolygonOffsetParameters(-3000.0,-3000.0);
glyphMapper->SetRelativeCoincidentTopologyLineOffsetParameters(-3000.0,-3000.0);
glyphMapper->SetRelativeCoincidentTopologyPointOffsetParameter(-3000.0);
m_pointActor = vtkSmartPointer<vtkActor>::New();
m_pointActor->SetMapper(glyphMapper);
m_pointActor->SetPickable(false);
//设置点颜色

View File

@ -47,6 +47,7 @@ public:
void importGrid(QString fileName);
vtkSmartPointer<vtkUnstructuredGrid> getGridStructure();
vtkSmartPointer<vtkUnstructuredGrid> getGridStructureOrigin();
vtkSmartPointer<vtkUnstructuredGrid> getPointStructure();
QVector<QSet<int> > getFaceToPoint();
QVector<QVector<int> > getFaceToCell();
@ -54,6 +55,7 @@ public:
QMap<int, int> getCellIdToGridIdMap();
vtkSmartPointer<vtkSphereSource> getSphereSource();
bool isHaveStructured();
bool is3DType();
private:
bool buildquad(ifstream &elements, vtkSmartPointer<vtkCellArray> cells);
bool buildcells(ifstream &elements, vtkSmartPointer<vtkCellArray> cells, int state, vtkSmartPointer<vtkUnstructuredGrid> Grid);
@ -78,17 +80,16 @@ private:
vtkSmartPointer<vtkUnstructuredGrid> m_gridStructure;
vtkSmartPointer<vtkUnstructuredGrid> m_gridStructure_origin;
vtkSmartPointer<vtkUnstructuredGrid> m_pointStructure;
vtkSmartPointer<vtkActor> m_pointActor;
vtkSmartPointer<vtkSphereSource> m_sphereSource;
vtkSmartPointer<vtkActor> m_cellActor;
vtkSmartPointer<vtkActor> m_cellActor2;
int m_modelType;
int m_status;
float m_x,m_y,m_z;
float m_ox,m_oy,m_oz;
QMap<vtkSmartPointer<vtkActor>,QString>m_map;

View File

@ -714,6 +714,11 @@ vtkSmartPointer<vtkUnstructuredGrid> gen2DGrid::getStructure()
return m_grid_surface;
}
vtkSmartPointer<vtkUnstructuredGrid> gen2DGrid::getStructureOrigin()
{
return m_grid;
}
QVector<QSet<int>> gen2DGrid::getFaceToPoint()
{
return m_faceToPoint;

View File

@ -134,6 +134,7 @@ public:
QVector<QVector<int> > getFaceToCell();
QMap<int, int> getCellIdToGridIdMap();
vtkSmartPointer<vtkUnstructuredGrid> getStructure();
vtkSmartPointer<vtkUnstructuredGrid> getStructureOrigin();
};

View File

@ -14,6 +14,7 @@ struct PreProcessingService
{
virtual vtkSmartPointer<vtkUnstructuredGrid> getGridStructure() = 0;
virtual vtkSmartPointer<vtkUnstructuredGrid> getPointStructure() = 0;
virtual bool is3DType() = 0;
virtual QVector<QSet<int> > getFaceToPoint() = 0;
virtual QVector<QVector<int> > getFaceToCell() = 0;
virtual vtkSmartPointer<vtkActor> getPointActor() = 0;