Skip to content

OpeningPointsUtil

implementation of the opening points utilities

OpeningPointsUtil

Canonical path: Utils.Architecture.OpeningPointsUtil.OpeningPointsUtil

implementation of the opening points utilities

calc_door_swing_base_point_index staticmethod

calc_door_swing_base_point_index(
    opening_start_pnt: Point2D,
    opening_end_pnt: Point2D,
    width: float,
    element_thickness: float,
    input_pnt: Point3D,
) -> int

calculate the door swing base point index

Parameters:

  • opening_start_pnt (Point2D) –

    opening start point

  • opening_end_pnt (Point2D) –

    opening end point

  • width (float) –

    with of the opening

  • element_thickness (float) –

    element thickness

  • input_pnt (Point3D) –

    input point

Returns:

  • int

    door swing base point index

calc_point_at_placement_arc staticmethod

calc_point_at_placement_arc(
    local_dist: float, placement_arc: Arc2D, placement_polyline: Polyline2D
) -> tuple[bool, Point2D]

calculate the point at the placement arc

Parameters:

  • local_dist (float) –

    local point distance at the placement arc

  • placement_arc (Arc2D) –

    placement arc

  • placement_polyline (Polyline2D) –

    placement polyline

Returns:

  • tuple[bool, Point2D]

    found state, point at the polyline

create_opening_end_point_for_axis_element staticmethod

create_opening_end_point_for_axis_element(
    opening_start_pnt: Point2D,
    opening_width: float,
    placement_ele_axis: Line2D | Arc2D,
    placement_ele_polygon: Polygon2D | Polyline2D,
    placement_line: Line2D,
) -> Point2D

create the opening points for an axis element

Parameters:

  • opening_start_pnt (Point2D) –

    opening start point

  • opening_width (float) –

    opening width

  • placement_ele_axis (Line2D | Arc2D) –

    opening placement element axis

  • placement_ele_polygon (Polygon2D | Polyline2D) –

    opening placement element polygon / polyline

  • placement_line (Line2D) –

    placement line

Returns:

  • Point2D

    end point of the opening

create_opening_end_point_for_shaped_element staticmethod

create_opening_end_point_for_shaped_element(
    opening_start_pnt: Point2D, opening_width: float, placement_line: Line2D
) -> Point2D

create the opening points for a shaped element

Parameters:

  • opening_start_pnt (Point2D) –

    opening start point

  • opening_width (float) –

    opening width

  • placement_line (Line2D) –

    placement line

Returns:

  • Point2D

    end point of the opening

create_opening_points_for_axis_element staticmethod

create_opening_points_for_axis_element(
    opening_start_pnt: Point2D,
    opening_end_pnt: Point2D,
    opening_width: float,
    placement_ele_thickness: float,
) -> tuple[Point2D, ...]

create the opening points for an axis element

Parameters:

  • opening_start_pnt (Point2D) –

    opening start point

  • opening_end_pnt (Point2D) –

    opening end point

  • opening_width (float) –

    opening width

  • placement_ele_thickness (float) –

    opening placement element thickness

Returns:

get_distance_from_offset_end_point staticmethod

get_distance_from_offset_end_point(
    input_pnt: Point3D,
    placement_ele_axis: Line2D | Arc2D | None,
    offset_end_pnt: Point2D,
    placement_line: Line2D,
    placement_arc: Arc2D | None,
    placement_ele_polygon: Polygon2D | Polyline2D,
) -> float

get the local distance between input and offset end point

Parameters:

  • input_pnt (Point3D) –

    input point

  • placement_ele_axis (Line2D | Arc2D | None) –

    opening placement element axis

  • offset_end_pnt (Point2D) –

    offset end point

  • placement_line (Line2D) –

    placement line

  • placement_arc (Arc2D | None) –

    placement arc

  • placement_ele_polygon (Polygon2D | Polyline2D) –

    opening placement element polygon / polyline

Returns:

  • float

    distance between input and start point

