当前位置: 首页>>代码示例>>C++>>正文


C++ IfcRepresentationShapeItems类代码示例

本文整理汇总了C++中IfcRepresentationShapeItems的典型用法代码示例。如果您正苦于以下问题:C++ IfcRepresentationShapeItems类的具体用法?C++ IfcRepresentationShapeItems怎么用?C++ IfcRepresentationShapeItems使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了IfcRepresentationShapeItems类的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: if

bool IfcGeom::Kernel::convert(const IfcSchema::IfcMappedItem* l, IfcRepresentationShapeItems& shapes) {
    gp_GTrsf gtrsf;
    IfcSchema::IfcCartesianTransformationOperator* transform = l->MappingTarget();
    if ( transform->is(IfcSchema::Type::IfcCartesianTransformationOperator3DnonUniform) ) {
        IfcGeom::Kernel::convert((IfcSchema::IfcCartesianTransformationOperator3DnonUniform*)transform,gtrsf);
    } else if ( transform->is(IfcSchema::Type::IfcCartesianTransformationOperator2DnonUniform) ) {
        Logger::Message(Logger::LOG_ERROR, "Unsupported MappingTarget:", transform->entity);
        return false;
    } else if ( transform->is(IfcSchema::Type::IfcCartesianTransformationOperator3D) ) {
        gp_Trsf trsf;
        IfcGeom::Kernel::convert((IfcSchema::IfcCartesianTransformationOperator3D*)transform,trsf);
        gtrsf = trsf;
    } else if ( transform->is(IfcSchema::Type::IfcCartesianTransformationOperator2D) ) {
        gp_Trsf2d trsf_2d;
        IfcGeom::Kernel::convert((IfcSchema::IfcCartesianTransformationOperator2D*)transform,trsf_2d);
        gtrsf = (gp_Trsf) trsf_2d;
    }
    IfcSchema::IfcRepresentationMap* map = l->MappingSource();
    IfcSchema::IfcAxis2Placement* placement = map->MappingOrigin();
    gp_Trsf trsf;
    if (placement->is(IfcSchema::Type::IfcAxis2Placement3D)) {
        IfcGeom::Kernel::convert((IfcSchema::IfcAxis2Placement3D*)placement,trsf);
    } else {
        gp_Trsf2d trsf_2d;
        IfcGeom::Kernel::convert((IfcSchema::IfcAxis2Placement2D*)placement,trsf_2d);
        trsf = trsf_2d;
    }
    gtrsf.Multiply(trsf);
    const unsigned int previous_size = (const unsigned int) shapes.size();
    bool b = convert_shapes(map->MappedRepresentation(),shapes);
    for ( unsigned int i = previous_size; i < shapes.size(); ++ i ) {
        shapes[i].append(gtrsf);
    }
    return b;
}
开发者ID:jf---,项目名称:IfcOpenShell,代码行数:35,代码来源:IfcGeomShapes.cpp

示例2:

bool IfcGeom::Kernel::convert(const IfcSchema::IfcFacetedBrep* l, IfcRepresentationShapeItems& shape) {
    TopoDS_Shape s;
    const SurfaceStyle* collective_style = get_style(l);
    if (convert_shape(l->Outer(),s) ) {
        const SurfaceStyle* indiv_style = get_style(l->Outer());
        shape.push_back(IfcRepresentationShapeItem(s, indiv_style ? indiv_style : collective_style));
        return true;
    }
    return false;
}
开发者ID:jf---,项目名称:IfcOpenShell,代码行数:10,代码来源:IfcGeomShapes.cpp

示例3: BRepBuilderAPI_GTransform

