graphics/GraphicCommons.py
author lbessard
Tue, 12 Aug 2008 18:16:09 +0200
changeset 231 fc2d6cbb8b39
parent 222 8ce5c2635976
child 237 097e8ee006cb
permissions -rw-r--r--
Adding support for highlighing compiling errors from matiec
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     1
#!/usr/bin/env python
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     2
# -*- coding: utf-8 -*-
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     3
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     4
#This file is part of PLCOpenEditor, a library implementing an IEC 61131-3 editor
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     5
#based on the plcopen standard. 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     6
#
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
     7
#Copyright (C) 2007: Edouard TISSERANT and Laurent BESSARD
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     8
#
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
     9
#See COPYING file for copyrights details.
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    10
#
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    11
#This library is free software; you can redistribute it and/or
5
f8652b073e84 GPL->LGPL
etisserant
parents: 3
diff changeset
    12
#modify it under the terms of the GNU General Public
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    13
#License as published by the Free Software Foundation; either
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    14
#version 2.1 of the License, or (at your option) any later version.
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    15
#
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    16
#This library is distributed in the hope that it will be useful,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    17
#but WITHOUT ANY WARRANTY; without even the implied warranty of
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    18
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    19
#General Public License for more details.
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    20
#
5
f8652b073e84 GPL->LGPL
etisserant
parents: 3
diff changeset
    21
#You should have received a copy of the GNU General Public
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    22
#License along with this library; if not, write to the Free Software
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    23
#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    24
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    25
import wx
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    26
from math import *
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    27
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    28
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    29
#                               Common constants
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    30
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    31
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    32
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    33
Definition of constants for dimensions of graphic elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    34
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    35
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    36
# FBD and SFC constants
28
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    37
MIN_MOVE = 5                            # Minimum move before starting a element dragging
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    38
CONNECTOR_SIZE = 8                      # Size of connectors
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    39
BLOCK_LINE_SIZE = 20                    # Minimum size of each line in a block
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    40
HANDLE_SIZE = 6                         # Size of the squares for handles
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    41
ANCHOR_DISTANCE = 5                     # Distance where wire is automativally attached to a connector
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    42
POINT_RADIUS = 2                        # Radius of the point of wire ends
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    43
MIN_SEGMENT_SIZE = 2                    # Minimum size of the endling segments of a wire
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    44
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    45
# LD constants
28
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    46
LD_LINE_SIZE = 40                       # Distance between two lines in a ladder rung
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    47
LD_ELEMENT_SIZE = (21, 15)              # Size (width, height) of a ladder element (contact or coil)
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    48
LD_WIRE_SIZE = 30                       # Size of a wire between two contact
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    49
LD_WIRECOIL_SIZE = 70                   # Size of a wire between a coil and a contact
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
    50
LD_POWERRAIL_WIDTH = 3                  # Width of a Powerrail
28
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    51
LD_OFFSET = (10, 10)                    # Distance (x, y) between each comment and rung of the ladder
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    52
LD_COMMENT_DEFAULTSIZE = (600, 40)      # Size (width, height) of a comment box
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    53
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    54
# SFC constants
28
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    55
SFC_STEP_DEFAULT_SIZE = (40, 30)        # Default size of a SFC step
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    56
SFC_TRANSITION_SIZE = (20, 2)           # Size of a SFC transition
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    57
SFC_DEFAULT_SEQUENCE_INTERVAL = 40      # Default size of the interval between two divergence branches
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    58
SFC_SIMULTANEOUS_SEQUENCE_EXTRA = 20    # Size of extra lines for simultaneous divergence and convergence
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    59
SFC_JUMP_SIZE = (12, 13)                # Size of a SFC jump to step
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    60
SFC_WIRE_MIN_SIZE = 25                  # Size of a wire between two elements
fc23e1f415d8 Adding support for concurrent overriden standard function
lbessard
parents: 27
diff changeset
    61
