Тема: Как определить выделенный на экране объект?

У меня заработала такая конструкция. Возможно, код и неправильный, но работает.

Private Sub AcadDocument_BeginCommand(ByVal CommandName As String)
    If CommandName = "EATTEDIT" Then
        Edit_kontakts
    End If
End Sub
Sub Edit_kontakts()
    Set ssetObj = ThisDrawing.ActiveSelectionSet
    Set elem = ssetObj.Item(0)
    b = elem.GetAttributes
    'd = b(.TagString.Count
    If StrComp(elem.Name, "Kontakt", 1) = 0 Then
        MsgBox "Редактируем контакты"
        EditKonForm.Show
    End If
End Sub

Re: Как определить выделенный на экране объект?

Все замечательно. Ты последовал одному из моих советов и стал использовать "реакторы" (это мое название для себя, код, который отслкживает действия) но использование ThisDrawing.Utility.GetEntity в данном случае предпочтительнее, ты сможешь проверить что тебе показали. Или можно использовать фильтр, чтоб выделяли только блоки а потом перебирать эти блоки в селектион сет и изменять атрибуты. Т.е. блоки скопом.

Re: Как определить выделенный на экране объект?

Как всегда, очень нужно...
ЗАДАЧА: сделать, чтобы при редактировании атрибутов блока с определенным именем вылетала моя форма вместо стандартной.
ВОПРОС: как определить имя блока, выделенного на чертеже до начала работы программы?

Re: Как определить выделенный на экране объект?

Может имеет смысл написать макрос так, что-бы он сначала просил выделить блок? А потом производить все манипуляции? Мне кажется это логичнее.

Re: Как определить выделенный на экране объект?

Тогда чтобы поменять атрибуты, нужно запускать макрос, выделять блок, и только тогда редактировать.
Я хочу сделать, чтобы при двойном щелчке по атрибуту открывалась моя форма. С BeginCommand "ATTEDIT" вроде бы разобрался, а вот имя блока что-то никак не проконтролировать.

Re: Как определить выделенный на экране объект?

Смотри в примерах. Может не понял тебя. Там есть примеры кода, на действия производимые в Акаде, т.н. "реакторы". Код на VB, который отслеживает действия такие как закрытие, сворачивание окна и прочее. Танцуй от этого, т.е. действие - макрос отреагировал на него, форму запустил или еще что-то, а потом пусть макрос сам попросит выделить блок. Выделишь блок и получишь и имя и все все все. Чуть позже прокоментирую.

Re: Как определить выделенный на экране объект?

' Этот код помести в модуль: ThisDrawing
Private Sub AcadDocument_BeginDoubleClick(ByVal PickPoint As Variant)
'Тебе нужно вот ЭТО!!!
       ThisDrawing.ActiveSelectionSet.Item (0)
End Sub

Re: Как определить выделенный на экране объект?

А определить имя блока, выделенного на чертеже до начала работы программы, я так понимаю, совсем не реально? Обидно будет.
СЕРГЕЙ как ты предлагаешь, получается, то я щелкаю на блоке, запускается программа и просит выделить тот блок, который я уже выделял. Неприятно. В моей задаче частично теряется смысл - в моем случае тогда проще через стандартное окно (не так много атрибутов).

Re: Как определить выделенный на экране объект?

ДИМА, подскажи еще, как сделать проверку на имя блока.
ПОЖАЛУЙСТА...

Re: Как определить выделенный на экране объект?

ThisDrawing.ActiveSelectionSet.item(0).name

Re: Как определить выделенный на экране объект?

ДИМА запустил такой код:

Private Sub AcadDocument_BeginDoubleClick(ByVal PickPoint As Variant)
ThisDrawing.ActiveSelectionSet.Item (0)
If ThisDrawing.ActiveSelectionSet.Item(0).Name = "Kontakt" Then
    MsgBox "Форма"
End If
End Sub

Вылетела ошибка:
Run-time error '-2147467259 (80004005)':
Method 'Item' of obgect 'IAcadSelectionSet' failed
Что я не так сделал?

Re: Как определить выделенный на экране объект?

> Gorez
В данном конретном случае стоит использовать это -
ThisDrawing.Utility.GetEntity
Разберись сам как это должно работать. Небольшая подсказка. smile

