|
| |

Fragen & Antworten rund um sev-Komponenten| Re: Nein, aber... | |  | | Autor: sebbi | | Datum: 05.11.10 13:49 |
| Hallo Mark,
Danke für deine ausführliche Antwort, das war genau der Ansatz den ich gebraucht habe.
Hab das jetzt mal so gelöst
Private bGridClicked As Boolean
Private bSelectCells As Boolean
Private Sub Form_Load()
'SevGrid füllen
With Me.sevZZ
.LockUpdate True
.DataMode = Mode_List
.SelectionHide
.FixedCol = False
.AllowColumnSizing = False
.AllowEdit = False
.AllowMultiSelect = False
.ColumnHeadersVisible = False
.clear
For i = 1 To 96
x = (i - 1) * 15
sHlp = Format(TimeSerial(0, x, 0), "hhmm")
.ColumnAdd sHlp
.Columns(sHlp).Width = 100
Next i
.LockUpdate False
.AddItem ""
.Refresh
End With
End Sub
Private Sub sevZZ_CellClick(ByVal nRow As Long, ByVal nCol As Long, ByVal _
Button As Integer, ByVal Shift As Integer)
With Me.sevZZ
.RowRefresh
If .ListItems(nRow).CellBackColor(nCol) = vbBlue Then
.ListItems(nRow).CellBackColor(nCol) = vbWhite
bSelectCells = False
Else
.ListItems(nRow).CellBackColor(nCol) = vbBlue
bSelectCells = True
End If
End With
'kennzeichen das ein Click ausgeführt wurde, wird im Mousemove wieder
' zurückgesetzt wenn der Button=0 ist
bGridClicked = True
End Sub
Private Sub sevZZ_OnMouseMove(ByVal nRow As Long, ByVal nCol As Long, ByVal _
Button As Integer, ByVal Shift As Integer, sToolTip As String)
If bGridClicked = True And Button > 0 Then
With Me.sevZZ
If bSelectCells = True Then
.ListItems(nRow).CellBackColor(nCol) = vbBlue
Else
.ListItems(nRow).CellBackColor(nCol) = vbWhite
End If
End With
End If
If Button = 0 Then
bGridClicked = False
End If
End Sub Das ganze beginnt mit nem Click in ne Zelle, hier wird erstmal festgestell ob diese schon die Selektionsfarbe hat und je nachdem die Zelle entweder Blau oder wieder weiß wird. Gleichzeitig wird ein Kennzeichen dafür gesetzt ob nachfolgende Zellen Selectiert oder Deselectiert werden sollen und ein Kennzeichen ob ein Click ausgeführt wurde.
Weiter gehts dann im MouseMove:
Hier wird geprüft ob vorher ein Click ausgeführt wurde und ob eine Maustaste gedrückt ist, ist dies der Fall wird die Zelle entweder blau oder wieder weiß.
Ist der Mausbutton = 0 wird das Kennzeichen eines vorangegangenen Clicks wieder rückgesetzt.
Vielleicht kanns noch wer gebrauchen....
EDIT:
nochmal ne Frage: gibt es ne Möglichkeit alle paar Spalten die Zwischenlinie (GridLine) dicker darzustellen ??
mfg
Sebastian
Beitrag wurde zuletzt am 05.11.10 um 13:57:36 editiert. |  |
 | 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 |
  |
|
Neu! sevCommand 4.0 
Professionelle Schaltflächen im modernen Design!
Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. Weitere InfosTipp des Monats TOP Entwickler-Paket 
TOP-Preis!!
Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1866.50 EUR...
Jetzt nur 979,00 EURWeitere Infos
|
| |
|
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
|
|