/** Liest neue Knotendaten ein. Liefert true, wenn erfolgreich */
  public boolean einlesen() {
    try {
      dx = Fkt.holZahl(felddx.getText());
      dz = Fkt.holZahl(felddz.getText());
      stabnr = Integer.parseInt(feldStabnr.getText());
      F = Fkt.holZahl(feldN.getText());
    } catch (IllegalArgumentException e) {
      System.out.println(e.toString());
      return false;
    }
    if (stabnr <= 0 || stabnr > Stabliste.size()) {
      System.out.println(tr("Stabexistiertnicht"));
      return false;
    }

    if (dx == 0 && dz == 0) return false;

    vektor[0] = dx;
    vektor[1] = dz;
    return true;
  }
  /** Creates new form clKnotenDialog */
  public clguiFindeOrt(
      int p_nr, LinkedList knliste, LinkedList stliste, Fachwerk.treillis parent, Locale lc) {
    super(parent, "Knotenposition suchen", true);
    nr = p_nr;
    Knotenliste = knliste;
    Stabliste = stliste;
    kn = (clKnoten) Knotenliste.get(p_nr - 1);

    // übersetzen
    locale = lc;
    addinsRB = ResourceBundle.getBundle("Fachwerk/locales/gui-addins", locale);
    if (addinsRB == null) {
      System.err.println("FEHLER: gui-addins für " + locale.toString());
    }

    // Ausgangskoordinaten merken
    ursprKoord[0] = kn.getX();
    ursprKoord[1] = kn.getZ();
    parentfw = parent;

    // Knoteninfos einleisen
    // Knoten-Nr
    nrstr = Integer.toString(nr);
    // bisherige Koord
    xstr = Double.toString(kn.getX());
    zstr = Double.toString(kn.getZ());

    // Falls der Knoten belastet ist: Lastrichtung vorschlagen
    if (kn.getLx() != 0 || kn.getLz() != 0) {
      double L[] = new double[2];
      L[0] = Math.abs(kn.getLx());
      L[1] = Math.abs(kn.getLz());
      double normierung = Fkt.max(L);
      dxstr = Double.toString(kn.getLx() / normierung);
      dzstr = Double.toString(kn.getLz() / normierung);
    }

    initComponents();
    felddx.setText(dxstr);
    felddz.setText(dzstr);
    übersetzen();
    pack();
    zentriere(parent);
    setVisible(true);
  }
  public int print(Graphics graphics, PageFormat pageformat, int pageIndex)
      throws PrinterException {
    if (pageIndex >= 1) return Printable.NO_SUCH_PAGE;

    this.pf = pageformat;
    g = (Graphics2D) graphics;
    g.scale(printskal, printskal);

    // auf den sichtbaren Bereich ausrichten
    g.translate(pf.getImageableX() / printskal, pf.getImageableY() / printskal);

    // -----------------
    // 1. Teil: Graphik
    // -----------------
    antVertikal = antGraph;
    antHorizontal = 1.0d;
    schriftgrStd = (int) (schriftgrGraph / printskal);

    double zusRandabst = 2d * schriftgrText;
    if (MIT_Lasten || MIT_Auflagerkräften) zusRandabst = maxPfeil;

    // -----------------------------
    // Intermezzo: Massstab abfragen
    // -----------------------------
    if (!MASSSTABABGEFRAGT) {
      if (ZOOMALL) koord = new clKoord(ZoomPkt1, ZoomPkt2, this, zusRandabst);
      else koord = new clKoord(ZoomPkt1, ZoomPkt2, this);
      // maximalen Massstab bestimmen
      double minzoomfaktor = koord.m(dpi / zoll);

      // Massstab abfragen
      clPrintGraphDialog dialog = new clPrintGraphDialog(parent, minzoomfaktor, locale);
      if (dialog.abgebrochen())
        throw new PrinterException(
            tr("druckenabgebrochen")); // return Printable.NO_SUCH_PAGE; // abgebrochen
      einheit = dialog.getEinheit();
      mst = dialog.getMst();
      // debug
      // mst = 100d;
      MASSSTABABGEFRAGT = true;
      // debug
      // System.out.println("minzoomfaktor " + Fkt.nf(minzoomfaktor,1));
      // System.out.println("Massstab 1:" + Fkt.nf(mst,1) + "  Einheit " + Fkt.nf(einheit,3) + "m");
    }
    koord = new clKoord(ZoomPkt1, ZoomPkt2, this, true, einheit * (dpi / zoll) / mst);
    // debug
    // System.out.println("mst " + Fkt.nf(mst,1));

    g.setPaint(Color.black);

    if (Kn != null) {
      if (MIT_Hintergrund) darstellenHintergrund();
      darstellenFachwerk(true);
      if (MIT_KnNr) darstellenKnNr();
      if (MIT_StabNr) darstellenStabNr();
      if (MIT_Lasten) darstellenLasten(MIT_Stabkräften);
      if (MIT_Auflagerkräften) darstellenAuflagerkräfte(MIT_Stabkräften);
      if (MIT_Stabkräften) darstellenStabkräfte();
      if (MIT_Mechanismus) darstellenMechanismus();
    }

    // -------------------------
    // 2. Teil: Text
    // -------------------------
    g.translate(0d, antGraph * pf.getImageableHeight() / printskal);
    antVertikal = antTxt;
    antHorizontal = 1.0d;
    double Feldhöhe = antVertikal * pf.getImageableHeight() / printskal;
    double Feldbreite = antHorizontal * pf.getImageableWidth() / printskal;
    int anzmöglzeilen = 2; // mind. eine Zeile am Schluss freilassen
    int anzmöglbuchst = 30;
    int schriftgr =
        schriftskal(
            Feldhöhe, Feldbreite, anzmöglzeilen, anzmöglbuchst, (int) (schriftgrText / printskal));
    float za = (float) faktorza * (float) schriftgr;
    g.setFont(new Font("Monospaced", Font.PLAIN, schriftgr));

    // Zoomfaktor bestimmen
    double zoomfaktor = koord.m(dpi / zoll) * einheit;
    g.drawString("1 : " + Fkt.nf(zoomfaktor, 1), 0f, (float) schriftgr + 1f * za);

    // drucken
    paint(g);
    // schongedruckt = true;
    return Printable.PAGE_EXISTS;
  }