get_distance_from_offset_start_point staticmethod

get_distance_from_offset_start_point(
    input_pnt: Point3D,
    placement_ele_axis: Line2D | Arc2D | None,
    offset_start_pnt: Point2D,
    placement_line: Line2D,
    placement_arc: Arc2D | None,
    placement_ele_polygon: Polygon2D | Polyline2D,
) -> float

get the local distance between input and offset start point

Parameters:

  • input_pnt (Point3D) –

    input point

  • placement_ele_axis (Line2D | Arc2D | None) –

    opening placement element axis

  • offset_start_pnt (Point2D) –

    offset start point

  • placement_line (Line2D) –

    placement line

  • placement_arc (Arc2D | None) –

    placement arc

  • placement_ele_polygon (Polygon2D | Polyline2D) –

    opening placement element polygon / polyline

Returns:

  • float

    distance between input and start point

get_opening_offset_points staticmethod

get_opening_offset_points(
    element: BaseElementAdapter,
    opening_start_pnt: Point2D,
    opening_end_pnt: Point2D,
    placement_line: Line2D,
) -> tuple[bool, Point2D, Point2D]

get the left and right point for the opening offset

Parameters:

  • element (BaseElementAdapter) –

    opening placement element for the opening

  • opening_start_pnt (Point2D) –

    opening start point

  • opening_end_pnt (Point2D) –

    opening end point

  • placement_line (Line2D) –

    placement line from the opening start point

Returns:

get_start_point_from_end_offset staticmethod

get_start_point_from_end_offset(
    placement_ele_axis: Line2D | Arc2D | None,
    offset_end_pnt: Point2D,
    placement_line: Line2D,
    placement_arc: Arc2D | None,
    opening_width: float,
    placement_ele_polygon: Polygon2D | Polyline2D,
    offset: float,
) -> tuple[bool, Point2D]

get the start point by an offset from an offset start point

Parameters:

  • placement_ele_axis (Line2D | Arc2D | None) –

    opening placement element axis

  • offset_end_pnt (Point2D) –

    offset end point

  • placement_line (Line2D) –

    placement line

  • placement_arc (Arc2D | None) –

    placement arc

  • opening_width (float) –

    opening width

  • placement_ele_polygon (Polygon2D | Polyline2D) –

    opening placement element polygon / polyline

  • offset (float) –

    offset from the offset start point

Returns:

get_start_point_from_start_offset staticmethod

get_start_point_from_start_offset(
    placement_ele_axis: Line2D | Arc2D | None,
    offset_start_pnt: Point2D,
    placement_line: Line2D,
    placement_arc: Arc2D | None,
    placement_ele_polygon: Polygon2D | Polyline2D,
    offset: float,
) -> tuple[bool, Point2D]

get the start point by an offset from an offset start point

Parameters:

  • placement_ele_axis (Line2D | Arc2D | None) –

    opening placement element axis

  • offset_start_pnt (Point2D) –

    offset start point

  • placement_line (Line2D) –

    placement line

  • placement_arc (Arc2D | None) –

    placement arc

  • placement_ele_polygon (Polygon2D | Polyline2D) –

    opening placement element polygon / polyline

  • offset (float) –

    offset from the offset start point

Returns:

select_opening_symbol_ref_pnt staticmethod

select_opening_symbol_ref_pnt(
    input_pnt: Point3D, opening_tier_ref_pnt: tuple[Point2D, ...]
) -> RefPointPosition

select the reference point for the opening symbol

Parameters:

  • input_pnt (Point3D) –

    input point

  • opening_tier_ref_pnt (tuple[Point2D, ...]) –

    opening tier reference points

Returns:

select_opening_tier staticmethod

select_opening_tier(
    input_pnt: Point3D, opening_tier_center: list[Point2D]
) -> int

select the opening tier

Parameters:

  • input_pnt (Point3D) –

    input point

  • opening_tier_center (list[Point2D]) –

    center for the opening tier

Returns:

  • int

    returns

Placeholder