Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Rund um AutoCAD
  vba-code für schraffur/solid

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte
  
PNY präsentiert die neue NVIDIA RTX A400 und die A1000 Grafikkarte, eine Pressemitteilung
Autor Thema:  vba-code für schraffur/solid (1006 mal gelesen)
jobau
Mitglied
Bauingenieur


Sehen Sie sich das Profil von jobau an!   Senden Sie eine Private Message an jobau  Schreiben Sie einen Gästebucheintrag für jobau

Beiträge: 209
Registriert: 21.01.2003

erstellt am: 28. Mrz. 2003 11:40    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

hallo zusammen,
ich lass mir mit vba für autocad 2002 längsschnitte (für straßen)
zeichnen. u.a. werden auch viertel-kreise in einer schleife mit
schraffur/solid farbig ausgefüllt. jetzt hab ich das problem, dass
ich später die schraffur nur komplett bearbeiten kann und nicht zb.
nur einen viertel-kreis löschen kann. weiss jemand, wie ich das
problem umgehen kann.

ps: bin vba anfänger und jetz im wochenende. also antwort hat zeit
bis montag....

danke
jörg


hier noch der prog-code (ausschnitt):

'**********************************************************
    'Wechselpunkte ausfüllen
   
    Dim hatchObj As AcadHatch
    Dim patternName As String
    Dim PatternType As Long
    Dim bAssociativity As Boolean
   
    patternName = "SOLID"
    PatternType = 0

    bAssociativity = True
    Set hatchObj = ThisDrawing.ModelSpace.AddHatch(PatternType, patternName, bAssociativity)
    'Dim arcObj As AcadArc
    Dim outerLoop(0 To 2) As AcadEntity

    For i = 1 To n
        If bez(i) = "TS" Or bez(i) = "START" Then
        TSpunkt = ts(i)
        Abstand = abst(i)
        neigung = m(i)
        End If
       
    mth(i) = (TSpunkt + neigung / 100 * Abstand / 2 - ursprung) * 10    'höhe bei hälfte                                                            'Neigung,ausgerichtet
    mt(i) = TSpunkt + neigung / 100 * Abstand                            'höhe bei nächstem TS
    mm(i) = Atn(10 * (mt(i) - TSpunkt) / Abstand)                    'neigung ausgerichtet
   
    'MsgBox (bez(i) & " / " & mm(i))
   
    'If bez(i) = "TS" Or bez(i) = "START" Then
    If bez(i) = "TS" Then
    GoTo 105:
    Else
    GoTo 1005:
    End If
105:
   
    m1 = mm(i) * 10
   
    mtt = 1 + m1 / 100 * 50
    mm1 = mm(i) 'Atn(10 * (mtt - 1) / 50)
    center(0) = s(i): center(1) = (ts(i) - ursprung + 1.5) * 10: _
    center(2) = 0#
    radius = 1
    startAngle = mm1 '+ 3.141592
    endAngle = 0.5 * 3.141592
    Set arcObj = ThisDrawing.ModelSpace.AddArc _
    (center, radius, startAngle, endAngle)
   
    Set outerLoop(0) = arcObj
    Set outerLoop(1) = ThisDrawing.ModelSpace.AddLine _
    (outerLoop(0).startPoint, arcObj.center)
    Set outerLoop(2) = ThisDrawing.ModelSpace.AddLine _
    (outerLoop(0).endPoint, arcObj.center)
   
    hatchObj.AppendOuterLoop (outerLoop)
   
    m11 = mm(i - 1) * 10
    'MsgBox (m11)
    mtt = 1 + m11 / 100 * 50
    mm11 = mm(i - 1) 'Atn(10 * (mtt - 1) / 50)
    center(0) = s(i): center(1) = (ts(i) - ursprung + 1.5) * 10: _
    center(2) = 0#
    radius = 1
    startAngle = mm11 + 3.141592
    endAngle = 1.5 * 3.141592
    Set arcObj = ThisDrawing.ModelSpace.AddArc _
    (center, radius, startAngle, endAngle)
   
    Set outerLoop(0) = arcObj
    Set outerLoop(1) = ThisDrawing.ModelSpace.AddLine _
    (outerLoop(0).startPoint, arcObj.center)
    Set outerLoop(2) = ThisDrawing.ModelSpace.AddLine _
    (outerLoop(0).endPoint, arcObj.center)
   
    hatchObj.AppendOuterLoop (outerLoop)
   
1005:
Next i

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Bernd Cuder
Mitglied
Selbständig


Sehen Sie sich das Profil von Bernd Cuder an!   Senden Sie eine Private Message an Bernd Cuder  Schreiben Sie einen Gästebucheintrag für Bernd Cuder

Beiträge: 692
Registriert: 10.07.2002

AutoCAD 2002/2004/2005
unter Windows 2000
Professional SP3
PIV 3.4GHz 1024MB
NVIDIA GeForce FX Go5700

erstellt am: 28. Mrz. 2003 22:08    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für jobau 10 Unities + Antwort hilfreich

Du erstellst eine Schraffur im Loop,
dann ist es auch eine Schraffur, wenn
du jedesmal eine Neue erzeugen würdest,
wären es auch einzelne Schraffuren, und
damit getrennt bearbeitbar.

------------------
Bernd Cuder
Cad&Co makes CAD easy - z.B. Applikation für lineare Bemaßung

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

JosefG
Mitglied
Bauzeichner (Hoch- u. Tiefbau)


Sehen Sie sich das Profil von JosefG an!   Senden Sie eine Private Message an JosefG  Schreiben Sie einen Gästebucheintrag für JosefG

Beiträge: 127
Registriert: 14.04.2003

erstellt am: 17. Sep. 2003 22:56    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für jobau 10 Unities + Antwort hilfreich

Hallo Jörg!

Bin erst heute auf Deine Anzeige gestoßen. Wenn ich es richtig interpretiere, hast Du Dir ein Lisp-Programm für Längsschnitte geschrieben. Ich suche schon seit längerer Zeit Lisp-Programme für diesen Bereich.
Ist es möglich, dass Du mir Dein Programm zur Verfügung stellst?

Danke und Gruß
Josef

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2024 CAD.de | Impressum | Datenschutz