วิธีเชื่อมต่อรูปร่างด้วยคอนเนคเตอร์ใน Python

วิธีเชื่อมต่อรูปร่างด้วยคอนเนคเตอร์ใน Python

คอนเนคเตอร์ใน Aspose.Slides FOSS คือรูปทรงเส้นที่เชื่อมต่อกับ จุดเชื่อมต่อ บนรูปทรงอื่น เมื่อคุณย้ายรูปทรงที่เชื่อมต่อ คอนเนคเตอร์ปลายจุดจะเคลื่อนที่ตามมัน ประเภทคอนเนคเตอร์ที่พบบ่อยที่สุดคือ BENT_CONNECTOR3 ซึ่งจะวางเส้นรอบอุปสรรคด้วยการโค้งศอกเดียว


ข้อกำหนดเบื้องต้น

pip install aspose-slides-foss

ดัชนีไซต์การเชื่อมต่อ

แต่ละรูปร่างมีจุดเชื่อมต่อสี่จุดที่มีหมายเลข:

ดัชนีตำแหน่ง
0บนศูนย์กลาง
1ซ้ายศูนย์กลาง
2ล่างศูนย์กลาง
3ขวาศูนย์กลาง

เชื่อมต่อสองรูปทรง

from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]

    # Add two rectangles
    box1 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 200, 200, 100)
    box2 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 450, 200, 200, 100)

    box1.add_text_frame("Start")
    box2.add_text_frame("End")

    # Add a bent connector (initial bounds are overwritten by the connection)
    conn = slide.shapes.add_connector(ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10)

    # Connect right side of box1 (site 3) to left side of box2 (site 1)
    conn.start_shape_connected_to = box1
    conn.start_shape_connection_site_index = 3
    conn.end_shape_connected_to = box2
    conn.end_shape_connection_site_index = 1

    prs.save("connected.pptx", SaveFormat.PPTX)

ขอบเขตของตัวแทน (0, 0, 10, 10) ที่ส่งไปยัง add_connector จะถูกละเลยเมื่อกำหนดจุดเชื่อมต่อแล้ว; PowerPoint จะเปลี่ยนเส้นเชื่อมไปยังรูปร่างที่แนบไว้.


ประเภทของคอนเนคเตอร์

from aspose.slides_foss import ShapeType

# Straight line
ShapeType.STRAIGHT_CONNECTOR1

# Single elbow (L-shape)
ShapeType.BENT_CONNECTOR2

# Double elbow (Z-shape): most common
ShapeType.BENT_CONNECTOR3

# Curved connector
ShapeType.CURVED_CONNECTOR3

กำหนดสไตล์เส้นเชื่อมต่อ

from aspose.slides_foss import ShapeType, LineDashStyle
from aspose.slides_foss.drawing import Color
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]

    box1 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 150, 180, 80)
    box2 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 500, 300, 180, 80)

    conn = slide.shapes.add_connector(ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10)
    conn.start_shape_connected_to = box1
    conn.start_shape_connection_site_index = 2   # bottom of box1
    conn.end_shape_connected_to = box2
    conn.end_shape_connection_site_index = 0     # top of box2

    # Style: dashed blue line, 2 pt width
    lf = conn.line_format
    lf.width = 2.0
    lf.fill_format.solid_fill_color.color = Color.blue
    lf.dash_style = LineDashStyle.DASH

    prs.save("styled-connector.pptx", SaveFormat.PPTX)

แผนภาพไหลที่มีตัวเชื่อมหลายตัว

from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]

    # Three-step flowchart
    step1 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 350, 50, 200, 70)
    step2 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 350, 220, 200, 70)
    step3 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 350, 390, 200, 70)

    step1.add_text_frame("Step 1")
    step2.add_text_frame("Step 2")
    step3.add_text_frame("Step 3")

    def connect_vertical(shapes, top_shape, bottom_shape):
        conn = shapes.add_connector(ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10)
        conn.start_shape_connected_to = top_shape
        conn.start_shape_connection_site_index = 2   # bottom
        conn.end_shape_connected_to = bottom_shape
        conn.end_shape_connection_site_index = 0     # top
        return conn

    connect_vertical(slide.shapes, step1, step2)
    connect_vertical(slide.shapes, step2, step3)

    prs.save("flowchart.pptx", SaveFormat.PPTX)

อ่านคุณสมบัติตัวเชื่อมต่อ

from aspose.slides_foss import Connector
import aspose.slides_foss as slides

with slides.Presentation("connected.pptx") as prs:
    for shape in prs.slides[0].shapes:
        if isinstance(shape, Connector):
            start = shape.start_shape_connected_to
            end = shape.end_shape_connected_to
            print(f"Connector: {getattr(start, 'name', '?')}{getattr(end, 'name', '?')}")

ดูเพิ่มเติม

 ภาษาไทย