961b3c0396
Stable working state after a long iteration session. The plugin now supports:
- Multi-Surface-Select für alle Element-Typen (Türen/Fenster/Treppen/Tragwerk)
- Wand-Z-Drag → unbound mode (UK/OK-Override, Wand vom Geschoss entkoppelt)
- Wand-Z-Drag nimmt verknüpfte Öffnungen mit (Brüstung += delta_z via Idle-Pfad)
- Öffnungs-XY-Drag snapt direktional auf Wand-Tangente
- Öffnungs-Z-Drag passt Brüstung an (Fenster sofort sync, Tür deferred)
- Wand-Delete kaskadiert Öffnungen (deferred via Idle, robust gegen _Rotate/_Move)
- Source-Cascade beim Öffnungs-Delete (deferred analog Wand-Kaskade)
- Listener-Cleanup robust gegen _reset_panels.py Reload (Refs in
_dossier_runtime_event_refs gespeichert, vor Re-Install deregistriert)
- _count_same_id_type filtert IsDeleted (verhindert Source-Duplikat-Bug bei Move)
- Frontend: Brüstungs-Slider für Tür ("Schwelle"), Flügel-Block nur bei Fenster
Plus aus früherer Phase dieser Session:
- Dossier-Launcher Auto-Load via Rhinos StartupCommands-XML
- Default-Pfad zeigt auf gebundeltes startup.py (out-of-the-box für neue User)
- Splash-Window beim Plugin-Load mit native macOS rounded corners
- Diverse Launcher-Verbesserungen (Brüstungs-Default, tauri.conf, capabilities)
Known issue: bei Multi-Select-Move mit vielen Sub-Volumen kann sporadisch
"Unable to transform" auftreten (Rhinos Move-Operation kollidiert mit Wand-
Regen). Tür-spezifischer Defer-Pfad mildert das, Fenster läuft sync.
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
52 lines
1.3 KiB
Python
52 lines
1.3 KiB
Python
#! python 3
|
|
"""
|
|
clean_layers.py
|
|
Loescht Rhino-Standardlayer (Default, Layer 01-05 usw.)
|
|
die keine Objekte enthalten und nicht zum RhinoPanel gehoeren.
|
|
Ausfuehren via _RunPythonScript.
|
|
"""
|
|
import re
|
|
import Rhino
|
|
import scriptcontext as sc
|
|
|
|
sc.sticky["rhinopanel_registered"] = False
|
|
sc.sticky["rhinopanel_form"] = None
|
|
|
|
doc = Rhino.RhinoDoc.ActiveDoc
|
|
|
|
PROTECTED = {
|
|
"10_grundrisse", "20_schnitte", "30_ansichten",
|
|
"00_raster", "01_vermessung", "40_situation",
|
|
"90_referenzen", "99_konstruktion",
|
|
}
|
|
|
|
pattern = re.compile(r'^(default|layer\s*0*\d+)$', re.IGNORECASE)
|
|
|
|
gone = []
|
|
skip = []
|
|
|
|
for i in range(doc.Layers.Count - 1, -1, -1):
|
|
layer = doc.Layers[i]
|
|
root = layer.FullPath.split("::")[0].strip().lower()
|
|
if root in PROTECTED:
|
|
continue
|
|
if not pattern.match(layer.Name.strip()):
|
|
continue
|
|
try:
|
|
if doc.Layers.Delete(i, True):
|
|
gone.append(layer.Name)
|
|
else:
|
|
skip.append(layer.Name)
|
|
except Exception:
|
|
skip.append(layer.Name)
|
|
|
|
doc.Views.Redraw()
|
|
|
|
if gone:
|
|
print("[clean_layers] Geloescht: {}".format(", ".join(gone)))
|
|
else:
|
|
print("[clean_layers] Nichts geloescht (schon sauber?)")
|
|
if skip:
|
|
print("[clean_layers] Uebersprungen (Objekte drauf): {}".format(", ".join(skip)))
|
|
print("[clean_layers] Panel-Sticky zurueckgesetzt")
|