Sub Example_GetEntity()
    ' This example creates several objects in model space. It then
    ' prompts the user to select an object. The example continues to
    ' have the user select objects until the user selects in empty space.
    ' Create a Ray object in model space
    Dim rayObj As AcadRay
    Dim basePoint(0 To 2) As Double
    Dim SecondPoint(0 To 2) As Double
    basePoint(0) = 3#: basePoint(1) = 3#: basePoint(2) = 0#
    SecondPoint(0) = 1#: SecondPoint(1) = 3#: SecondPoint(2) = 0#
    Set rayObj = ThisDrawing.ModelSpace.AddRay(basePoint, SecondPoint)
    ' Create a polyline object in model space
    Dim plineObj As AcadLWPolyline
    Dim points(0 To 5) As Double
    points(0) = 3: points(1) = 7
    points(2) = 9: points(3) = 2
    points(4) = 3: points(5) = 5
    Set plineObj = ThisDrawing.ModelSpace.AddLightWeightPolyline(points)
    plineObj.Closed = True
    ' Create a line object in model space
    Dim lineObj As AcadLine
    Dim startPoint(0 To 2) As Double
    Dim endPoint(0 To 2) As Double
    startPoint(0) = 0: startPoint(1) = 0: startPoint(2) = 0
    endPoint(0) = 2: endPoint(1) = 2: endPoint(2) = 0
    Set lineObj = ThisDrawing.ModelSpace.AddLine(startPoint, endPoint)
    ' Create a circle object in model space
    Dim circObj As AcadCircle
    Dim centerPt(0 To 2) As Double
    Dim radius As Double
    centerPt(0) = 20: centerPt(1) = 30: centerPt(2) = 0
    radius = 3
    Set circObj = ThisDrawing.ModelSpace.AddCircle(centerPt, radius)
    ' Create an ellipse object in model space
    Dim ellObj As AcadEllipse
    Dim majAxis(0 To 2) As Double
    Dim center(0 To 2) As Double
    Dim radRatio As Double
    center(0) = 5#: center(1) = 5#: center(2) = 0#
    majAxis(0) = 10: majAxis(1) = 20#: majAxis(2) = 0#
    radRatio = 0.3
    Set ellObj = ThisDrawing.ModelSpace.AddEllipse(center, majAxis, radRatio)
    ZoomAll
    ' Begin the selection
    Dim returnObj As AcadObject
    Dim basePnt As Variant
    On Error Resume Next
    ' The following example waits for a selection from the user
RETRY:
    ThisDrawing.Utility.GetEntity returnObj, basePnt, "Select an object"
    If Err <> 0 Then
        Err.Clear
        MsgBox "Good Bye.", , "GetEntity Example"
        Exit Sub
    Else
        returnObj.Color = acRed
        returnObj.Update
        MsgBox "The object type is: " & returnObj.EntityName, , "GetEntity Example"
        returnObj.Color = acByLayer
        returnObj.Update
    End If
    GoTo RETRY
End Sub

Х ее знает может я задау не понял.

Re: Как определить выделенный на экране объект?

ThisDrawing.Utility.GetEntity я еще не пробовал. Займусь.

Re: Как определить выделенный на экране объект?

Тебе необходимо будет организовать проверку чего выделяют. Т.е. если вместо блока выделили арку или текст посылать выделять до тех пор пока блок не выделят и обработчик ошибок нормальный сделать скажем если Esc начнут нажимать и все такое.

Re: Как определить выделенный на экране объект?

Gorez, добавь к своему получившемуся коду всего одну строчку (которую советовал Дима) и получишь то, что хотел:
Private Sub AcadDocument_BeginCommand(ByVal CommandName As String)
'********************** Вот строка *****************
ThisDrawing.ActiveSelectionSet.Item (0)
'чтобы знать, что выделено в текущий момент
'если с .Item(0) - то только первый примитив из текущего набора
'если без .Item(0) - полный набор примитивов, выделенных в текущий момент.
    If CommandName = "EATTEDIT" Then
        Edit_kontakts
    End If
End Sub

Re: Как определить выделенный на экране объект?

Пока работало так, как написал.
Теперь буду модернизировать.
Спасибо за совет.