Operator Reference

get_region_chainT_get_region_chainGetRegionChainGetRegionChainget_region_chain (Operator)

get_region_chainT_get_region_chainGetRegionChainGetRegionChainget_region_chain — Contour of an object as chain code.

Warning

get_region_chainget_region_chainGetRegionChainGetRegionChainget_region_chain is obsolete and is only provided for reasons of backward compatibility.

Signature

get_region_chain(Region : : : Row, Column, Chain)

Herror T_get_region_chain(const Hobject Region, Htuple* Row, Htuple* Column, Htuple* Chain)

void GetRegionChain(const HObject& Region, HTuple* Row, HTuple* Column, HTuple* Chain)

void HRegion::GetRegionChain(Hlong* Row, Hlong* Column, HTuple* Chain) const

static void HOperatorSet.GetRegionChain(HObject region, out HTuple row, out HTuple column, out HTuple chain)

void HRegion.GetRegionChain(out int row, out int column, out HTuple chain)

def get_region_chain(region: HObject) -> Tuple[int, int, Sequence[int]]

Description

The operator get_region_chainget_region_chainGetRegionChainGetRegionChainget_region_chain returns the contour of a region. A contour is a series of pixels describing the outline of the region. The contour “lies on” the region. It starts at the smallest line number; in that line at the pixel with the largest column index. The rotation occurs clockwise. Holes of the region are ignored. The direction code (chain code) is defined as follows:

3 2 1 4 * 0 5 6 7 The operator get_region_chainget_region_chainGetRegionChainGetRegionChainget_region_chain returns the code in the form of a tuple. In case of an empty region the parameters RowRowRowrowrow and ColumnColumnColumncolumncolumn are zero and ChainChainChainchainchain is the empty tuple.

Attention

Holes of the region are ignored. Only one region may be passed, and it must have exactly one connection component.

Execution Information

  • Multithreading type: reentrant (runs in parallel with non-exclusive operators).
  • Multithreading scope: global (may be called from any thread).
  • Processed without parallelization.

Parameters

RegionRegionRegionregionregion (input_object)  region objectHRegionHObjectHObjectHobject

Region to be transformed.

RowRowRowrowrow (output_control)  chain.begin.y HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Line of starting point.

ColumnColumnColumncolumncolumn (output_control)  chain.begin.x HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Column of starting point.

ChainChainChainchainchain (output_control)  chain.code-array HTupleSequence[int]HTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Direction code of the contour (from starting point).

Value range: 0 ≤ Chain Chain Chain chain chain ≤ 7

Result

The operator get_region_chainget_region_chainGetRegionChainGetRegionChainget_region_chain normally returns the value 2 ( H_MSG_TRUE) . If more than one connection component is passed an exception is raised. The behavior in case of empty input (no input regions available) is set via the operator set_system('no_object_result',<Result>)set_system("no_object_result",<Result>)SetSystem("no_object_result",<Result>)SetSystem("no_object_result",<Result>)set_system("no_object_result",<Result>). The behavior in case of empty region (the region is the empty set) is set via the operator set_system('empty_region_result',<Result>)set_system("empty_region_result",<Result>)SetSystem("empty_region_result",<Result>)SetSystem("empty_region_result",<Result>)set_system("empty_region_result",<Result>). If necessary an exception is raised.

Possible Predecessors

sobel_ampsobel_ampSobelAmpSobelAmpsobel_amp, thresholdthresholdThresholdThresholdthreshold, skeletonskeletonSkeletonSkeletonskeleton, edges_imageedges_imageEdgesImageEdgesImageedges_image, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1gen_rectangle1, gen_circlegen_circleGenCircleGenCirclegen_circle

Possible Successors

approx_chainapprox_chainApproxChainApproxChainapprox_chain, approx_chain_simpleapprox_chain_simpleApproxChainSimpleApproxChainSimpleapprox_chain_simple

See also

copy_objcopy_objCopyObjCopyObjcopy_obj, get_region_contourget_region_contourGetRegionContourGetRegionContourget_region_contour, get_region_polygonget_region_polygonGetRegionPolygonGetRegionPolygonget_region_polygon

Module

Foundation