AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

DevExpress Grid: Selection

Ein Thema von haentschman · begonnen am 21. Mär 2018 · letzter Beitrag vom 23. Mär 2018
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#1

DevExpress Grid: Selection

  Alt 21. Mär 2018, 11:34
Hallöle...

Ich habe ein Grid mit MultiSelect. Ich möchte die Datensätze mit CTRL und/oder SHIFT markieren... soweit so gut.

Einschränkung:

Manche Datensätze dürfen nicht markiert werden! Im OnCanSelectRecord wird AAllow entsprechend der Bedingung auf False gesetzt. Auch gut...
Aber:
Mit SHIFT werden, trotz AAllow = False, alle Datensätze markiert?

Hat jemand eine Idee?

Danke...
  Mit Zitat antworten Zitat
HeZa

Registriert seit: 4. Nov 2004
Ort: Dortmund
182 Beiträge
 
Delphi 10 Seattle Professional
 
#2

AW: DevExpress Grid: Selection

  Alt 21. Mär 2018, 12:23
Hallo,

ich mache erst seit ein paar Tagen etwas mit TcxGrid, daher nur ein paar Fragen, mit denen du dein Problem evtl. einkreisen könntest:
  • Wird OnCanSelectRecord überhaupt für alle Datensätze beim markieren mit Shift aufgerufen?
  • Evtl. sehen die Datensätze nur selektiert aus? Prüfe einmal, ob ForAllSelected auch die nicht gewünschten Sätze berücksichtigt.
  • Mit dem DevExpress-Support das Problem klären (und die Antwort auch hier posten )
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#3

AW: DevExpress Grid: Selection

  Alt 21. Mär 2018, 12:41
Danke...
Zitat:
Wird OnCanSelectRecord überhaupt für alle Datensätze beim markieren mit Shift aufgerufen?
...ja. AAllow wird korrekt gesetzt.
Zitat:
Evtl. sehen die Datensätze nur selektiert aus?
...nein. Alle Datensätze sind in der Selection enthalten. ...auch die die mit AAllow = False.
Zitat:
Mit dem DevExpress-Support das Problem klären (und die Antwort auch hier posten )
Werde ich dann mal machen müssen. Die wollen aber immer ein Testprojekt...für solchen "Firlefanz" habe ich keine Zeit.
  Mit Zitat antworten Zitat
Benutzerbild von ULIK
ULIK

Registriert seit: 25. Sep 2006
Ort: Regensburg
427 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: DevExpress Grid: Selection

  Alt 21. Mär 2018, 17:00
Na ja, so ganz ohne Testprojekt wirst nicht davonkommen: hab mir mal ein sehr einfaches gebaut und siehe da: Auch bei Markierung mit Shift ist der spezielle Record nicht selektiert.

Was hab ich gemacht: TableView mit
OptionsSelection.CellSelect = False
OptionsSelection.MultiSelect = True

Selektierst Du über irgendwelche Gruppierungen hinweg? Wenn ja, könnte der OnCanSelectRecord dann eventuell mit dem falschen Datensatz arbeiten?
  Mit Zitat antworten Zitat
StepByStep

Registriert seit: 12. Nov 2014
Ort: Schleswig-Holstein
61 Beiträge
 
Delphi 7 Professional
 
#5

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 08:52
Moin zusammen,

ich habe gerade das selbe Problem wie der Threadersteller und habe einmal gedebuggt, aber erst einmal kurz der Aufbau des Testprojekts:

Ich habe ein TcxGrid und eine TcxGridDBTableView. Die Daten kommen über ein TADODataSet. Meine Options der TableView sind die gleichen wie von ULIK.

Problembeschreibung:

Im Grid stehen drei Datensätze, einer davon müsste nach dem OnCanSelectRecord herausfallen, auf Grund folgender Bedingung...

Delphi-Quellcode:
if qTest.FieldByName('TEST_ANZAHL').AsInteger < 1 then
begin
  AAllow := False;
end;
... und folgender Datenbasis

TEST_ID / TEST_ANZAHL
1 / 2
2 / 1
3 / 0