SFC_ACTION_MIN_SIZE = (100, 30)         # Minimum size of an action block line
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    62
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    63
# Type definition constants for graphic elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    64
[INPUT, OUTPUT, INOUT] = range(3)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    65
[CONNECTOR, CONTINUATION] = range(2)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    66
[LEFTRAIL, RIGHTRAIL] = range(2)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    67
[CONTACT_NORMAL, CONTACT_REVERSE, CONTACT_RISING, CONTACT_FALLING] = range(4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    68
[COIL_NORMAL, COIL_REVERSE, COIL_SET, COIL_RESET] = range(4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    69
[SELECTION_DIVERGENCE, SELECTION_CONVERGENCE, SIMULTANEOUS_DIVERGENCE, SIMULTANEOUS_CONVERGENCE] = range(4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    70
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    71
# Constants for defining the type of dragging that has been selected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    72
[HANDLE_MOVE, HANDLE_RESIZE, HANDLE_POINT, HANDLE_SEGMENT, HANDLE_CONNECTOR] = range(5)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    73
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    74
# List of value for resize handle that are valid
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    75
VALID_HANDLES = [(1,1), (1,2), (1,3), (2,3), (3,3), (3,2), (3,1), (2,1)]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    76
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    77
# Contants for defining the direction of a connector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    78
[EAST, NORTH, WEST, SOUTH] = [(1,0), (0,-1), (-1,0), (0,1)]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    79
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
    80
# Contants for defining which mode is selected for each view 
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    81
[MODE_SELECTION, MODE_BLOCK, MODE_VARIABLE, MODE_CONNECTION, MODE_COMMENT, 
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    82
 MODE_COIL, MODE_CONTACT, MODE_POWERRAIL, MODE_INITIALSTEP, MODE_STEP, 
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    83
 MODE_TRANSITION, MODE_DIVERGENCE, MODE_JUMP, MODE_ACTION] = range(14)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    84
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    85
# Contants for defining alignment types for graphic group 
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
    86
[ALIGN_LEFT, ALIGN_CENTER, ALIGN_RIGHT, ALIGN_TOP, ALIGN_MIDDLE, ALIGN_BOTTOM] = range(6)
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
    87
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
    88
# Contants for defining which drawing mode is selected for app
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
    89
[FREEDRAWING_MODE, DRIVENDRAWING_MODE] = [1, 2]
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
    90
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
    91
# Color for Highlighting
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
    92
HIGHLIGHTCOLOR = wx.CYAN
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
    93
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    94
CURSORS = None
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    95
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    96
def ResetCursors():
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    97
    global CURSORS
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
    98
    if CURSORS == None:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
    99
        CURSORS = [wx.NullCursor, 
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   100
                   wx.StockCursor(wx.CURSOR_HAND),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   101
                   wx.StockCursor(wx.CURSOR_SIZENWSE),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   102
                   wx.StockCursor(wx.CURSOR_SIZENESW),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   103
                   wx.StockCursor(wx.CURSOR_SIZEWE),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   104
                   wx.StockCursor(wx.CURSOR_SIZENS)]
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   105
           
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   106
HANDLE_CURSORS = {
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   107
    (1, 1) : 2,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   108
    (3, 3) : 2,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   109
    (1, 3) : 3,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   110
    (3, 1) : 3,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   111
    (1, 2) : 4,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   112
    (3, 2) : 4,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   113
    (2, 1) : 5,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   114
    (2, 3) : 5
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   115
}
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   116
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   117
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   118
Basic vector operations for calculate wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   119
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   120
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   121
# Calculate the scalar product of two vectors
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   122
def product(v1, v2):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   123
    return v1[0] * v2[0] + v1[1] * v2[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   124
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   125
# Create a vector from two points and define if vector must be normal
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   126
def vector(p1, p2, normal = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   127
    vector = (p2.x - p1.x, p2.y - p1.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   128
    if normal:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   129
        return normalize(vector)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   130
    return vector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   131
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   132
# Calculate the norm of a given vector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   133
def norm(v):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   134
    return sqrt(v[0] * v[0] + v[1] * v[1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   135
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   136
# Normalize a given vector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   137
def normalize(v):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   138
    v_norm = norm(v)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   139
    # Verifie if it is not a null vector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   140
    if v_norm > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   141
        return (v[0] / v_norm, v[1] / v_norm)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   142
    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   143
        return v
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   144
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   145
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   146
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   147
Function that calculates the nearest point of the grid defined by scaling for the given point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   148
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   149
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   150
def GetScaledEventPosition(event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   151
    pos = event.GetLogicalPosition(dc)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   152
    if scaling:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   153
        pos.x = round(float(pos.x) / float(scaling[0])) * scaling[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   154
        pos.y = round(float(pos.y) / float(scaling[1])) * scaling[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   155
    return pos
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   156
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   157
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   158
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   159
Function that choose a direction during the wire points generation
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   160
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   161
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   162
def DirectionChoice(v_base, v_target, dir_target):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   163
    dir_product = product(v_base, v_target)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   164
    if dir_product < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   165
        return (-v_base[0], -v_base[1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   166
    elif dir_product == 0 and product(v_base, dir_target) != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   167
        return dir_target
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   168
    return v_base
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   169
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   170
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   171
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   172
#                               Viewer Rubberband
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   173
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   174
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   175
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   176
Class that implements a rubberband
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   177
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   178
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   179
class RubberBand:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   180
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   181
    # Create a rubberband by indicated on which window it must be drawn
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   182
    def __init__(self, drawingSurface):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   183
        self.drawingSurface = drawingSurface
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   184
        self.Reset()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   185
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   186
    # Method that initializes the internal attributes of the rubberband
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   187
    def Reset(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   188
        self.startPoint = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   189
        self.currentBox = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   190
        self.lastBox = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   191
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   192
    # Method that return if a box is currently edited
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   193
    def IsShown(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   194
        return self.currentBox != None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   195
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   196
    # Method that returns the currently edited box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   197
    def GetCurrentExtent(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   198
        return self.currentBox
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   199
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   200
    # Method called when a new box starts to be edited
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   201
    def OnLeftDown(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   202
        pos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   203
        # Save the point for calculate the box position and size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   204
        self.startPoint = pos
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   205
        self.currentBox = wx.Rect(pos.x, pos.y, 0, 0)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   206
        self.drawingSurface.SetCursor(wx.StockCursor(wx.CURSOR_CROSS))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   207
        self.Redraw()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   208
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   209
    # Method called when dragging with a box edited
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   210
    def OnMotion(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   211
        pos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   212
        # Save the last position and size of the box for erasing it
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   213
        self.lastBox = wx.Rect(self.currentBox.x, self.currentBox.y, self.currentBox.width,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   214
            self.currentBox.height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   215
        # Calculate new position and size of the box 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   216
        if pos.x >= self.startPoint.x:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   217
            self.currentBox.x = self.startPoint.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   218
            self.currentBox.width = pos.x - self.startPoint.x + 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   219
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   220
            self.currentBox.x = pos.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   221
            self.currentBox.width = self.startPoint.x - pos.x + 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   222
        if pos.y >= self.startPoint.y:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   223
            self.currentBox.y = self.startPoint.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   224
            self.currentBox.height = pos.y - self.startPoint.y + 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   225
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   226
            self.currentBox.y = pos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   227
            self.currentBox.height = self.startPoint.y - pos.y + 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   228
        self.Redraw()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   229
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   230
    # Method called when dragging is stopped
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   231
    def OnLeftUp(self, event, dc, scaling):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   232
        self.drawingSurface.SetCursor(wx.NullCursor)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   233
        self.lastBox = self.currentBox
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   234
        self.currentBox = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   235
        self.Redraw()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   236
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   237
    # Method that erase the last box and draw the new box
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   238
    def Redraw(self, dc = None):
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   239
        if not dc:
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   240
            dc = self.drawingSurface.GetLogicalDC()
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   241
        dc.SetPen(wx.Pen(wx.WHITE, 1, wx.DOT))
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   242
        dc.SetBrush(wx.TRANSPARENT_BRUSH)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   243
        dc.SetLogicalFunction(wx.XOR)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   244
        if self.lastBox:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   245
            # Erase last box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   246
            dc.DrawRectangle(self.lastBox.x, self.lastBox.y, self.lastBox.width,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   247
                self.lastBox.height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   248
        if self.currentBox:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   249
            # Draw current box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   250
            dc.DrawRectangle(self.currentBox.x, self.currentBox.y, self.currentBox.width,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   251
                self.currentBox.height)
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   252
    
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   253
    # Erase last box
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   254
    def Erase(self, dc = None):
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   255
        if not dc:
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   256
            dc = self.drawingSurface.GetLogicalDC()
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   257
        dc.SetPen(wx.Pen(wx.WHITE, 1, wx.DOT))
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   258
        dc.SetBrush(wx.TRANSPARENT_BRUSH)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   259
        dc.SetLogicalFunction(wx.XOR)
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   260
        if self.lastBox:
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   261
            dc.DrawRectangle(self.lastBox.x, self.lastBox.y, self.lastBox.width,
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   262
                self.lastBox.height)
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   263
    
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   264
    # Draw current box
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   265
    def Draw(self, dc = None):
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   266
        if not dc:
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
   267
            dc = self.drawingSurface.GetLogicalDC()
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   268
        dc.SetPen(wx.Pen(wx.WHITE, 1, wx.DOT))
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   269
        dc.SetBrush(wx.TRANSPARENT_BRUSH)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   270
        dc.SetLogicalFunction(wx.XOR)
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   271
        if self.currentBox:
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   272
            # Draw current box
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   273
            dc.DrawRectangle(self.currentBox.x, self.currentBox.y, self.currentBox.width,
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   274
                self.currentBox.height)
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   275
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   276
#-------------------------------------------------------------------------------
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   277
#                    Helper for highlighting error in drawn text
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   278
#-------------------------------------------------------------------------------
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   279
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   280
def HighlightErrorZone(dc, x, y, width, height):
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   281
    dc.SetPen(wx.TRANSPARENT_PEN)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   282
    dc.SetLogicalFunction(wx.AND)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   283
    dc.SetBrush(wx.Brush(wx.Colour(0,255,0)))
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   284
    dc.DrawRectangle(x, y, width, height)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   285
    dc.SetLogicalFunction(wx.XOR)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   286
    dc.SetBrush(wx.Brush(wx.Colour(255,0,0)))
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   287
    dc.DrawRectangle(x, y, width, height)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   288
    dc.SetLogicalFunction(wx.COPY)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   289
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   290
#-------------------------------------------------------------------------------
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   291
#                           Graphic element base class
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   292
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   293
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   294
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   295
Class that implements a generic graphic element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   296
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   297
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   298
class Graphic_Element:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   299
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   300
    # Create a new graphic element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   301
    def __init__(self, parent, id = None):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   302
        self.Parent = parent
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   303
        self.Id = id
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   304
        self.oldPos = None
180
3b0d3ea35ee5 Fixed bad handle initialisation, causing exception on rightup event in some cases.
etisserant
parents: 175
diff changeset
   305
        self.Handle = (None,None)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   306
        self.Dragging = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   307
        self.Selected = False
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   308
        self.Highlighted = False
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   309
        self.Pos = wx.Point(0, 0)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   310
        self.Size = wx.Size(0, 0)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   311
        self.BoundingBox = wx.Rect(0, 0, 0, 0)
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   312
        self.CurrentCursor = 0
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   313
        ResetCursors()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   314
    
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   315
    def IsOfType(self, type, reference):
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   316
        return self.Parent.IsOfType(type, reference)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   317
    
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   318
    def IsEndType(self, type):
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   319
        return self.Parent.IsEndType(type)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   320
        
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   321
    def GetDragging(self):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   322
        return self.Dragging
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   323
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   324
    # Make a clone of this element
162
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
   325
    def Clone(self, parent):
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
   326
        return Graphic_Element(parent, self.Id)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   327
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   328
    # Changes the block position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   329
    def SetPosition(self, x, y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   330
        self.Pos.x = x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   331
        self.Pos.y = y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   332
        self.RefreshConnected()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   333
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   334
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   335
    # Returns the block position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   336
    def GetPosition(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   337
        return self.Pos.x, self.Pos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   338
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   339
    # Changes the element size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   340
    def SetSize(self, width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   341
        self.Size.SetWidth(width)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   342
        self.Size.SetHeight(height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   343
        self.RefreshConnectors()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   344
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   345
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   346
    # Returns the element size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   347
    def GetSize(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   348
        return self.Size.GetWidth(), self.Size.GetHeight()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   349
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   350
    # Refresh the element Bounding Box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   351
    def RefreshBoundingBox(self):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   352
        self.BoundingBox = wx.Rect(self.Pos.x, self.Pos.y, self.Size[0], self.Size[1])
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   353
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   354
    # Refresh the element connectors position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   355
    def RefreshConnectors(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   356
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   357
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   358
    # Refresh the position of wires connected to element inputs and outputs
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   359
    def RefreshConnected(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   360
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   361
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   362
    # Change the parent
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   363
    def SetParent(self, parent):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   364
        self.Parent = parent
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   365
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   366
    # Override this method for defining the method to call for deleting this element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   367
    def Delete(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   368
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   369
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   370
    # Returns the Id
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   371
    def GetId(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   372
        return self.Id
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   373
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   374
    # Returns if the point given is in the bounding box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   375
    def HitTest(self, pt):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   376
        rect = self.BoundingBox
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   377
        return rect.InsideXY(pt.x, pt.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   378
    
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   379
    # Returns if the point given is in the bounding box
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   380
    def IsInSelection(self, rect):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   381
        return rect.InsideXY(self.BoundingBox.x, self.BoundingBox.y) and rect.InsideXY(self.BoundingBox.x + self.BoundingBox.width, self.BoundingBox.y + self.BoundingBox.height)
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   382
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   383
    # Override this method for refreshing the bounding box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   384
    def RefreshBoundingBox(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   385
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   386
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   387
    # Returns the bounding box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   388
    def GetBoundingBox(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   389
        return self.BoundingBox
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   390
    
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   391
    # Returns the RedrawRect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   392
    def GetRedrawRect(self, movex = 0, movey = 0):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   393
        rect = wx.Rect()
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   394
        rect.x = self.BoundingBox.x - HANDLE_SIZE - 2 - abs(movex)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   395
        rect.y = self.BoundingBox.y - HANDLE_SIZE - 2 - abs(movey)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   396
        rect.width = self.BoundingBox.width + 2 * (HANDLE_SIZE + abs(movex)) + 4
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   397
        rect.height = self.BoundingBox.height + 2 * (HANDLE_SIZE + abs(movey)) + 4
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   398
        return rect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   399
    
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   400
    def Refresh(self, rect = None):
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   401
        if rect is not None:
155
b695f7459ef6 Removing flickering on Windows
lbessard
parents: 145
diff changeset
   402
            self.Parent.RefreshRect(self.Parent.GetScrolledRect(rect), False)
b695f7459ef6 Removing flickering on Windows
lbessard
parents: 145
diff changeset
   403
        else:
b695f7459ef6 Removing flickering on Windows
lbessard
parents: 145
diff changeset
   404
            self.Parent.RefreshRect(self.Parent.GetScrolledRect(self.GetRedrawRect()), False)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   405
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   406
    # Change the variable that indicates if this element is selected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   407
    def SetSelected(self, selected):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   408
        self.Selected = selected
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   409
        self.Refresh()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   410
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   411
    # Change the variable that indicates if this element is highlighted
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   412
    def SetHighlighted(self, highlighted):
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   413
        self.Highlighted = highlighted
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   414
        self.Refresh()
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   415
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   416
    # Test if the point is on a handle of this element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   417
    def TestHandle(self, pt):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   418
        extern_rect = wx.Rect(self.BoundingBox.x - HANDLE_SIZE - 2, self.BoundingBox.y - HANDLE_SIZE - 2, 
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   419
            self.BoundingBox.width + 2 * HANDLE_SIZE + 4, self.BoundingBox.height + 2 * HANDLE_SIZE + 4)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   420
        intern_rect = wx.Rect(self.BoundingBox.x - 2, self.BoundingBox.y - 2, 
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   421
            self.BoundingBox.width + 4, self.BoundingBox.height + 4)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   422
        # Verify that this element is selected
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   423
        if self.Selected and extern_rect.InsideXY(pt.x, pt.y) and not intern_rect.InsideXY(pt.x, pt.y):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   424
            # Find if point is on a handle horizontally
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   425
            if self.BoundingBox.x - HANDLE_SIZE - 2 <= pt.x < self.BoundingBox.x - 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   426
                handle_x = 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   427
            elif self.BoundingBox.x + (self.BoundingBox.width - HANDLE_SIZE) / 2 <= pt.x < self.BoundingBox.x + (self.BoundingBox.width + HANDLE_SIZE) / 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   428
                handle_x = 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   429
            elif self.BoundingBox.x + self.BoundingBox.width + 2 <= pt.x < self.BoundingBox.x + self.BoundingBox.width + HANDLE_SIZE + 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   430
                handle_x = 3
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   431
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   432
                handle_x = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   433
            # Find if point is on a handle vertically
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   434
            if self.BoundingBox.y - HANDLE_SIZE - 2 <= pt.y < self.BoundingBox.y - 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   435
                handle_y = 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   436
            elif self.BoundingBox.y + (self.BoundingBox.height - HANDLE_SIZE) / 2 <= pt.y < self.BoundingBox.y + (self.BoundingBox.height + HANDLE_SIZE) / 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   437
                handle_y = 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   438
            elif self.BoundingBox.y + self.BoundingBox.height - 2 <= pt.y < self.BoundingBox.y + self.BoundingBox.height + HANDLE_SIZE + 2:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   439
                handle_y = 3
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   440
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   441
                handle_y = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   442
            # Verify that the result is valid
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   443
            if (handle_x, handle_y) in VALID_HANDLES:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   444
                return handle_x, handle_y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   445
        return 0, 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   446
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   447
    # Method called when a LeftDown event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   448
    def OnLeftDown(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   449
        pos = event.GetLogicalPosition(dc)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   450
        # Test if an handle have been clicked
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   451
        handle = self.TestHandle(pos)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   452
        # Find which type of handle have been clicked,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   453
        # Save a resize event and change the cursor
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   454
        cursor = HANDLE_CURSORS.get(handle, 1)
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   455
        if cursor != self.CurrentCursor:
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   456
            self.Parent.SetCursor(CURSORS[cursor])
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   457
            self.CurrentCursor = cursor
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   458
        if cursor > 1:
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   459
            self.Handle = (HANDLE_RESIZE, handle)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   460
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   461
            self.Handle = (HANDLE_MOVE, None)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   462
            self.SetSelected(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   463
        # Initializes the last position
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   464
        self.oldPos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   465
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   466
    # Method called when a LeftUp event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   467
    def OnLeftUp(self, event, dc, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   468
        # If a dragging have been initiated
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   469
        if self.Dragging and self.oldPos:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   470
            self.RefreshModel()
56
7187e1c00975 Adding support for Undo/Redo and Unsaved File On Close detection
lbessard
parents: 42
diff changeset
   471
            self.Parent.RefreshBuffer()
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   472
        if self.CurrentCursor != 0:
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   473
            self.Parent.SetCursor(CURSORS[0])
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   474
            self.CurrentCursor = 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   475
        self.SetSelected(True)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   476
        self.oldPos = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   477
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   478
    # Method called when a RightDown event have been generated
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   479
    def OnRightDown(self, event, dc, scaling):
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   480
        pass
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   481
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   482
    # Method called when a RightUp event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   483
    def OnRightUp(self, event, dc, scaling):
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   484
        if self.Dragging and self.oldPos:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   485
            self.RefreshModel()
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   486
            self.Parent.RefreshBuffer()
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   487
        if self.CurrentCursor != 0:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   488
            self.Parent.SetCursor(CURSORS[0])
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   489
            self.CurrentCursor = 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   490
        self.SetSelected(True)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   491
        self.oldPos = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   492
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   493
    # Method called when a LeftDClick event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   494
    def OnLeftDClick(self, event, dc, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   495
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   496
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   497
    # Method called when a Motion event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   498
    def OnMotion(self, event, dc, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   499
        # If the cursor is dragging and the element have been clicked
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   500
        if event.Dragging() and self.oldPos:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   501
            # Calculate the movement of cursor
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   502
            pos = event.GetLogicalPosition(dc)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   503
            movex = pos.x - self.oldPos.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   504
            movey = pos.y - self.oldPos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   505
            # If movement is greater than MIN_MOVE then a dragging is initiated
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   506
            if not self.Dragging and (abs(movex) > MIN_MOVE or abs(movey) > MIN_MOVE):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   507
                self.Dragging = True
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   508
            # If a dragging have been initiated, refreshes the element state
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   509
            if self.Dragging:
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   510
                dragx, dragy = self.ProcessDragging(movex, movey, event.ShiftDown(), scaling)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   511
                self.oldPos.x += dragx
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   512
                self.oldPos.y += dragy
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   513
                return dragx, dragy
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   514
            return movex, movey
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   515
        # If cursor just pass over the element, changes the cursor if it is on a handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   516
        else:
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   517
            pos = event.GetLogicalPosition(dc)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   518
            handle = self.TestHandle(pos)
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   519
            # Find which type of handle have been clicked,
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   520
            # Save a resize event and change the cursor
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   521
            cursor = HANDLE_CURSORS.get(handle, 0)
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   522
            if cursor != self.CurrentCursor:
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   523
                self.Parent.SetCursor(CURSORS[cursor])
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   524
                self.CurrentCursor = cursor
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   525
            return 0, 0
58
39cd981ff242 Changing file headers
lbessard
parents: 56
diff changeset
   526
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   527
    # Moves the element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   528
    def Move(self, dx, dy, exclude = []):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   529
        self.Pos.x += dx
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   530
        self.Pos.y += dy
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   531
        self.RefreshConnected(exclude)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   532
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   533
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   534
    # Resizes the element from position and size given
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   535
    def Resize(self, x, y, width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   536
        self.Move(x, y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   537
        self.SetSize(width, height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   538
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   539
    # Refreshes the element state according to move defined and handle selected
175
cc78572dfbbc Some minor SFC/LD drawing enhancements
etisserant
parents: 165
diff changeset
   540
    def ProcessDragging(self, movex, movey, centered, scaling, width_fac = 1, height_fac = 1):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   541
        handle_type, handle = self.Handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   542
        # If it is a resize handle, calculate the values from resizing
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   543
        if handle_type == HANDLE_RESIZE:
175
cc78572dfbbc Some minor SFC/LD drawing enhancements
etisserant
parents: 165
diff changeset
   544
            if scaling is not None:
cc78572dfbbc Some minor SFC/LD drawing enhancements
etisserant
parents: 165
diff changeset
   545
                scaling = (scaling[0] * width_fac, scaling[1] * height_fac)
110
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   546
            x = y = start_x = start_y = 0
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   547
            width, height = start_width, start_height = self.GetSize()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   548
            if handle[0] == 1:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   549
                movex = max(-self.BoundingBox.x, movex)
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   550
                if scaling is not None:
180
3b0d3ea35ee5 Fixed bad handle initialisation, causing exception on rightup event in some cases.
etisserant
parents: 175
diff changeset
   551
                    movex = -(round(float(width - movex) / float(scaling[0])) * scaling[0] - width)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   552
                x = movex
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   553
                if centered:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   554
                    width -= 2 * movex
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   555
                else:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   556
                    width -= movex
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   557
            elif handle[0] == 3:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   558
                if scaling is not None:
180
3b0d3ea35ee5 Fixed bad handle initialisation, causing exception on rightup event in some cases.
etisserant
parents: 175
diff changeset
   559
                    movex = round(float(width + movex) / float(scaling[0])) * scaling[0] - width
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   560
                if centered:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   561
                    x = -movex
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   562
                    width += 2 * movex
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   563
                else:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   564
                    width += movex
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   565
            if handle[1] == 1:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   566
                movey = max(-self.BoundingBox.y, movey)
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   567
                if scaling is not None:
180
3b0d3ea35ee5 Fixed bad handle initialisation, causing exception on rightup event in some cases.
etisserant
parents: 175
diff changeset
   568
                    movey = -(round(float(height - movey) / float(scaling[1])) * scaling[1] - height)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   569
                y = movey
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   570
                if centered:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   571
                    height -= 2 * movey
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   572
                else:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   573
                    height -= movey
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   574
            elif handle[1] == 3:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   575
                if scaling is not None:
180
3b0d3ea35ee5 Fixed bad handle initialisation, causing exception on rightup event in some cases.
etisserant
parents: 175
diff changeset
   576
                    movey = round(float(height + movey) / float(scaling[1])) * scaling[1] - height
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   577
                if centered:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   578
                    y = -movey
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   579
                    height += 2 * movey
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   580
                else:
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
   581
                    height += movey
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   582
            # Verify that new size is not lesser than minimum
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   583
            min_width, min_height = self.GetMinSize()
110
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   584
            if handle[0] != 2 and (width >= min_width or width > self.Size[0]):
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   585
                start_x = x
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   586
                start_width = width
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   587
            else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   588
                movex = 0
110
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   589
            if handle[1] != 2 and (height >= min_height or height > self.Size[1]):
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   590
                start_y = y
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   591
                start_height = height
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   592
            else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   593
                movey = 0
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   594
            if movex != 0 or movey != 0:
110
29b6b70e1721 Bug that makes element resizing acting strongly fixed
lbessard
parents: 108
diff changeset
   595
                self.Resize(start_x, start_y, start_width, start_height)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   596
            return movex, movey
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   597
        # If it is a move handle, Move this element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   598
        elif handle_type == HANDLE_MOVE:
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   599
            movex = max(-self.BoundingBox.x, movex)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   600
            movey = max(-self.BoundingBox.y, movey)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   601
            if scaling is not None:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   602
                movex = round(float(self.Pos.x + movex) / float(scaling[0])) * scaling[0] - self.Pos.x
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
   603
                movey = round(float(self.Pos.y + movey) / float(scaling[1])) * scaling[1] - self.Pos.y
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   604
            self.Move(movex, movey)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   605
            return movex, movey
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   606
        return 0, 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   607
    
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   608
    def AddError(self, infos, start, end):
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   609
        pass
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   610
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   611
    # Override this method for defining the method to call for refreshing the model of this element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   612
    def RefreshModel(self, move=True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   613
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   614
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   615
    # Draws the highlightment of this element if it is highlighted (can be overwritten)
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   616
    def DrawHighlightment(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   617
        dc.SetPen(wx.Pen(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   618
        dc.SetBrush(wx.Brush(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   619
        dc.SetLogicalFunction(wx.AND)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   620
        dc.DrawRectangle(self.Pos.x - 2, self.Pos.y - 2, self.Size.width + 5, self.Size.height + 5)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   621
        dc.SetLogicalFunction(wx.COPY)
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   622
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   623
    # Draws the handles of this element if it is selected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   624
    def Draw(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   625
        if self.Highlighted:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   626
            self.DrawHighlightment(dc)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   627
        if self.Selected:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   628
            dc.SetPen(wx.BLACK_PEN)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   629
            dc.SetBrush(wx.BLACK_BRUSH)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   630
            dc.DrawRectangle(self.BoundingBox.x - HANDLE_SIZE - 2, self.BoundingBox.y - HANDLE_SIZE - 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   631
            dc.DrawRectangle(self.BoundingBox.x + (self.BoundingBox.width - HANDLE_SIZE) / 2,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   632
                self.BoundingBox.y - HANDLE_SIZE - 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   633
            dc.DrawRectangle(self.BoundingBox.x + self.BoundingBox.width + 2, 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   634
                self.BoundingBox.y - HANDLE_SIZE - 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   635
            dc.DrawRectangle(self.BoundingBox.x + self.BoundingBox.width + 2, 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   636
                self.BoundingBox.y + (self.BoundingBox.height - HANDLE_SIZE) / 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   637
            dc.DrawRectangle(self.BoundingBox.x + self.BoundingBox.width + 2, 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   638
                self.BoundingBox.y + self.BoundingBox.height + 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   639
            dc.DrawRectangle(self.BoundingBox.x + (self.BoundingBox.width - HANDLE_SIZE) / 2, 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   640
                self.BoundingBox.y + self.BoundingBox.height + 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   641
            dc.DrawRectangle(self.BoundingBox.x - HANDLE_SIZE - 2, self.BoundingBox.y + self.BoundingBox.height + 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   642
            dc.DrawRectangle(self.BoundingBox.x - HANDLE_SIZE - 2, self.BoundingBox.y + (self.BoundingBox.height - HANDLE_SIZE) / 2, HANDLE_SIZE, HANDLE_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   643
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   644
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   645
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   646
#                           Group of graphic elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   647
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   648
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   649
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   650
Class that implements a group of graphic elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   651
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   652
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   653
class Graphic_Group(Graphic_Element):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   654
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   655
    # Create a new group of graphic elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   656
    def __init__(self, parent):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   657
        Graphic_Element.__init__(self, parent)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   658
        self.Elements = []
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   659
        self.RefreshWireExclusion()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   660
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   661
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   662
    # Destructor
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   663
    def __del__(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   664
        self.Elements = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   665
    
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   666
    # Refresh the list of wire excluded
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   667
    def RefreshWireExclusion(self):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   668
        self.WireExcluded = []
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   669
        for element in self.Elements:
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   670
            if isinstance(element, Wire):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   671
                startblock = element.StartConnected.GetParentBlock()
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   672
                endblock = element.EndConnected.GetParentBlock()
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   673
                if startblock in self.Elements and endblock in self.Elements:
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   674
                    self.WireExcluded.append(element)
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   675
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   676
    # Make a clone of this group
162
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
   677
    def Clone(self, parent):
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
   678
        clone = Graphic_Group(parent)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   679
        elements = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   680
        # Makes a clone of all the elements in this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   681
        for element in self.Elements:
162
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
   682
            elements.append(element.Clone(parent))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   683
        clone.SetElements(elements)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   684
        return clone
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   685
    
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   686
    # Returns the RedrawRect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   687
    def GetRedrawRect(self, movex = 0, movey = 0):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   688
        rect = None
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   689
        for element in self.Elements:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   690
            if rect is None:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   691
                rect = element.GetRedrawRect(movex, movey)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   692
            else:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   693
                rect = rect.Union(element.GetRedrawRect(movex, movey))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   694
        return rect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   695
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   696
    # Clean this group of elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   697
    def Clean(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   698
        # Clean all the elements of the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   699
        for element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   700
            element.Clean()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   701
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   702
    # Delete this group of elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   703
    def Delete(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   704
        # Delete all the elements of the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   705
        for element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   706
            element.Delete()
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   707
        self.WireExcluded = []
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   708
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   709
    # Returns if the point given is in the bounding box of one of the elements of this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   710
    def HitTest(self, pt):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   711
        result = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   712
        for element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   713
            result |= element.HitTest(pt)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   714
        return result
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   715
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   716
    # Returns if the element given is in this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   717
    def IsElementIn(self, element):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   718
        return element in self.Elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   719
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   720
    # Change the elements of the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   721
    def SetElements(self, elements):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   722
        self.Elements = elements
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   723
        self.RefreshWireExclusion()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   724
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   725
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   726
    # Returns the elements of the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   727
    def GetElements(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   728
        return self.Elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   729
    
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   730
    # Align the group elements
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   731
    def AlignElements(self, horizontally, vertically):
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   732
        minx = self.BoundingBox.x + self.BoundingBox.width
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   733
        miny = self.BoundingBox.y + self.BoundingBox.height
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   734
        maxx = self.BoundingBox.x
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   735
        maxy = self.BoundingBox.y
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   736
        for element in self.Elements:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   737
            if not isinstance(element, Wire):
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   738
                posx, posy = element.GetPosition()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   739
                width, height = element.GetSize()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   740
                minx = min(minx, posx)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   741
                miny = min(miny, posy)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   742
                maxx = max(maxx, posx + width)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   743
                maxy = max(maxy, posy + height)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   744
        for element in self.Elements:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   745
            if not isinstance(element, Wire):
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   746
                posx, posy = element.GetPosition()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   747
                width, height = element.GetSize()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   748
                movex = movey = 0
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   749
                if horizontally == ALIGN_LEFT:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   750
                    movex = minx - posx
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   751
                elif horizontally == ALIGN_CENTER:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   752
                    movex = (maxx + minx - width) / 2 - posx
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   753
                elif horizontally == ALIGN_RIGHT:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   754
                    movex = maxx - width - posx
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   755
                if vertically == ALIGN_TOP:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   756
                    movey = miny - posy
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   757
                elif vertically == ALIGN_MIDDLE:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   758
                    movey = (maxy + miny - height) / 2 - posy
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   759
                elif vertically == ALIGN_BOTTOM:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   760
                    movey = maxy - height - posy
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   761
                if movex != 0 or movey != 0:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   762
                    element.Move(movex, movey)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   763
                    element.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   764
        self.RefreshWireExclusion()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   765
        self.RefreshBoundingBox()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   766
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   767
    # Remove or select the given element if it is or not in the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   768
    def SelectElement(self, element):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   769
        if element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   770
            self.Elements.remove(element)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   771
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   772
            self.Elements.append(element)
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   773
        self.RefreshWireExclusion()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   774
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   775
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   776
    # Move this group of elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   777
    def Move(self, movex, movey):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   778
        # Move all the elements of the group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   779
        for element in self.Elements:
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   780
            if not isinstance(element, Wire):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   781
                element.Move(movex, movey, self.WireExcluded)
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   782
            elif element in self.WireExcluded:
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   783
                element.Move(movex, movey, True)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   784
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   785
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   786
    # Refreshes the bounding box of this group of elements
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   787
    def RefreshBoundingBox(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   788
        if len(self.Elements) > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   789
            bbox = self.Elements[0].GetBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   790
            minx, miny = bbox.x, bbox.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   791
            maxx = bbox.x + bbox.width
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   792
            maxy = bbox.y + bbox.height
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   793
            for element in self.Elements[1:]:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   794
                bbox = element.GetBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   795
                minx = min(minx, bbox.x)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   796
                miny = min(miny, bbox.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   797
                maxx = max(maxx, bbox.x + bbox.width)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   798
                maxy = max(maxy, bbox.y + bbox.height)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   799
            self.BoundingBox = wx.Rect(minx, miny, maxx - minx, maxy - miny)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   800
        else:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   801
            self.BoundingBox = wx.Rect(0, 0, 0, 0)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   802
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   803
    # Forbids to change the group position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   804
    def SetPosition(x, y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   805
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   806
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   807
    # Returns the position of this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   808
    def GetPosition(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   809
        return self.BoundingBox.x, self.BoundingBox.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   810
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   811
    # Forbids to change the group size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   812
    def SetSize(width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   813
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   814
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   815
    # Returns the size of this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   816
    def GetSize(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   817
        return self.BoundingBox.width, self.BoundingBox.height
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   818
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   819
    # Change the variable that indicates if this element is highlighted
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   820
    def SetHighlighted(self, highlighted):
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   821
        for element in self.Elements:
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   822
            element.SetHighlighted(highlighted)
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
   823
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   824
    # Change the variable that indicates if the elemente is selected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   825
    def SetSelected(self, selected):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   826
        for element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   827
            element.SetSelected(selected)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   828
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   829
    # Method called when a RightUp event has been generated
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   830
    def OnRightUp(self, event, dc, scaling):
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   831
        # Popup the menu with special items for a group
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   832
        self.Parent.PopupGroupMenu()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
   833
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   834
    # Refreshes the model of all the elements of this group
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   835
    def RefreshModel(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   836
        for element in self.Elements:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   837
            element.RefreshModel()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   838
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   839
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   840
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   841
#                         Connector for all types of blocks
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   842
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   843
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   844
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   845
Class that implements a connector for any type of block
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   846
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   847
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   848
class Connector:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   849
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   850
    # Create a new connector
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   851
    def __init__(self, parent, name, type, position, direction, negated = False, edge = "none", onlyone = False):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   852
        self.ParentBlock = parent
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   853
        self.Name = name
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   854
        self.Type = type
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   855
        self.Pos = position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   856
        self.Direction = direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   857
        self.Wires = []
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   858
        if self.ParentBlock.IsOfType("BOOL", type):
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   859
            self.Negated = negated
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   860
            self.Edge = edge
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   861
        else:
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   862
            self.Negated = False
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   863
            self.Edge = "none"
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
   864
        self.OneConnected = onlyone
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   865
        self.Pen = wx.BLACK_PEN
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   866
        self.Errors = {}
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   867
        self.RefreshNameSize()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   868
    
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   869
    # Returns the RedrawRect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   870
    def GetRedrawRect(self, movex = 0, movey = 0):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   871
        parent_pos = self.ParentBlock.GetPosition()
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   872
        x = min(parent_pos[0] + self.Pos.x, parent_pos[0] + self.Pos.x + self.Direction[0] * CONNECTOR_SIZE)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   873
        y = min(parent_pos[1] + self.Pos.y, parent_pos[1] + self.Pos.y + self.Direction[1] * CONNECTOR_SIZE)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   874
        if self.Direction[0] == 0:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   875
            width = 5
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   876
        else:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   877
            width = CONNECTOR_SIZE
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   878
        if self.Direction[1] == 0:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   879
            height = 5
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   880
        else:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   881
            height = CONNECTOR_SIZE
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   882
        return wx.Rect(x - abs(movex), y - abs(movey), width + 2 * abs(movex), height + 2 * abs(movey))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   883
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   884
    # Change the connector pen
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   885
    def SetPen(self, pen):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   886
        self.Pen = pen
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   887
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   888
    # Make a clone of the connector
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
   889
    def Clone(self, parent = None):
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
   890
        if parent is None:
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
   891
            parent = self.ParentBlock
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
   892
        return Connector(parent, self.Name, self.Type, wx.Point(self.Pos[0], self.Pos[1]),
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   893
                self.Direction, self.Negated)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   894
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   895
    # Returns the connector parent block
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   896
    def GetParentBlock(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   897
        return self.ParentBlock
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   898
    
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   899
    # Returns the connector type
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
   900
    def GetType(self, raw = False):
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   901
        if self.ParentBlock.IsEndType(self.Type) or raw:
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   902
            return self.Type
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   903
        elif (self.Negated or self.Edge != "none") and self.ParentBlock.IsOfType("BOOL", self.Type):
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   904
            return "BOOL"
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   905
        else:
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   906
            return self.ParentBlock.GetConnectionResultType(self, self.Type)
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   907
    
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   908
    # Returns the connector type
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   909
    def GetConnectedType(self):
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   910
        if self.ParentBlock.IsEndType(self.Type):
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   911
            return self.Type
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   912
        elif len(self.Wires) == 1:
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   913
            return self.Wires[0][0].GetOtherConnectedType(self.Wires[0][1])
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   914
        return self.Type
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   915
    
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   916
    # Returns the connector type
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   917
    def GetConnectedRedrawRect(self, movex, movey):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   918
        rect = None
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   919
        for wire, handle in self.Wires:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   920
            if rect is None:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   921
                rect = wire.GetRedrawRect()
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   922
            else:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   923
                rect = rect.Union(wire.GetRedrawRect())
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   924
        return rect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
   925
    
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
   926
    # Returns if connector type is compatible with type given
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
   927
    def IsCompatible(self, type):
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
   928
        reference = self.GetType()
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
   929
        return self.ParentBlock.IsOfType(type, reference) or self.ParentBlock.IsOfType(reference, type)
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
   930
    
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   931
    # Changes the connector name
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   932
    def SetType(self, type):
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   933
        self.Type = type
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   934
    
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
   935
    # Returns the connector name
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   936
    def GetName(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   937
        return self.Name
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   938
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   939
    # Changes the connector name
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   940
    def SetName(self, name):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   941
        self.Name = name
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   942
        self.RefreshNameSize()
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   943
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   944
    def SetValue(self, value):
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   945
        for wire, handle in self.Wires:
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
   946
            wire.SetValue(value)
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   947
    
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   948
    # Changes the connector name size
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   949
    def RefreshNameSize(self):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   950
        if self.Name != "":
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   951
            dc = wx.ClientDC(self.ParentBlock.Parent)
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   952
            self.NameSize = dc.GetTextExtent(self.Name)
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   953
        else:
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   954
            self.NameSize = 0, 0
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   955
    
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   956
    # Returns the connector name size
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   957
    def GetNameSize(self):
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
   958
        return self.NameSize
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   959
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   960
    # Returns the wires connected to the connector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   961
    def GetWires(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   962
        return self.Wires
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   963
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   964
    # Returns the parent block Id
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   965
    def GetBlockId(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   966
        return self.ParentBlock.GetId()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   967
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   968
    # Returns the connector relative position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   969
    def GetRelPosition(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   970
        return self.Pos
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   971
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   972
    # Returns the connector absolute position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   973
    def GetPosition(self, size = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   974
        parent_pos = self.ParentBlock.GetPosition()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   975
        # If the position of the end of the connector is asked
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   976
        if size:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   977
            x = parent_pos[0] + self.Pos.x + self.Direction[0] * CONNECTOR_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   978
            y = parent_pos[1] + self.Pos.y + self.Direction[1] * CONNECTOR_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   979
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   980
            x = parent_pos[0] + self.Pos.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   981
            y = parent_pos[1] + self.Pos.y
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
   982
        return wx.Point(x, y)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   983
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   984
    # Change the connector relative position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   985
    def SetPosition(self, pos):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   986
        self.Pos = pos
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   987
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   988
    # Returns the connector direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   989
    def GetDirection(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   990
        return self.Direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   991
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   992
    # Change the connector direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   993
    def SetDirection(self, direction):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   994
        self.Direction = direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   995
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   996
    # Connect a wire to this connector at the last place
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   997
    def Connect(self, wire, refresh = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   998
        self.InsertConnect(len(self.Wires), wire, refresh)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
   999
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1000
    # Connect a wire to this connector at the place given
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1001
    def InsertConnect(self, idx, wire, refresh = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1002
        if wire not in self.Wires:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1003
            self.Wires.insert(idx, wire)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1004
            if refresh:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1005
                self.ParentBlock.RefreshModel(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1006
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1007
    # Returns the index of the wire given in the list of connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1008
    def GetWireIndex(self, wire):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1009
        for i, (tmp_wire, handle) in enumerate(self.Wires):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1010
            if tmp_wire == wire:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1011
                return i
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1012
        return None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1013
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1014
    # Unconnect a wire or all wires connected to the connector
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1015
    def UnConnect(self, wire = None, unconnect = True, delete = False):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1016
        i = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1017
        found = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1018
        while i < len(self.Wires) and not found:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1019
            if not wire or self.Wires[i][0] == wire:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1020
                # If Unconnect haven't been called from a wire, disconnect the connector in the wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1021
                if unconnect:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1022
                    if self.Wires[i][1] == 0:
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1023
                        self.Wires[i][0].UnConnectStartPoint(delete)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1024
                    else:
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1025
                        self.Wires[i][0].UnConnectEndPoint(delete)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1026
                # Remove wire from connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1027
                if wire:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1028
                    self.Wires.pop(i)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1029
                    found = True
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1030
            i += 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1031
        # If no wire defined, unconnect all wires
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1032
        if not wire:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1033
            self.Wires = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1034
        self.ParentBlock.RefreshModel(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1035
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1036
    # Returns if connector has one or more wire connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1037
    def IsConnected(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1038
        return len(self.Wires) > 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1039
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1040
    # Move the wires connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1041
    def MoveConnected(self, exclude = []):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1042
        if len(self.Wires) > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1043
            # Calculate the new position of the end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1044
            parent_pos = self.ParentBlock.GetPosition()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1045
            x = parent_pos[0] + self.Pos.x + self.Direction[0] * CONNECTOR_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1046
            y = parent_pos[1] + self.Pos.y + self.Direction[1] * CONNECTOR_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1047
            # Move the corresponding point on all the wires connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1048
            for wire, index in self.Wires:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1049
                if wire not in exclude:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1050
                    if index == 0:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1051
                        wire.MoveStartPoint(wx.Point(x, y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1052
                    else:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1053
                        wire.MoveEndPoint(wx.Point(x, y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1054
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1055
    # Refreshes the model of all the wires connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1056
    def RefreshWires(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1057
        for wire in self.Wires:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1058
            wire[0].RefreshModel()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1059
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1060
    # Refreshes the parent block model
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1061
    def RefreshParentBlock(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1062
        self.ParentBlock.RefreshModel(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1063
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1064
    # Highlight the parent block
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1065
    def HighlightParentBlock(self, highlight):
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1066
        self.ParentBlock.SetHighlighted(highlight)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1067
        self.ParentBlock.Refresh()
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1068
    
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1069
    # Returns all the blocks connected to this connector
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1070
    def GetConnectedBlocks(self):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1071
        blocks = []
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1072
        for wire, handle in self.Wires:
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1073
            # Get other connector connected to each wire
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1074
            if handle == 0:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1075
                connector = wire.GetEndConnected()
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1076
            else:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1077
                connector = wire.GetStartConnected()
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1078
            # Get parent block for this connector
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1079
            if connector:
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1080
                block = connector.GetParentBlock()
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1081
                if block not in blocks:
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1082
                    blocks.append(block)
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1083
        return blocks
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1084
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1085
    # Returns the connector negated property
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1086
    def IsNegated(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1087
        return self.Negated
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1088
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1089
    # Changes the connector negated property
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1090
    def SetNegated(self, negated):
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1091
        if self.ParentBlock.IsOfType("BOOL", self.Type):
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1092
            self.Negated = negated
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1093
            self.Edge = "none"
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1094
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1095
    # Returns the connector edge property
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1096
    def GetEdge(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1097
        return self.Edge
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1098
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1099
    # Changes the connector edge property
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1100
    def SetEdge(self, edge):
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1101
        if self.ParentBlock.IsOfType("BOOL", self.Type):
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1102
            self.Edge = edge    
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1103
            self.Negated = False
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1104
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1105
    # Tests if the point given is near from the end point of this connector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1106
    def TestPoint(self, pt, exclude = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1107
        parent_pos = self.ParentBlock.GetPosition()
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1108
        if not (len(self.Wires) > 0 and self.OneConnected and exclude):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1109
            # Calculate a square around the end point of this connector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1110
            x = parent_pos[0] + self.Pos.x + self.Direction[0] * CONNECTOR_SIZE - ANCHOR_DISTANCE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1111
            y = parent_pos[1] + self.Pos.y + self.Direction[1] * CONNECTOR_SIZE - ANCHOR_DISTANCE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1112
            width = ANCHOR_DISTANCE * 2 + abs(self.Direction[0]) * CONNECTOR_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1113
            height = ANCHOR_DISTANCE * 2 + abs(self.Direction[1]) * CONNECTOR_SIZE
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1114
            rect = wx.Rect(x, y, width, height)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1115
            return rect.InsideXY(pt.x, pt.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1116
        return False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1117
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1118
    # Draws the highlightment of this element if it is highlighted
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1119
    def DrawHighlightment(self, dc):
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1120
        dc.SetPen(wx.Pen(HIGHLIGHTCOLOR))
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1121
        dc.SetBrush(wx.Brush(HIGHLIGHTCOLOR))
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1122
        dc.SetLogicalFunction(wx.AND)
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1123
        parent_pos = self.ParentBlock.GetPosition()
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1124
        posx = parent_pos[0] + self.Pos.x
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1125
        posy = parent_pos[1] + self.Pos.y
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1126
        width = CONNECTOR_SIZE
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1127
        height = CONNECTOR_SIZE
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1128
        if self.Direction[0] < 0:
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1129
            posx += CONNECTOR_SIZE * self.Direction[0]
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1130
        elif self.Direction[0] == 0:
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1131
            posx -= 2
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1132
            width = 5
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1133
        if self.Direction[1] < 0:
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1134
            posy += CONNECTOR_SIZE * self.Direction[1]
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1135
        elif self.Direction[1] == 0:
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1136
            posy -= 2
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1137
            height = 5
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1138
        dc.DrawRectangle(posx, posy, width, height)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1139
        dc.SetLogicalFunction(wx.COPY)
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  1140
    
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1141
    def AddError(self, infos, start, end):
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1142
        if len(infos) == 0:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1143
            for wire, handle in self.Wires:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1144
                wire.MarkAsInvalid()
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1145
        else:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1146
            self.Errors[infos[0]] = (start, end)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1147
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1148
    # Draws the connector
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1149
    def Draw(self, dc):
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1150
        if len(self.Errors) > 0:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1151
            dc.SetPen(wx.RED_PEN)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1152
            dc.SetBrush(wx.Brush(wx.Colour(255, 255, 0)))
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1153
        else:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1154
            dc.SetPen(self.Pen)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1155
            dc.SetBrush(wx.WHITE_BRUSH)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1156
        parent_pos = self.ParentBlock.GetPosition()
213
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1157
        
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1158
        if getattr(dc, "printing", False):
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1159
            name_size = dc.GetTextExtent(self.Name)
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1160
        else:
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1161
            name_size = self.NameSize
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1162
        
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1163
        if self.Negated:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1164
            # If connector is negated, draw a circle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1165
            xcenter = parent_pos[0] + self.Pos.x + (CONNECTOR_SIZE * self.Direction[0]) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1166
            ycenter = parent_pos[1] + self.Pos.y + (CONNECTOR_SIZE * self.Direction[1]) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1167
            dc.DrawCircle(xcenter, ycenter, CONNECTOR_SIZE / 2)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1168
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1169
            xstart = parent_pos[0] + self.Pos.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1170
            ystart = parent_pos[1] + self.Pos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1171
            if self.Edge == "rising":
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1172
                # If connector has a rising edge, draw a right arrow
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1173
                dc.DrawLine(xstart, ystart, xstart - 4, ystart - 4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1174
                dc.DrawLine(xstart, ystart, xstart - 4, ystart + 4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1175
            elif self.Edge == "falling":
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1176
                # If connector has a falling edge, draw a left arrow
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1177
                dc.DrawLine(xstart, ystart, xstart + 4, ystart - 4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1178
                dc.DrawLine(xstart, ystart, xstart + 4, ystart + 4)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1179
            xend = xstart + CONNECTOR_SIZE * self.Direction[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1180
            yend = ystart + CONNECTOR_SIZE * self.Direction[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1181
            dc.DrawLine(xstart + self.Direction[0], ystart + self.Direction[1], xend, yend)
231
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1182
        if len(self.Errors) > 0:
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1183
            dc.SetPen(self.Pen)
fc2d6cbb8b39 Adding support for highlighing compiling errors from matiec
lbessard
parents: 222
diff changeset
  1184
            dc.SetBrush(wx.WHITE_BRUSH)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1185
        if self.Direction[0] != 0:
213
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1186
            ytext = parent_pos[1] + self.Pos.y - name_size[1] / 2
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1187
            if self.Direction[0] < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1188
                xtext = parent_pos[0] + self.Pos.x + 5
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1189
            else:
213
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1190
                xtext = parent_pos[0] + self.Pos.x - (name_size[0] + 5)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1191
        if self.Direction[1] != 0:
213
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1192
            xtext = parent_pos[0] + self.Pos.x - name_size[0] / 2
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1193
            if self.Direction[1] < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1194
                ytext = parent_pos[1] + self.Pos.y + 5
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1195
            else:
213
4931959ea256 Adding support for printing graphical languages
lbessard
parents: 208
diff changeset
  1196
                ytext = parent_pos[1] + self.Pos.y - (name_size[1] + 5)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1197
        # Draw the text
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1198
        dc.DrawText(self.Name, xtext, ytext)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1199
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1200
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1201
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1202
#                           Common Wire Element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1203
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1204
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1205
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1206
Class that implements a wire for connecting two blocks
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1207
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1208
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1209
class Wire(Graphic_Element):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1210
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1211
    # Create a new wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1212
    def __init__(self, parent, start = None, end = None):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1213
        Graphic_Element.__init__(self, parent)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1214
        self.StartPoint = start
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1215
        self.EndPoint = end
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1216
        self.StartConnected = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1217
        self.EndConnected = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1218
        # If the start and end points are defined, calculate the wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1219
        if start and end:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1220
            self.ResetPoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1221
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1222
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1223
            self.Points = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1224
            self.Segments = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1225
        self.SelectedSegment = None
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1226
        self.Valid = True
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1227
        self.Value = None
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1228
        self.OverStart = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1229
        self.OverEnd = False
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1230
        self.ComputingType = False
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1231
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1232
    # Destructor of a wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1233
    def __del__(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1234
        self.StartConnected = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1235
        self.EndConnected = None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1236
    
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1237
    # Returns the RedrawRect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1238
    def GetRedrawRect(self, movex = 0, movey = 0):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1239
        rect = Graphic_Element.GetRedrawRect(self, movex, movey)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1240
        if self.StartConnected:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1241
            rect = rect.Union(self.StartConnected.GetRedrawRect(movex, movey))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1242
        if self.EndConnected:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1243
            rect = rect.Union(self.EndConnected.GetRedrawRect(movex, movey))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1244
        return rect
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1245
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1246
    # Forbids to change the wire position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1247
    def SetPosition(x, y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1248
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1249
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1250
    # Forbids to change the wire size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1251
    def SetSize(width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1252
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1253
    
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1254
    # Returns connector to which start point is connected
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1255
    def GetStartConnected(self):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1256
        return self.StartConnected
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1257
    
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1258
    # Returns connector to which start point is connected
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1259
    def GetStartConnectedType(self):
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1260
        if self.StartConnected and not self.ComputingType:
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1261
            self.ComputingType = True
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1262
            computed_type = self.StartConnected.GetType()
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1263
            self.ComputingType = False
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1264
            return computed_type
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1265
        return None
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1266
    
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1267
    # Returns connector to which end point is connected
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1268
    def GetEndConnected(self):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1269
        return self.EndConnected
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1270
    
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1271
    # Returns connector to which end point is connected
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1272
    def GetEndConnectedType(self):
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1273
        if self.EndConnected and not self.ComputingType:
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1274
            self.ComputingType = True
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1275
            computed_type = self.EndConnected.GetType()
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1276
            self.ComputingType = False
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1277
            return computed_type
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1278
        return None
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1279
    
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1280
    def GetOtherConnected(self, connector):
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1281
        if self.StartConnected == connector:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1282
            return self.EndConnected
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1283
        else:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1284
            return self.StartConnected
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1285
    
99
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1286
    def GetOtherConnectedType(self, handle):
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1287
        if handle == 0:
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1288
            return self.GetEndConnectedType()
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1289
        else:
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1290
            return self.GetStartConnectedType()
2b18a72dcaf0 Added support for standard functions type compatibility check
lbessard
parents: 98
diff changeset
  1291
    
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1292
    def IsConnectedCompatible(self):
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1293
        if self.StartConnected:
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1294
            return self.StartConnected.IsCompatible(self.GetEndConnectedType())
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1295
        elif self.EndConnected:
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1296
            return True
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1297
        return False
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  1298
    
102
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1299
    def SetValue(self, value):
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1300
        self.Value = value
85875dcb7754 Adding edit user's POU by double click on block instance
lbessard
parents: 99
diff changeset
  1301
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1302
    # Unconnect the start and end points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1303
    def Clean(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1304
        if self.StartConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1305
            self.UnConnectStartPoint()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1306
        if self.EndConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1307
            self.UnConnectEndPoint()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1308
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1309
    # Delete this wire by calling the corresponding method
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1310
    def Delete(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1311
        self.Parent.DeleteWire(self)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1312
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1313
    # Select a segment and not the whole wire. It's useful for Ladder Diagram
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1314
    def SetSelectedSegment(self, segment):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1315
        # The last segment is indicated
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1316
        if segment == -1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1317
            segment = len(self.Segments) - 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1318
        # The selected segment is reinitialised
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1319
        if segment == None:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1320
            if self.StartConnected:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1321
                self.StartConnected.SetPen(wx.BLACK_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1322
            if self.EndConnected:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1323
                self.EndConnected.SetPen(wx.BLACK_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1324
        # The segment selected is the first
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1325
        elif segment == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1326
            if self.StartConnected:
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1327
                self.StartConnected.SetPen(wx.BLUE_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1328
            if self.EndConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1329
                # There is only one segment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1330
                if len(self.Segments) == 1:
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1331
                    self.EndConnected.SetPen(wx.BLUE_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1332
                else:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1333
                    self.EndConnected.SetPen(wx.BLACK_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1334
        # The segment selected is the last
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1335
        elif segment == len(self.Segments) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1336
            if self.StartConnected:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1337
                self.StartConnected.SetPen(wx.BLACK_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1338
            if self.EndConnected:
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1339
                self.EndConnected.SetPen(wx.BLUE_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1340
        self.SelectedSegment = segment
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1341
        self.Refresh()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1342
    
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1343
    # Select a segment and not the whole wire. It's useful for Ladder Diagram
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1344
    def MarkAsInvalid(self):
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1345
        self.Valid = False
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1346
        if self.StartConnected:
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1347
            self.StartConnected.SetPen(wx.RED_PEN)
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1348
        if self.EndConnected:
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1349
            self.EndConnected.SetPen(wx.RED_PEN)
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  1350
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1351
    # Reinitialize the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1352
    def ResetPoints(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1353
        if self.StartPoint and self.EndPoint:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1354
            self.Points = [self.StartPoint[0], self.EndPoint[0]]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1355
            self.Segments = [self.StartPoint[1]]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1356
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1357
            self.Points = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1358
            self.Segments = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1359
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1360
    # Refresh the wire bounding box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1361
    def RefreshBoundingBox(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1362
        if len(self.Points) > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1363
            # If startpoint or endpoint is connected, save the point radius
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1364
            start_radius = end_radius = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1365
            if not self.StartConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1366
                start_radius = POINT_RADIUS
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1367
            if not self.EndConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1368
                end_radius = POINT_RADIUS
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1369
            # Initialize minimum and maximum from the first point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1370
            minx, minbbxx = self.Points[0].x, self.Points[0].x - start_radius
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1371
            maxx, maxbbxx = self.Points[0].x, self.Points[0].x + start_radius
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1372
            miny, minbbxy = self.Points[0].y, self.Points[0].y - start_radius
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1373
            maxy, maxbbxy = self.Points[0].y, self.Points[0].y + start_radius
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1374
            # Actualize minimum and maximum with the other points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1375
            for point in self.Points[1:-1]:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1376
                minx, minbbxx = min(minx, point.x), min(minbbxx, point.x)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1377
                maxx, maxbbxx = max(maxx, point.x), max(maxbbxx, point.x)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1378
                miny, minbbxy = min(miny, point.y), min(minbbxy, point.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1379
                maxy, maxbbxy = max(maxy, point.y), max(maxbbxy, point.y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1380
            if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1381
                minx, minbbxx = min(minx, self.Points[-1].x), min(minbbxx, self.Points[-1].x - end_radius)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1382
                maxx, maxbbxx = max(maxx, self.Points[-1].x), max(maxbbxx, self.Points[-1].x + end_radius)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1383
                miny, minbbxy = min(miny, self.Points[-1].y), min(minbbxy, self.Points[-1].y - end_radius)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1384
                maxy, maxbbxy = max(maxy, self.Points[-1].y), max(maxbbxy, self.Points[-1].y + end_radius)
108
9aa1fdfb7cb2 A lots of bugs fixed
lbessard
parents: 102
diff changeset
  1385
            self.Pos.x, self.Pos.y = minx, miny
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1386
            self.Size = wx.Size(maxx - minx, maxy - miny)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1387
            self.BoundingBox = wx.Rect(minbbxx, minbbxy, maxbbxx - minbbxx + 1, maxbbxy - minbbxy + 1)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1388
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1389
    # Refresh the realpoints that permits to keep the proportionality in wire during resizing
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1390
    def RefreshRealPoints(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1391
        if len(self.Points) > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1392
            self.RealPoints = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1393
            # Calculate float relative position of each point with the minimum point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1394
            for point in self.Points:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1395
                self.RealPoints.append([float(point.x - self.Pos.x), float(point.y - self.Pos.y)])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1396
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1397
    # Returns the wire minimum size 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1398
    def GetMinSize(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1399
        width = 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1400
        height = 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1401
        dir_product = product(self.StartPoint[1], self.EndPoint[1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1402
        # The directions are opposed
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1403
        if dir_product < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1404
            if self.StartPoint[0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1405
                width = MIN_SEGMENT_SIZE * 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1406
            if self.StartPoint[1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1407
                height = MIN_SEGMENT_SIZE * 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1408
        # The directions are the same
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1409
        elif dir_product > 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1410
            if self.StartPoint[0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1411
                width = MIN_SEGMENT_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1412
            if self.StartPoint[1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1413
                height = MIN_SEGMENT_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1414
        # The directions are perpendiculars
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1415
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1416
            width = MIN_SEGMENT_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1417
            height = MIN_SEGMENT_SIZE
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1418
        return width + 1, height + 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1419
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1420
    # Returns if the point given is on one of the wire segments
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1421
    def HitTest(self, pt):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1422
        test = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1423
        for i in xrange(len(self.Points) - 1):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1424
            rect = wx.Rect(0, 0, 0, 0)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1425
            x1, y1 = self.Points[i].x, self.Points[i].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1426
            x2, y2 = self.Points[i + 1].x, self.Points[i + 1].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1427
            # Calculate a rectangle around the segment
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1428
            rect = wx.Rect(min(x1, x2) - ANCHOR_DISTANCE, min(y1, y2) - ANCHOR_DISTANCE,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1429
                abs(x1 - x2) + 2 * ANCHOR_DISTANCE, abs(y1 - y2) + 2 * ANCHOR_DISTANCE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1430
            test |= rect.InsideXY(pt.x, pt.y) 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1431
        return test
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1432
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1433
    # Returns the wire start or end point if the point given is on one of them 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1434
    def TestPoint(self, pt):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1435
        # Test the wire start point
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1436
        rect = wx.Rect(self.Points[0].x - ANCHOR_DISTANCE, self.Points[0].y - ANCHOR_DISTANCE,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1437
            2 * ANCHOR_DISTANCE, 2 * ANCHOR_DISTANCE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1438
        if rect.InsideXY(pt.x, pt.y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1439
            return 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1440
        # Test the wire end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1441
        if len(self.Points) > 1:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1442
            rect = wx.Rect(self.Points[-1].x - ANCHOR_DISTANCE, self.Points[-1].y - ANCHOR_DISTANCE,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1443
                2 * ANCHOR_DISTANCE, 2 * ANCHOR_DISTANCE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1444
            if rect.InsideXY(pt.x, pt.y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1445
                return -1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1446
        return None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1447
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1448
    # Returns the wire segment if the point given is on it
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1449
    def TestSegment(self, pt, all=False):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1450
        for i in xrange(len(self.Segments)):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1451
            # If wire is not in a Ladder Diagram, first and last segments are excluded
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1452
            if 0 < i < len(self.Segments) - 1 or all:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1453
                x1, y1 = self.Points[i].x, self.Points[i].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1454
                x2, y2 = self.Points[i + 1].x, self.Points[i + 1].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1455
                # Calculate a rectangle around the segment
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1456
                rect = wx.Rect(min(x1, x2) - ANCHOR_DISTANCE, min(y1, y2) - ANCHOR_DISTANCE,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1457
                    abs(x1 - x2) + 2 * ANCHOR_DISTANCE, abs(y1 - y2) + 2 * ANCHOR_DISTANCE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1458
                if rect.InsideXY(pt.x, pt.y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1459
                    return i, self.Segments[i]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1460
        return None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1461
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1462
    # Define the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1463
    def SetPoints(self, points):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1464
        if len(points) > 1:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1465
            self.Points = [wx.Point(x, y) for x, y in points]
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1466
            # Calculate the start and end directions
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1467
            self.StartPoint = [None, vector(self.Points[0], self.Points[1])]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1468
            self.EndPoint = [None, vector(self.Points[-1], self.Points[-2])]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1469
            # Calculate the start and end points
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1470
            self.StartPoint[0] = wx.Point(self.Points[0].x + CONNECTOR_SIZE * self.StartPoint[1][0], 
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1471
                self.Points[0].y + CONNECTOR_SIZE * self.StartPoint[1][1])
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1472
            self.EndPoint[0] = wx.Point(self.Points[-1].x + CONNECTOR_SIZE * self.EndPoint[1][0], 
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1473
                self.Points[-1].y + CONNECTOR_SIZE * self.EndPoint[1][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1474
            self.Points[0] = self.StartPoint[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1475
            self.Points[-1] = self.EndPoint[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1476
            # Calculate the segments directions
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1477
            self.Segments = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1478
            for i in xrange(len(self.Points) - 1):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1479
                self.Segments.append(vector(self.Points[i], self.Points[i + 1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1480
            self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1481
            self.RefreshRealPoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1482
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1483
    # Returns the position of the point indicated
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1484
    def GetPoint(self, index):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1485
        if index < len(self.Points):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1486
            return self.Points[index].x, self.Points[index].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1487
        return None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1488
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1489
    # Returns a list of the position of all wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1490
    def GetPoints(self, invert = False):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1491
        points = self.VerifyPoints()
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1492
        points[0] = wx.Point(points[0].x - CONNECTOR_SIZE * self.StartPoint[1][0], 
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1493
                points[0].y - CONNECTOR_SIZE * self.StartPoint[1][1])
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1494
        points[-1] = wx.Point(points[-1].x - CONNECTOR_SIZE * self.EndPoint[1][0], 
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1495
                points[-1].y - CONNECTOR_SIZE * self.EndPoint[1][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1496
        # An inversion of the list is asked
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1497
        if invert:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1498
            points.reverse()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1499
        return points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1500
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1501
    # Returns the position of the two selected segment points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1502
    def GetSelectedSegmentPoints(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1503
        if self.SelectedSegment != None and len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1504
            return self.Points[self.SelectedSegment:self.SelectedSegment + 2]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1505
        return []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1506
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1507
    # Returns if the selected segment is the first and/or the last of the wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1508
    def GetSelectedSegmentConnections(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1509
        if self.SelectedSegment != None and len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1510
            return self.SelectedSegment == 0, self.SelectedSegment == len(self.Segments) - 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1511
        return (True, True)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1512
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1513
    # Returns the connectors on which the wire is connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1514
    def GetConnected(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1515
        connected = []
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1516
        if self.StartConnected and self.StartPoint[1] == WEST:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1517
            connected.append(self.StartConnected)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1518
        if self.EndConnected and self.EndPoint[1] == WEST:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1519
            connected.append(self.EndConnected)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1520
        return connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1521
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1522
    # Returns the id of the block connected to the first or the last wire point
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1523
    def GetConnectedInfos(self, index):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1524
        if index == 0 and self.StartConnected:
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1525
            return self.StartConnected.GetBlockId(), self.StartConnected.GetName()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1526
        elif index == -1 and self.EndConnected:
42
4a8400732001 Adding optimization on redrawing
lbessard
parents: 28
diff changeset
  1527
            return self.EndConnected.GetBlockId(), self.EndConnected.GetName()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1528
        return None
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1529
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1530
    # Update the wire points position by keeping at most possible the current positions
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1531
    def GeneratePoints(self, realpoints = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1532
        i = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1533
        # Calculate the start enad end points with the minimum segment size in the right direction
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1534
        end = wx.Point(self.EndPoint[0].x + self.EndPoint[1][0] * MIN_SEGMENT_SIZE,
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1535
            self.EndPoint[0].y + self.EndPoint[1][1] * MIN_SEGMENT_SIZE)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1536
        start = wx.Point(self.StartPoint[0].x + self.StartPoint[1][0] * MIN_SEGMENT_SIZE, 
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1537
            self.StartPoint[0].y + self.StartPoint[1][1] * MIN_SEGMENT_SIZE)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1538
        # Evaluate the point till it's the last
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1539
        while i < len(self.Points) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1540
            # The next point is the last
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1541
            if i + 1 == len(self.Points) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1542
                # Calculate the direction from current point to end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1543
                v_end = vector(self.Points[i], end)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1544
                # The current point is the first
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1545
                if i == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1546
                    # If the end point is not in the start direction, a point is added
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1547
                    if v_end != self.Segments[0] or v_end == self.EndPoint[1]:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1548
                        self.Points.insert(1, wx.Point(start.x, start.y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1549
                        self.Segments.insert(1, DirectionChoice((self.Segments[0][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1550
                            self.Segments[0][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1551
                # The current point is the second
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1552
                elif i == 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1553
                    # The previous direction and the target direction are mainly opposed, a point is added
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1554
                    if product(v_end, self.Segments[0]) < 0:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1555
                        self.Points.insert(2, wx.Point(self.Points[1].x, self.Points[1].y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1556
                        self.Segments.insert(2, DirectionChoice((self.Segments[1][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1557
                            self.Segments[1][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1558
                    # The previous direction and the end direction are the same or they are
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1559
                    # perpendiculars and the end direction points towards current segment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1560
                    elif product(self.Segments[0], self.EndPoint[1]) >= 0 and product(self.Segments[1], self.EndPoint[1]) <= 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1561
                        # Current point and end point are aligned
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1562
                        if self.Segments[0][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1563
                            self.Points[1].x = end.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1564
                        if self.Segments[0][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1565
                            self.Points[1].y = end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1566
                        # If the previous direction and the end direction are the same, a point is added
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1567
                        if product(self.Segments[0], self.EndPoint[1]) > 0:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1568
                            self.Points.insert(2, wx.Point(self.Points[1].x, self.Points[1].y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1569
                            self.Segments.insert(2, DirectionChoice((self.Segments[1][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1570
                                self.Segments[1][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1571
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1572
                        # Current point is positioned in the middle of start point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1573
                        # and end point on the current direction and a point is added
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1574
                        if self.Segments[0][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1575
                            self.Points[1].x = (end.x + start.x) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1576
                        if self.Segments[0][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1577
                            self.Points[1].y = (end.y + start.y) / 2
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1578
                        self.Points.insert(2, wx.Point(self.Points[1].x, self.Points[1].y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1579
                        self.Segments.insert(2, DirectionChoice((self.Segments[1][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1580
                            self.Segments[1][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1581
                else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1582
                    # The previous direction and the end direction are perpendiculars
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1583
                    if product(self.Segments[i - 1], self.EndPoint[1]) == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1584
                        # The target direction and the end direction aren't mainly the same
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1585
                        if product(v_end, self.EndPoint[1]) <= 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1586
                            # Current point and end point are aligned
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1587
                            if self.Segments[i - 1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1588
                                self.Points[i].x = end.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1589
                            if self.Segments[i - 1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1590
                                self.Points[i].y = end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1591
                            # Previous direction is updated from the new point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1592
                            if product(vector(self.Points[i - 1], self.Points[i]), self.Segments[i - 1]) < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1593
                                self.Segments[i - 1] = (-self.Segments[i - 1][0], -self.Segments[i - 1][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1594
                        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1595
                            test = True
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1596
                            # If the current point is the third, test if the second 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1597
                            # point can be aligned with the end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1598
                            if i == 2:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1599
                                test_point = wx.Point(self.Points[1].x, self.Points[1].y)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1600
                                if self.Segments[1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1601
                                    test_point.y = end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1602
                                if self.Segments[1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1603
                                    test_point.x = end.x
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1604
                                vector_test = vector(self.Points[0], test_point, False)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1605
                                test = norm(vector_test) > MIN_SEGMENT_SIZE and product(self.Segments[0], vector_test) > 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1606
                            # The previous point can be aligned
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1607
                            if test:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1608
                                self.Points[i].x, self.Points[i].y = end.x, end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1609
                                if self.Segments[i - 1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1610
                                    self.Points[i - 1].y = end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1611
                                if self.Segments[i - 1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1612
                                    self.Points[i - 1].x = end.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1613
                                self.Segments[i] = (-self.EndPoint[1][0], -self.EndPoint[1][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1614
                            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1615
                                # Current point is positioned in the middle of previous point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1616
                                # and end point on the current direction and a point is added
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1617
                                if self.Segments[1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1618
                                    self.Points[2].x = (self.Points[1].x + end.x) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1619
                                if self.Segments[1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1620
                                    self.Points[2].y = (self.Points[1].y + end.y) / 2
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1621
                                self.Points.insert(3, wx.Point(self.Points[2].x, self.Points[2].y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1622
                                self.Segments.insert(3, DirectionChoice((self.Segments[2][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1623
                                    self.Segments[2][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1624
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1625
                        # Current point is aligned with end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1626
                        if self.Segments[i - 1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1627
                            self.Points[i].x = end.x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1628
                        if self.Segments[i - 1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1629
                            self.Points[i].y = end.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1630
                        # Previous direction is updated from the new point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1631
                        if product(vector(self.Points[i - 1], self.Points[i]), self.Segments[i - 1]) < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1632
                            self.Segments[i - 1] = (-self.Segments[i - 1][0], -self.Segments[i - 1][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1633
                        # If previous direction and end direction are opposed
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1634
                        if product(self.Segments[i - 1], self.EndPoint[1]) < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1635
                            # Current point is positioned in the middle of previous point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1636
                            # and end point on the current direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1637
                            if self.Segments[i - 1][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1638
                                self.Points[i].x = (end.x + self.Points[i - 1].x) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1639
                            if self.Segments[i - 1][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1640
                                self.Points[i].y = (end.y + self.Points[i - 1].y) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1641
                        # A point is added
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1642
                        self.Points.insert(i + 1, wx.Point(self.Points[i].x, self.Points[i].y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1643
                        self.Segments.insert(i + 1, DirectionChoice((self.Segments[i][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1644
                                self.Segments[i][0]), v_end, self.EndPoint[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1645
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1646
                # Current point is the first, and second is not mainly in the first direction
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1647
                if i == 0 and product(vector(start, self.Points[1]), self.Segments[0]) < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1648
                    # If first and second directions aren't perpendiculars, a point is added 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1649
                    if product(self.Segments[0], self.Segments[1]) != 0:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1650
                        self.Points.insert(1, wx.Point(start.x, start.y))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1651
                        self.Segments.insert(1, DirectionChoice((self.Segments[0][1], 
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1652
                            self.Segments[0][0]), vector(start, self.Points[1]), self.Segments[1]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1653
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1654
                        self.Points[1].x, self.Points[1].y = start.x, start.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1655
                else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1656
                    # Next point is aligned with current point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1657
                    if self.Segments[i][0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1658
                        self.Points[i + 1].y = self.Points[i].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1659
                    if self.Segments[i][1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1660
                        self.Points[i + 1].x = self.Points[i].x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1661
                    # Current direction is updated from the new point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1662
                    if product(vector(self.Points[i], self.Points[i + 1]), self.Segments[i]) < 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1663
                        self.Segments[i] = (-self.Segments[i][0], -self.Segments[i][1])
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1664
            i += 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1665
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1666
        if realpoints:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1667
            self.RefreshRealPoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1668
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1669
    # Verify that two consecutive points haven't the same position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1670
    def VerifyPoints(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1671
        points = [point for point in self.Points]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1672
        segments = [segment for segment in self.Segments]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1673
        i = 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1674
        while i < len(points) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1675
            if points[i] == points[i + 1] and segments[i - 1] == segments[i + 1]:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1676
                for j in xrange(2):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1677
                    points.pop(i)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1678
                    segments.pop(i)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1679
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1680
                i += 1
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1681
        # If the wire isn't in a Ladder Diagram, save the new point list
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1682
        if self.Parent.__class__.__name__ != "LD_Viewer":
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1683
            self.Points = [point for point in points]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1684
            self.Segments = [segment for segment in segments]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1685
            self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1686
            self.RefreshRealPoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1687
        return points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1688
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1689
    # Moves all the wire points except the first and the last if they are connected
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1690
    def Move(self, dx, dy, endpoints = False):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1691
        for i, point in enumerate(self.Points):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1692
            if endpoints or not (i == 0 and self.StartConnected) and not (i == len(self.Points) - 1 and self.EndConnected):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1693
                point.x += dx
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1694
                point.y += dy
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1695
        self.StartPoint[0] = self.Points[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1696
        self.EndPoint[0] = self.Points[-1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1697
        self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1698
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1699
    # Resize the wire from position and size given
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1700
    def Resize(self, x, y, width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1701
        if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1702
            # Calculate the new position of each point for testing the new size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1703
            minx, miny = self.Pos.x, self.Pos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1704
            lastwidth, lastheight = self.Size.width, self.Size.height
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1705
            for i, point in enumerate(self.RealPoints):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1706
                # If start or end point is connected, it's not calculate
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1707
                if not (i == 0 and self.StartConnected) and not (i == len(self.Points) - 1 and self.EndConnected):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1708
                    if i == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1709
                        dir = self.StartPoint[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1710
                    elif i == len(self.Points) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1711
                        dir = self.EndPoint[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1712
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1713
                        dir = (0, 0)
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1714
                    pointx = max(-dir[0] * MIN_SEGMENT_SIZE, min(int(round(point[0] * width / float(max(lastwidth, 1)))),
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1715
                            width - dir[0] * MIN_SEGMENT_SIZE))
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1716
                    pointy = max(-dir[1] * MIN_SEGMENT_SIZE, min(int(round(point[1] * height / float(max(lastheight, 1)))),
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1717
                            height - dir[1] * MIN_SEGMENT_SIZE))
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1718
                    self.Points[i] = wx.Point(minx + x + pointx, miny + y + pointy)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1719
            self.StartPoint[0] = self.Points[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1720
            self.EndPoint[0] = self.Points[-1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1721
            self.GeneratePoints(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1722
            # Test if the wire position or size have changed
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1723
            if x != 0 and minx == self.Pos.x:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1724
                x = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1725
                width = lastwidth
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1726
            if y != 0 and miny == self.Pos.y:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1727
                y = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1728
                height = lastwidth
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1729
            if width != lastwidth and lastwidth == self.Size.width:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1730
                width = lastwidth
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1731
            if height != lastheight and lastheight == self.Size.height:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1732
                height = lastheight
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1733
            # Calculate the real points from the new size, it's important for
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1734
            # keeping a proportionality in the points position with the size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1735
            # duringa resize dragging
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1736
            for i, point in enumerate(self.RealPoints):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1737
                if not (i == 0 and self.StartConnected) and not (i == len(self.Points) - 1 and self.EndConnected):
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1738
                    point[0] = point[0] * width / float(max(lastwidth, 1))
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1739
                    point[1] = point[1] * height / float(max(lastheight, 1))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1740
            # Calculate the correct position of the points from real points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1741
            for i, point in enumerate(self.RealPoints):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1742
                if not (i == 0 and self.StartConnected) and not (i == len(self.Points) - 1 and self.EndConnected):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1743
                    if i == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1744
                        dir = self.StartPoint[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1745
                    elif i == len(self.Points) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1746
                        dir = self.EndPoint[1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1747
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1748
                        dir = (0, 0)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1749
                    realpointx = max(-dir[0] * MIN_SEGMENT_SIZE, min(int(round(point[0])),
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1750
                            width - dir[0] * MIN_SEGMENT_SIZE))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1751
                    realpointy = max(-dir[1] * MIN_SEGMENT_SIZE, min(int(round(point[1])),
208
c70aefcadf66 Bugs with feedback path in View, Controler and Generator fixed
lbessard
parents: 180
diff changeset
  1752
                            height - dir[1] * MIN_SEGMENT_SIZE))
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1753
                    self.Points[i] = wx.Point(minx + x + realpointx, miny + y + realpointy)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1754
            self.StartPoint[0] = self.Points[0]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1755
            self.EndPoint[0] = self.Points[-1]
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1756
            self.GeneratePoints(False)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1757
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1758
    # Moves the wire start point and update the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1759
    def MoveStartPoint(self, point):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1760
        if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1761
            self.StartPoint[0] = point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1762
            self.Points[0] = point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1763
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1764
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1765
    # Changes the wire start direction and update the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1766
    def SetStartPointDirection(self, dir):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1767
        if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1768
            self.StartPoint[1] = dir
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1769
            self.Segments[0] = dir
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1770
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1771
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1772
    # Rotates the wire start direction by an angle of 90 degrees anticlockwise
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1773
    def RotateStartPoint(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1774
        self.SetStartPointDirection((self.StartPoint[1][1], -self.StartPoint[1][0]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1775
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1776
    # Connects wire start point to the connector given and moves wire start point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1777
    # to given point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1778
    def ConnectStartPoint(self, point, connector):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1779
        if point:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1780
            self.MoveStartPoint(point)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1781
        self.StartConnected = connector
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1782
        self.RefreshBoundingBox()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1783
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1784
    # Unconnects wire start point
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1785
    def UnConnectStartPoint(self, delete = False):
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1786
        if delete:
60
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1787
            self.StartConnected = None
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1788
            self.Delete()
60
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1789
        elif self.StartConnected:
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1790
            self.StartConnected.UnConnect(self, unconnect = False)
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1791
            self.StartConnected = None
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1792
            self.RefreshBoundingBox()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1793
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1794
    # Moves the wire end point and update the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1795
    def MoveEndPoint(self, point):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1796
        if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1797
            self.EndPoint[0] = point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1798
            self.Points[-1] = point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1799
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1800
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1801
    # Changes the wire end direction and update the wire points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1802
    def SetEndPointDirection(self, dir):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1803
        if len(self.Points) > 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1804
            self.EndPoint[1] = dir
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1805
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1806
            
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1807
    # Rotates the wire end direction by an angle of 90 degrees anticlockwise
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1808
    def RotateEndPoint(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1809
        self.SetEndPointDirection((self.EndPoint[1][1], -self.EndPoint[1][0]))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1810
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1811
    # Connects wire end point to the connector given and moves wire end point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1812
    # to given point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1813
    def ConnectEndPoint(self, point, connector):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1814
        if point:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1815
            self.MoveEndPoint(point)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1816
        self.EndConnected = connector
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1817
        self.RefreshBoundingBox()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1818
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1819
    # Unconnects wire end point
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1820
    def UnConnectEndPoint(self, delete = False):
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1821
        if delete:
60
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1822
            self.EndConnected = None
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1823
            self.Delete()
60
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1824
        elif self.EndConnected:
ef940f442b8d Bug on wire deletion from a connector fixed
lbessard
parents: 58
diff changeset
  1825
            self.EndConnected.UnConnect(self, unconnect = False)
2
93bc4c2cf376 PLCGenerator finished
lbessard
parents: 0
diff changeset
  1826
            self.EndConnected = None
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1827
            self.RefreshBoundingBox()
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1828
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1829
    # Moves the wire segment given by its index
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1830
    def MoveSegment(self, idx, movex, movey, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1831
        if 0 < idx < len(self.Segments) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1832
            if self.Segments[idx] in (NORTH, SOUTH):
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1833
                start_x = self.Points[idx].x
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1834
                if scaling is not None:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1835
                    movex = round(float(self.Points[idx].x + movex) / float(scaling[0])) * scaling[0] - self.Points[idx].x
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1836
                self.Points[idx].x += movex
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1837
                self.Points[idx + 1].x += movex
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1838
                self.GeneratePoints()
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1839
                if start_x != self.Points[idx].x:
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1840
                    return self.Points[idx].x - start_x, 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1841
            elif self.Segments[idx] in (EAST, WEST):
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1842
                start_y = self.Points[idx].y
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1843
                if scaling is not None:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1844
                    movey = round(float(self.Points[idx].y + movey) / float(scaling[1])) * scaling[1] - self.Points[idx].y
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1845
                self.Points[idx].y += movey
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1846
                self.Points[idx + 1].y += movey
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1847
                self.GeneratePoints()
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  1848
                if start_y != self.Points[idx].y:
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1849
                    return 0, self.Points[idx].y - start_y
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1850
        return 0, 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1851
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1852
    # Adds two points in the middle of the handled segment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1853
    def AddSegment(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1854
        handle_type, handle = self.Handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1855
        if handle_type == HANDLE_SEGMENT:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1856
            segment, dir = handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1857
            pointx = self.Points[segment].x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1858
            pointy = self.Points[segment].y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1859
            if dir[0] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1860
                pointx = (self.Points[segment].x + self.Points[segment + 1].x) / 2
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1861
            if dir[1] != 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1862
                pointy = (self.Points[segment].y + self.Points[segment + 1].y) / 2
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1863
            self.Points.insert(segment + 1, wx.Point(pointx, pointy))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1864
            self.Segments.insert(segment + 1, (dir[1], dir[0]))
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1865
            self.Points.insert(segment + 2, wx.Point(pointx, pointy))
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1866
            self.Segments.insert(segment + 2, dir)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1867
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1868
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1869
    # Delete the handled segment by removing the two segment points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1870
    def DeleteSegment(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1871
        handle_type, handle = self.Handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1872
        if handle_type == HANDLE_SEGMENT:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1873
            segment, dir = handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1874
            for i in xrange(2):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1875
                self.Points.pop(segment)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1876
                self.Segments.pop(segment)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1877
            self.GeneratePoints()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1878
            self.RefreshModel()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1879
            
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1880
    # Method called when a LeftDown event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1881
    def OnLeftDown(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1882
        pos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1883
        # Test if a point have been handled
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1884
        #result = self.TestPoint(pos)
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1885
        #if result != None:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1886
        #    self.Handle = (HANDLE_POINT, result)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1887
        #    self.Parent.SetCursor(wx.StockCursor(wx.CURSOR_HAND))
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1888
        #else:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1889
        # Test if a segment have been handled
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1890
        result = self.TestSegment(pos)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1891
        if result != None:
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1892
            if result[1] in (NORTH, SOUTH):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1893
                self.Parent.SetCursor(wx.StockCursor(wx.CURSOR_SIZEWE))
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1894
            elif result[1] in (EAST, WEST):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1895
                self.Parent.SetCursor(wx.StockCursor(wx.CURSOR_SIZENS))
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1896
            self.Handle = (HANDLE_SEGMENT, result)
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1897
        # Execute the default method for a graphic element
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1898
        else:
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1899
            Graphic_Element.OnLeftDown(self, event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1900
        self.oldPos = pos
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1901
    
80
c798a68c5560 Lots of bugs fixed
lbessard
parents: 64
diff changeset
  1902
    # Method called when a RightUp event has been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1903
    def OnRightUp(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1904
        pos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1905
        # Test if a segment has been handled
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1906
        result = self.TestSegment(pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1907
        if result != None:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1908
            self.Handle = (HANDLE_SEGMENT, result)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1909
            # Popup the menu with special items for a wire
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1910
            self.Parent.PopupWireMenu()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1911
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1912
            # Execute the default method for a graphic element
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1913
            Graphic_Element.OnRightUp(self, event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1914
    
80
c798a68c5560 Lots of bugs fixed
lbessard
parents: 64
diff changeset
  1915
    # Method called when a LeftDClick event has been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1916
    def OnLeftDClick(self, event, dc, scaling):
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1917
        if event.ControlDown():
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1918
            direction = (self.StartPoint[1], self.EndPoint[1])
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1919
            if direction in [(EAST, WEST), (WEST, EAST)]:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1920
                avgy = (self.StartPoint[0].y + self.EndPoint[0].y) / 2
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1921
                if self.StartConnected is not None:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1922
                    startblock = self.StartConnected.GetParentBlock()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1923
                    startblock.Move(0, avgy - self.StartPoint[0].y)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1924
                    startblock.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1925
                else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1926
                    self.MoveStartPoint(wx.Point(self.StartPoint[0].x, avgy))
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1927
                if self.EndConnected is not None:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1928
                    endblock = self.EndConnected.GetParentBlock()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1929
                    endblock.Move(0, avgy - self.EndPoint[0].y)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1930
                    endblock.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1931
                else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1932
                    self.MoveEndPoint(wx.Point(self.EndPoint[0].x, avgy))
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1933
            elif direction in [(NORTH, SOUTH), (SOUTH, NORTH)]:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1934
                avgx = (self.StartPoint[0].x + self.EndPoint[0].x) / 2
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1935
                if self.StartConnected is not None:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1936
                    startblock = self.StartConnected.GetParentBlock()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1937
                    startblock.Move(avgx - self.StartPoint[0].x, 0)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1938
                    startblock.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1939
                else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1940
                    self.MoveStartPoint(wx.Point(avgx, self.StartPoint[0].y))
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1941
                if self.EndConnected is not None:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1942
                    endblock = self.EndConnected.GetParentBlock()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1943
                    endblock.Move(avgx - self.EndPoint[0].x, 0)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1944
                    endblock.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1945
                else:
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1946
                    self.MoveEndPoint(wx.Point(avgx, self.EndPoint[0].y))
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1947
            self.Parent.RefreshBuffer()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1948
        else:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1949
            rect = self.GetRedrawRect()
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1950
            self.ResetPoints()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1951
            self.GeneratePoints()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1952
            self.RefreshModel()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1953
            self.Parent.RefreshBuffer()
155
b695f7459ef6 Removing flickering on Windows
lbessard
parents: 145
diff changeset
  1954
            self.Parent.RefreshRect(self.Parent.GetScrolledRect(rect), False)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1955
        
80
c798a68c5560 Lots of bugs fixed
lbessard
parents: 64
diff changeset
  1956
    # Method called when a Motion event has been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1957
    def OnMotion(self, event, dc, scaling):
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  1958
        pos = GetScaledEventPosition(event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1959
        if not event.Dragging():
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1960
            # Test if a segment has been handled
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1961
            result = self.TestSegment(pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1962
            if result:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1963
                if result[1] in (NORTH, SOUTH):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1964
                    if self.CurrentCursor != 4:
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1965
                        self.CurrentCursor = 4
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1966
                        wx.CallAfter(self.Parent.SetCursor, CURSORS[4])
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1967
                elif result[1] in (EAST, WEST):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1968
                    if self.CurrentCursor != 5:
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1969
                        self.CurrentCursor = 5
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  1970
                        wx.CallAfter(self.Parent.SetCursor, CURSORS[5])
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  1971
                return 0, 0
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1972
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1973
                # Test if a point has been handled
3
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1974
                #result = self.TestPoint(pos)
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1975
                #if result != None:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1976
                #    if result == 0 and self.StartConnected:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1977
                #        self.OverStart = True
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1978
                #    elif result != 0 and self.EndConnected:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1979
                #        self.OverEnd = True
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1980
                #else:
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1981
                #    self.OverStart = False
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1982
                #    self.OverEnd = False
86ccc89d7b0b FBD Blocks and Variables can now be modified and wires can't be unconnected on both sides
lbessard
parents: 2
diff changeset
  1983
                # Execute the default method for a graphic element
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
  1984
                return Graphic_Element.OnMotion(self, event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1985
        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1986
            # Execute the default method for a graphic element
90
2245e8776086 Adding support support for using PLCOpenEditor with Beremiz
lbessard
parents: 80
diff changeset
  1987
            return Graphic_Element.OnMotion(self, event, dc, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1988
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1989
    # Refreshes the wire state according to move defined and handle selected
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
  1990
    def ProcessDragging(self, movex, movey, centered, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1991
        handle_type, handle = self.Handle
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1992
        # A point has been handled
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1993
        if handle_type == HANDLE_POINT:
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1994
            movex = max(-self.Points[handle].x + POINT_RADIUS, movex)
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  1995
            movey = max(-self.Points[handle].y + POINT_RADIUS, movey)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1996
            if scaling is not None:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1997
                movex = round(float(self.Points[handle].x + movex) / float(scaling[0])) * scaling[0] - self.Points[handle].x
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  1998
                movey = round(float(self.Points[handle].y + movey) / float(scaling[1])) * scaling[1] - self.Points[handle].y
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  1999
            # Try to connect point to a connector
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2000
            new_pos = wx.Point(self.Points[handle].x + movex, self.Points[handle].y + movey)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2001
            connector = self.Parent.FindBlockConnector(new_pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2002
            if connector:
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  2003
                if handle == 0 and self.EndConnected != connector and connector.IsCompatible(self.GetEndConnectedType()):
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2004
                    connector.HighlightParentBlock(True)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2005
                    connector.Connect((self, handle))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2006
                    self.SetStartPointDirection(connector.GetDirection())
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2007
                    self.ConnectStartPoint(connector.GetPosition(), connector)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2008
                    pos = connector.GetPosition()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2009
                    movex = pos.x - self.oldPos.x
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2010
                    movey = pos.y - self.oldPos.y
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2011
                    self.Dragging = False
98
ec5d7af033d8 Added support for wire type compatibility check
lbessard
parents: 90
diff changeset
  2012
                elif handle != 0 and self.StartConnected != connector and connector.IsCompatible(self.GetStartConnectedType()):
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2013
                    connector.HighlightParentBlock(True)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2014
                    connector.Connect((self, handle))
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2015
                    self.SetEndPointDirection(connector.GetDirection())
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2016
                    self.ConnectEndPoint(connector.GetPosition(), connector)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2017
                    pos = connector.GetPosition()
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2018
                    movex = pos.x - self.oldPos.x
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2019
                    movey = pos.y - self.oldPos.y
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2020
                    self.Dragging = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2021
                elif handle == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2022
                    self.MoveStartPoint(new_pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2023
                else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2024
                    self.MoveEndPoint(new_pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2025
            # If there is no connector, move the point
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2026
            elif handle == 0:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2027
                if self.StartConnected:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2028
                    self.UnConnectStartPoint()
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2029
                    self.StartConnected.HighlightParentBlock(False)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2030
                self.MoveStartPoint(new_pos)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2031
            else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2032
                if self.EndConnected:
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2033
                    self.EndConnected.HighlightParentBlock(False)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2034
                    self.UnConnectEndPoint()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2035
                self.MoveEndPoint(new_pos)
138
9c74d00ce93e Last bugs on block and wire moving, resizing with cursor fixed
lbessard
parents: 112
diff changeset
  2036
            return movex, movey
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2037
        # A segment has been handled, move a segment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2038
        elif handle_type == HANDLE_SEGMENT:
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2039
            return self.MoveSegment(handle[0], movex, movey, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2040
        # Execute the default method for a graphic element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2041
        else:
165
e464a4e4e06d Adding Font support in Dialog
lbessard
parents: 162
diff changeset
  2042
            return Graphic_Element.ProcessDragging(self, movex, movey, centered, scaling)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2043
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2044
    # Refreshes the wire model
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2045
    def RefreshModel(self, move=True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2046
        if self.StartConnected and self.StartPoint[1] in [WEST, NORTH]:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2047
            self.StartConnected.RefreshParentBlock()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2048
        if self.EndConnected and self.EndPoint[1] in [WEST, NORTH]:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2049
            self.EndConnected.RefreshParentBlock()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2050
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2051
    # Draws the highlightment of this element if it is highlighted
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2052
    def DrawHighlightment(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2053
        dc.SetPen(wx.Pen(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2054
        dc.SetBrush(wx.Brush(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2055
        dc.SetLogicalFunction(wx.AND)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2056
        # Draw the start and end points if they are not connected or the mouse is over them
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2057
        if len(self.Points) > 0 and (not self.StartConnected or self.OverStart):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2058
            dc.DrawCircle(self.Points[0].x, self.Points[0].y, POINT_RADIUS + 2)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2059
        if len(self.Points) > 1 and (not self.EndConnected or self.OverEnd):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2060
            dc.DrawCircle(self.Points[-1].x, self.Points[-1].y, POINT_RADIUS + 2)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2061
        for i in xrange(len(self.Points) - 1):
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2062
            posx = min(self.Points[i].x, self.Points[i + 1].x) - 2
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2063
            posy = min(self.Points[i].y, self.Points[i + 1].y) - 2
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2064
            width = abs(self.Points[i + 1].x - self.Points[i].x) + 5
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2065
            height = abs(self.Points[i + 1].y - self.Points[i].y) + 5
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2066
            dc.DrawRectangle(posx, posy, width, height)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2067
        dc.SetLogicalFunction(wx.COPY)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2068
        if self.StartConnected is not None:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2069
            self.StartConnected.DrawHighlightment(dc)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2070
            self.StartConnected.Draw(dc)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2071
        if self.EndConnected is not None:
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2072
            self.EndConnected.DrawHighlightment(dc)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2073
            self.EndConnected.Draw(dc)
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2074
        
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2075
    # Draws the wire lines and points
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2076
    def Draw(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2077
        Graphic_Element.Draw(self, dc)
222
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  2078
        if self.Valid:
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  2079
            dc.SetPen(wx.BLACK_PEN)
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  2080
        else:
8ce5c2635976 Adding support for underlying type incompatible wire loaded instead of removing them
lbessard
parents: 213
diff changeset
  2081
            dc.SetPen(wx.RED_PEN)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2082
        dc.SetBrush(wx.BLACK_BRUSH)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2083
        # Draw the start and end points if they are not connected or the mouse is over them
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2084
        if len(self.Points) > 0 and (not self.StartConnected or self.OverStart):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2085
            dc.DrawCircle(self.Points[0].x, self.Points[0].y, POINT_RADIUS)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2086
        if len(self.Points) > 1 and (not self.EndConnected or self.OverEnd):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2087
            dc.DrawCircle(self.Points[-1].x, self.Points[-1].y, POINT_RADIUS)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2088
        # Draw the wire lines and the last point (it seems that DrawLines stop before the last point)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2089
        dc.DrawLines(self.Points)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2090
        dc.DrawPoint(self.Points[-1].x, self.Points[-1].y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2091
        # Draw the segment selected in red
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2092
        if self.SelectedSegment != None:
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2093
            dc.SetPen(wx.RED_PEN)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2094
            dc.DrawLine(self.Points[self.SelectedSegment].x, self.Points[self.SelectedSegment].y,
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2095
                        self.Points[self.SelectedSegment + 1].x, self.Points[self.SelectedSegment + 1].y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2096
            if self.SelectedSegment == len(self.Segments) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2097
                dc.DrawPoint(self.Points[-1].x, self.Points[-1].y)
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2098
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2099
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2100
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2101
#                           Graphic comment element
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2102
#-------------------------------------------------------------------------------
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2103
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2104
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2105
Class that implements a comment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2106
"""
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2107
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2108
class Comment(Graphic_Element):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2109
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2110
    # Create a new comment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2111
    def __init__(self, parent, content, id = None):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2112
        Graphic_Element.__init__(self, parent)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2113
        self.Id = id
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2114
        self.Content = content
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2115
        self.Pos = wx.Point(0, 0)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2116
        self.Size = wx.Size(0, 0)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2117
    
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  2118
    # Make a clone of this comment
162
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
  2119
    def Clone(self, parent, id = None, pos = None):
e746ff4aa8be Bug on Element Paste fixed
lbessard
parents: 155
diff changeset
  2120
        comment = Comment(parent, self.Content, id)
145
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2121
        if pos is not None:
4fb225afddf4 Adding scaling
lbessard
parents: 144
diff changeset
  2122
            comment.SetPosition(pos.x, pos.y)
112
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  2123
        comment.SetSize(self.Size[0], self.Size[1])
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  2124
        return comment
317148fc1225 Adding support for block copy
lbessard
parents: 110
diff changeset
  2125
    
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2126
    # Method for keeping compatibility with others
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2127
    def Clean(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2128
        pass
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2129
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2130
    # Delete this comment by calling the corresponding method
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2131
    def Delete(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2132
        self.Parent.DeleteComment(self)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2133
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2134
    # Refresh the comment bounding box
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2135
    def RefreshBoundingBox(self):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2136
        self.BoundingBox = wx.Rect(self.Pos.x, self.Pos.y, self.Size[0] + 1, self.Size[1] + 1)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2137
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2138
    # Changes the comment size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2139
    def SetSize(self, width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2140
        self.Size.SetWidth(width)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2141
        self.Size.SetHeight(height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2142
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2143
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2144
    # Returns the comment size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2145
    def GetSize(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2146
        return self.Size.GetWidth(), self.Size.GetHeight()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2147
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2148
    # Returns the comment minimum size
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2149
    def GetMinSize(self):
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2150
        dc = wx.ClientDC(self.Parent)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2151
        min_width = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2152
        min_height = 0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2153
        # The comment minimum size is the maximum size of words in the content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2154
        for line in self.Content.splitlines():
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2155
            for word in line.split(" "):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2156
                wordwidth, wordheight = dc.GetTextExtent(word)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2157
                min_width = max(min_width, wordwidth)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2158
                min_height = max(min_height, wordheight)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2159
        return min_width + 20, min_height + 20
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2160
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2161
    # Changes the comment position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2162
    def SetPosition(self, x, y):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2163
        self.Pos.x = x
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2164
        self.Pos.y = y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2165
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2166
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2167
    # Changes the comment content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2168
    def SetContent(self, content):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2169
        self.Content = content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2170
        min_width, min_height = self.GetMinSize()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2171
        self.Size[0] = max(self.Size[0], min_width)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2172
        self.Size[1] = max(self.Size[1], min_height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2173
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2174
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2175
    # Returns the comment content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2176
    def GetContent(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2177
        return self.Content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2178
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2179
    # Returns the comment position
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2180
    def GetPosition(self):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2181
        return self.Pos.x, self.Pos.y
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2182
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2183
    # Moves the comment
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2184
    def Move(self, dx, dy, connected = True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2185
        self.Pos.x += dx
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2186
        self.Pos.y += dy
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2187
        self.RefreshBoundingBox()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2188
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2189
    # Resizes the comment with the position and the size given
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2190
    def Resize(self, x, y, width, height):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2191
        self.Move(x, y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2192
        self.SetSize(width, height)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2193
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2194
    # Method called when a RightUp event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  2195
    def OnRightUp(self, event, dc, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2196
        # Popup the default menu
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2197
        self.Parent.PopupDefaultMenu()
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2198
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2199
    # Refreshes the comment model
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2200
    def RefreshModel(self, move=True):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2201
        self.Parent.RefreshCommentModel(self)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2202
    
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2203
    # Method called when a LeftDClick event have been generated
27
dae55dd9ee14 Current developping version
lbessard
parents: 5
diff changeset
  2204
    def OnLeftDClick(self, event, dc, scaling):
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2205
        # Edit the comment content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2206
        self.Parent.EditCommentContent(self)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2207
    
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2208
    # Draws the highlightment of this element if it is highlighted
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2209
    def DrawHighlightment(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2210
        dc.SetPen(wx.Pen(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2211
        dc.SetBrush(wx.Brush(HIGHLIGHTCOLOR))
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2212
        dc.SetLogicalFunction(wx.AND)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2213
        polygon = [wx.Point(self.Pos.x - 2, self.Pos.y - 2), 
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2214
                   wx.Point(self.Pos.x + self.Size[0] - 8, self.Pos.y - 2),
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2215
                   wx.Point(self.Pos.x + self.Size[0] + 2, self.Pos.y + 8),
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2216
                   wx.Point(self.Pos.x + self.Size[0] + 2, self.Pos.y + self.Size[1] + 2),
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2217
                   wx.Point(self.Pos.x - 2, self.Pos.y + self.Size[1] + 2)]
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2218
        dc.DrawPolygon(polygon)
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2219
        dc.SetLogicalFunction(wx.COPY)
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2220
        
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2221
    # Draws the comment and its content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2222
    def Draw(self, dc):
144
b67a5de5a24a Adding optimization on Viewer redrawing
lbessard
parents: 140
diff changeset
  2223
        Graphic_Element.Draw(self, dc)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2224
        dc.SetPen(wx.BLACK_PEN)
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2225
        dc.SetBrush(wx.WHITE_BRUSH)
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2226
        # Draws the comment shape
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2227
        polygon = [wx.Point(self.Pos.x, self.Pos.y), 
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2228
                   wx.Point(self.Pos.x + self.Size[0] - 10, self.Pos.y),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2229
                   wx.Point(self.Pos.x + self.Size[0], self.Pos.y + 10),
140
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2230
                   wx.Point(self.Pos.x + self.Size[0], self.Pos.y + self.Size[1]),
06d28f03f6f4 Adding highlighting on group or element when mouse is over
lbessard
parents: 138
diff changeset
  2231
                   wx.Point(self.Pos.x, self.Pos.y + self.Size[1])]
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2232
        dc.DrawPolygon(polygon)
64
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2233
        lines = [wx.Point(self.Pos.x + self.Size[0] - 10, self.Pos.y),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2234
                 wx.Point(self.Pos.x + self.Size[0] - 10, self.Pos.y + 10),
dd6f693e46a1 Cleaning code for using only wxPython 2.6 class naming
lbessard
parents: 60
diff changeset
  2235
                 wx.Point(self.Pos.x + self.Size[0], self.Pos.y + 10)]
0
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2236
        dc.DrawLines(lines)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2237
        # Draws the comment content
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2238
        y = self.Pos.y + 10
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2239
        for line in self.Content.splitlines():
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2240
            first = True
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2241
            words = line.split(" ")
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2242
            for i, word in enumerate(words):
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2243
                if first:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2244
                    test = word
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2245
                else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2246
                    test = linetext + " " + word
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2247
                wordwidth, wordheight = dc.GetTextExtent(test)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2248
                if y + wordheight > self.Pos.y + self.Size[1] - 10:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2249
                    break
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2250
                if wordwidth < self.Size[0] - 20 and i < len(words) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2251
                    linetext = test
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2252
                    first = False
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2253
                else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2254
                    if wordwidth < self.Size[0] - 20 and i == len(words) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2255
                        dc.DrawText(test, self.Pos.x + 10, y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2256
                    else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2257
                        dc.DrawText(linetext, self.Pos.x + 10, y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2258
                        if i == len(words) - 1:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2259
                            y += wordheight + 5
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2260
                            if y + wordheight > self.Pos.y + self.Size[1] - 10:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2261
                                break
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2262
                            dc.DrawText(word, self.Pos.x + 10, y)
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2263
                        else:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2264
                            linetext = word
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2265
                    y += wordheight + 5
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2266
            if y + wordheight > self.Pos.y + self.Size[1] - 10:
b622defdfd98 PLCOpenEditor initial commit. 31/01/07.
etisserant
parents:
diff changeset
  2267
                break