bool IfcGeom::convert_openings_fast(const Ifc2x3::IfcProduct::ptr entity, const Ifc2x3::IfcRelVoidsElement::list& openings, 
							   const IfcRepresentationShapeItems& entity_shapes, const gp_Trsf& entity_trsf, IfcRepresentationShapeItems& cut_shapes) {
	
	// Create a compound of all opening shapes in order to speed up the boolean operations
	TopoDS_Compound opening_compound;
	BRep_Builder builder;
	builder.MakeCompound(opening_compound);

	for ( Ifc2x3::IfcRelVoidsElement::it it = openings->begin(); it != openings->end(); ++ it ) {
		Ifc2x3::IfcRelVoidsElement::ptr v = *it;
		Ifc2x3::IfcFeatureElementSubtraction::ptr fes = v->RelatedOpeningElement();
		if ( fes->is(Ifc2x3::Type::IfcOpeningElement) ) {

			// Convert the IfcRepresentation of the IfcOpeningElement
			gp_Trsf opening_trsf;
			IfcGeom::convert(fes->ObjectPlacement(),opening_trsf);

			// Move the opening into the coordinate system of the IfcProduct
			opening_trsf.PreMultiply(entity_trsf.Inverted());

			Ifc2x3::IfcProductRepresentation::ptr prodrep = fes->Representation();
			Ifc2x3::IfcRepresentation::list reps = prodrep->Representations();

			IfcGeom::IfcRepresentationShapeItems opening_shapes;
						
			for ( Ifc2x3::IfcRepresentation::it it2 = reps->begin(); it2 != reps->end(); ++ it2 ) {
				IfcGeom::convert_shapes(*it2,opening_shapes);
			}

			for ( unsigned int i = 0; i < opening_shapes.size(); ++ i ) {
				gp_GTrsf gtrsf = opening_shapes[i].Placement();
				gtrsf.PreMultiply(opening_trsf);
				const TopoDS_Shape& opening_shape = gtrsf.Form() == gp_Other
					? BRepBuilderAPI_GTransform(opening_shapes[i].Shape(),gtrsf,true).Shape()
					: (opening_shapes[i].Shape()).Moved(gtrsf.Trsf());
				builder.Add(opening_compound,opening_shape);
			}

		}
	}

	// Iterate over the shapes of the IfcProduct
	for ( IfcGeom::IfcRepresentationShapeItems::const_iterator it3 = entity_shapes.begin(); it3 != entity_shapes.end(); ++ it3 ) {
		TopoDS_Shape entity_shape_solid;
		const TopoDS_Shape& entity_shape_unlocated = IfcGeom::ensure_fit_for_subtraction(it3->Shape(),entity_shape_solid);
		const gp_GTrsf& entity_shape_gtrsf = it3->Placement();
		TopoDS_Shape entity_shape;
		if ( entity_shape_gtrsf.Form() == gp_Other ) {
			Logger::Message(Logger::LOG_WARNING,"Applying non uniform transformation to:",entity->entity);
			entity_shape = BRepBuilderAPI_GTransform(entity_shape_unlocated,entity_shape_gtrsf,true).Shape();
		} else {
			entity_shape = entity_shape_unlocated.Moved(entity_shape_gtrsf.Trsf());
		}

		BRepAlgoAPI_Cut brep_cut(entity_shape,opening_compound);
		bool is_valid = false;
		if ( brep_cut.IsDone() ) {
			TopoDS_Shape brep_cut_result = brep_cut;
				
			BRepCheck_Analyzer analyser(brep_cut_result);
			is_valid = analyser.IsValid() != 0;
			if ( is_valid ) {
				cut_shapes.push_back(IfcGeom::IfcRepresentationShapeItem(brep_cut_result, &it3->Style()));
			}
		}
		if ( !is_valid ) {
			// Apparently processing the boolean operation failed or resulted in an invalid result
			// in which case the original shape without the subtractions is returned instead
			// we try convert the openings in the original way, one by one.
			Logger::Message(Logger::LOG_WARNING,"Subtracting combined openings compound failed:",entity->entity);
			return false;
		}
		
	}
	return true;
}
开发者ID:iwataka,项目名称:IfcOpenShell-JNI,代码行数:76,代码来源:IfcGeomFunctions.cpp


注:本文中的IfcRepresentationShapeItems类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。