Wird jetzt der oberste Satz angeklickt, funktioniert die Selektion. Ebenso bei Datensatz 2 und beim letzten nicht, da die Bedingung das ausschließt. Wählst du aber über STRG + SHIFT + Klick eine Datenmenge aus, dann gehst du so oft durch das OnCanSelectRecord-Event wie du Datensätze zusätzlich zum aktuellen Fokus ausgewählt hast. Soll heißen, wenn Datensatz 1 den Fokus hat und du wählst alle aus, dann läufst du für ID 2 und 3 nochmal durch das Event.

Jetzt kommt aber der Gag an dem Ganzen: In meinem Fall ändert sich natürlich nicht der Satz im DataSet, sondern der steht in beiden Durchläufen auf ID 3. Würde es also einen Datensatz 4 geben, der die If-Bedingung erfüllt, dann würde Datensatz 3 selektiert werden.

Ich hoffe das war so erstmal verständlich. Wenn du keine DB-Anbindung hast, musst du sonst nochmal genauer schildern was du alles hast. Bin relativ fit mit DevExpress, nutze ich nämlich täglich, da lernt man dann das ein oder andere.

LG

Jan

PS.: Ich habe keine Ahnung wie ich die Tabelle hübsch gestalten kann. Verzeiht mir.
Jan
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#6

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 09:01
Moin...
Das ist die Lösung. Aber verstehen muß ich das nicht...
Zitat DevExpress:
Delphi-Quellcode:
procedure <AForm>.<AcxGridDBTableView>CanSelectRecord(Sender: TcxCustomGridTableView; ARecord: TcxCustomGridRecord; var AAllow: Boolean);
var
  AView: TcxGridDBTableView;
  AColumn: TcxGridDBColumn;
begin
  AView := TcxGridDBTableView(Sender);
  AColumn := AView.GetColumnByFieldName(<AFieldName>);

  AAllow := ARecord.Values[AColumn.Index] < 0; // Werteermittlung für den Vergleich aus dem Record
end;
Bild: Selection mit SHIFT
Miniaturansicht angehängter Grafiken
shift.png  
  Mit Zitat antworten Zitat
StepByStep

Registriert seit: 12. Nov 2014
Ort: Schleswig-Holstein
61 Beiträge
 
Delphi 7 Professional
 
#7

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 09:16
Moin.

Die Frage ist ja jetzt was du genau stehen hattest, dass es nicht funktioniert.

In deinem Sample ist es so, dass der Record anders als zum DataSet sich in den Durchläufen ändert. Über den Index deiner Spalte kannst du dann auf den jeweiligen Wert innerhalb des Records zugreifen und diesen prüfen.

LG

Jan
Jan
  Mit Zitat antworten Zitat
Bentissimo

Registriert seit: 25. Apr 2006
Ort: Friedenfels
82 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 09:29
Hallo zusammen,

aus der Ticket-Beschreibung bei DevExpress würde ich tippen, dass die Abfrage auf "EditValue" nicht korrekt ist. Nur so aus dem Kopf, da ich gerade kein cxGrid vor mir habe.
Stephan Schmahl
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#9

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 09:39
Moin...
Der Ursprungscode:
Delphi-Quellcode:
procedure TfoAssignment.GridDBTableViewCanSelectRecord(Sender: TcxCustomGridTableView; ARecord: TcxCustomGridRecord; var AAllow: Boolean);
var
  View: TcxGridDBTableView;
begin
  View := TcxGridDBTableView(Sender);
  AAllow := ContainsText(View.GetColumnByFieldName('ixBELArt').EditValue, conAllowedDocumentType); // nicht bei SHIFT!!!!
end;
  Mit Zitat antworten Zitat
StepByStep

Registriert seit: 12. Nov 2014
Ort: Schleswig-Holstein
61 Beiträge
 
Delphi 7 Professional
 
#10

AW: DevExpress Grid: Selection

  Alt 22. Mär 2018, 11:46
Also die View ist jedes Mal wo du da reinkommst identisch, ebenso die Spalte. Den Wert liest du dann aber eben nicht aus dem aktuellen Record, sondern dieser wird immer den Wert der in dem angeklickten Datensatz steht. Somit läufst du x-Mal dadurch und schaust jedoch immer auf den selben Wert.

So würde ich mir das ohne es gedebuggt zu haben mal erschließen. ^^

LG

Jan
Jan
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:35 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz