vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
sevDataGrid - Gönnen Sie Ihrem SQL-Kommando diesen krönenden Abschluß!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

Fortgeschrittene Programmierung
Raster 80 * 40 anzeigen - Milimetergenau anzeigen und steuern 
Autor: Inge
Datum: 12.08.08 09:52

Hallo,

arbeite mit VB 6.0
ich möchte in einem Formular ein Punkteraster 100 punkte * 40 punkte ausgegeben werden. (genau wie in der Entwurfsansicht)(Waagrecht 100 Punkte; Senkrecht 40 Punkte)
Im Formular sollen die Punkte exakte Positionsangaben sein.
Die Punkte sollen waagrecht alle 3 mm auseinander, und senkrecht alle 0,6 mm auseinander liegen.
Wenn der Benutzer auf einen Punkt klickt, soll die genaue Positionsangabe ausgegeben werden.

Es sollen auch Zahlen von 1 -100 (waagrecht) und 1-40 (senkrecht) erscheinen.

Kennt jemand ein fertiges Objekt, das so etwas realisiert oder muß man die mit FOR-Schleifen regeln.

Meine Lösung wäre folgende - jedoch ist hierbei die mm Angabe nicht berücksichtigt, da VB in Twips rechnet.

Geht dies auch eleganter mit einem vorgefertigtem Objekt oder ist die Lösung ausschließlich im Erzeugen einer eigenen Grafik.

Mein bisheriger Vorschlag:
Labelfelder werden dynamisch erzeugt; Labelfelder für Zahlen; Labelfelder mit _
  '+' Zeichen
FOR-Schleife mit Waagrechten Punkte in der eine FOR-Schleife mit Senkrechten _
Punkten integriert ist.
[u]Aber wie kann ich die Zahlenlabel und Punktlabel milimetergenau ausrichten?


Public Sub Raster()
Dim i As Integer, j As Integer, Z As Integer, hoehe As Integer, Weite As _
  Integer, X As Integer 
Dim Y As Integer
 
max_X = 40
max_Y = 100
hoehe = (frmVorschau.Height - 200) / max_X
Weite = (frmVorschau.Width - 200) / max_Y
    'Zahlenhorizontale erzeugen
For i = 1 To max_Y
    Load lblZahl(i)
    With lblZahl(i)
        If i = 1 Then
            .Top = 80
            .Left = 250
            .Caption = i
        Else
            .Top = 80
            .Left = lblZahl(i - 1).Left + 8 + Weite
            Debug.Print i & "-" & .Left & "  ";
        End If
        If i Mod 5 = 0 Then
            .Caption = i 
        End If
        .Visible = True
    End With
Next
'"X-Zahlen"
For j = 1 To max_X
    Load lblZahl(i)
    With lblZahl(i)
        If j = 1 Then
            .Top = 150
            .Left = 80
            .Caption = j
        Else
            .Left = 80
            .Top = lblZahl(i - 1).Top + 6 + hoehe           
        End If
        If i Mod 5 = 0 Then
            .Caption = j
        End If
        .Visible = True
    End With
    i = i + 1
Next
 
Z = 1
Y = 1
 
lblPunkt(0).Top = 240
lblPunkt(0).Left = 250
For i = 0 To max_Y
    If i > 0 Then
        Load lblPunkt(Z)
        With lblPunkt(Z)
            .Top = 240
            .Left = lblPunkt(Z - max_X).Left + Weite
            .Visible = True
        End With
        Z = Z + 1
    End If
    For j = 1 To max_X
        Load lblPunkt(Z)
        With lblPunkt(Z)
            .Top = lblPunkt(j - 1).Top + hoehe + 7
            .Left = lblPunkt(Z - 1).Left
            .Visible = True
        End With
        Z = Z + 1
    Next
 
Next
fi_X = lblPunkt(41).Left - 240
fi_Y = lblPunkt(1).Top - 240
End Sub
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Raster 80 * 40 anzeigen - Milimetergenau anzeigen und steuer...905Inge12.08.08 09:52
Re: Raster 80 * 40 anzeigen - Milimetergenau anzeigen und st...575VBStein12.08.08 12:08
Re: Raster 80 * 40 anzeigen - Milimetergenau anzeigen und st...573Inge12.08.08 12:18
Re: Raster 80 * 40 anzeigen - Milimetergenau anzeigen und st...572VBStein12.08.08 21:12
Re: Raster 80 * 40 anzeigen - Milimetergenau anzeigen und st...550Dirk12.08.08 13:27
Re: Raster 80 * 40 anzeigen - Milimetergenau anzeigen und st...535Inge12.08.08 13:41

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel