Ver Mensaje Individual
  #2  
Antiguo 24-10-2007
Avatar de Gabo
[Gabo] Gabo is offline
Miembro Premium
 
Registrado: mar 2007
Ubicación: Murcia (España)
Posts: 684
Reputación: 18
Gabo Va por buen camino
En cuanto a poder, pues claro que se puede... Eso sí requiere programar más que si usas un DBGrid

Para llenar el ListView con una Query (código C++Builder), sería:

Código:
 
AnsiString sql="SELECT CODIGO, NOMBRE FROM TABLA";
DataModule1->Query->Close();
DataModule1->Query->SQL->Clear();
DataModule1->Query->SQL->Add(sql);
DataModule1->Query->Prepare();
DataModule1->Query->Open();
DataModule1->DataSource->DataSet->First();
while (!DataModule1->DataSource->DataSet->Eof)
{
  TListItem* List= ListView1->Items->Add();
  List->Caption=DataModule1->DataSource->DataSet->FieldByName("CODIGO")->AsInteger;
  List->SubItems->Add(DataModule1->DataSource->DataSet->FieldByName("NOMBRE")->AsString);
  DataModule1->DataSource->DataSet->Next();
}
Siempre utilizo la primera columna del ListView para guardar el código, así, si necesito saber el código de un ítem que el usuario ha seleccionado, lo recupero con:

Código:
 
StrToInt(lvPlanosNoCreados->Selected->Caption);
Esto es porque el valor de la primera columna lo obtienes mediante el Caption del ítem seleccionado, no así el resto de las columnas. Por ejemplo, si quisiera pasar un ítem del ListView1 (el que acabo de llenar) a un ListView2, tendría que hacerlo así:

Código:
 
TListItem* List2= ListView2->Items->Add();
List2->Caption=ListView1 ->Selected->Caption;
List2->SubItems->Add(ListView1 ->Selected->SubItems[0][0]);
// Y sí hubieran más columnas seguiría así:
List2->SubItems->Add(ListView1 ->Selected->SubItems[0][1]);
Cómo verás, sí se puede, pero hay que escribir más código.
__________________
Saludos,
Gabo

A menos que se indique lo contrario, el código estará hecho en C++Builder.

Última edición por Gabo fecha: 24-10-2007 a las 10:08:55.
Responder Con Cita