Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-06-2017
rafaelon rafaelon is offline
Miembro
 
Registrado: sep 2010
Posts: 29
Poder: 0
rafaelon Va por buen camino
Agregar varios captions de checkbox a bd

Buenas noches tengo la siguiente duda tengo 17 checkboxs y lo que quiero lograr es que si estan seleccionados (checked o enabled no se cual es la diferencia ) los captions de dichos checkboxs se guarden en una tabla m gracias de antemano
Responder Con Cita
  #2  
Antiguo 26-06-2017
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.267
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por rafaelon Ver Mensaje
...quiero lograr es que si estan seleccionados (checked o enabled no se cual es la diferencia )
Todos los componentes tienen la propiedad Enabled que indica si es componente está habilitado o no. Un componente deshabilitado significa que no puedes interactuar con él.
La propiedad Checked indica que un checkbox está "marcado", por lo tanto es una propiedad que no existe en el resto que controles (sólo tiene sentido en un checkbox, rediobutton y alguno más).

Cita:
Empezado por rafaelon Ver Mensaje
lo que quiero lograr es que si estan seleccionados los captions de dichos checkboxs se guarden en una tabla
No tiene mucho sentido lo que comentas.
Guardar los Caption de determinados checkbox significaque tendrás que:
1) Crear una tabla para almacenarlos.
2) Crear un campo en la tabla de tipo String (VARCHAR(40), por ejemplo).
3) En algún memento crear registros en esta tabla para almacanar esos valores.
4) El código será el estandard para crear registros (Dataset.Append/Post).

De todas formas, como te he dicho, no le veo sentido a esto. Tal vez no explicas lo suficiente o no lo explicas correctamente.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 26-06-2017
rafaelon rafaelon is offline
Miembro
 
Registrado: sep 2010
Posts: 29
Poder: 0
rafaelon Va por buen camino
muchas gracias por responder, pues voy a tratar de responder un poco mejor , tengo un negocio de recepción de equipos moviles y trato de automatizar un poco el proceso , tengo 17 checkbox cada uno indica graficamente un problema del equipo que se esta recibiendo ,por ejemplo si marco el checkbox1 significa que el equipo tiene problemas con la señal , el checkbox2 con el wifi y asi sucesivamente , pudiendo estar marcados uno o 2 ,o todos y tengo una tabla "problemas" que esta donde quiero que se guarden , se me ocurrio que se podria guardan el caption del que se marca a la tabla y se elimine si se deselecciona pero no he conseguido hacerlo
Responder Con Cita
  #4  
Antiguo 26-06-2017
Avatar de oscarac
[oscarac] oscarac is offline
Miembro Premium
 
Registrado: sep 2006
Ubicación: Lima - Perú
Posts: 2.010
Poder: 20
oscarac Va por buen camino
muestra el diseño tu tabla "Problemas"
pienso que el proceso debería ser el Batch, teniendo un boton que diga "Grabar/Actualizar" con el cual mediante un identificador (numero de celular, DNI del cliente, o cualquier otro identificador unico) puedas grabar/actualizar lo que necesitas
__________________
Dulce Regalo que Satanas manda para mi.....
Responder Con Cita
  #5  
Antiguo 26-06-2017
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Lo que podrias hacer es tener campos booleanos, estilo: ProblemaWifi, ProblemaSeñal, etc. Luego es cuestion de asignar en los registros el valor que tenga la propiedad Checked del TCheckBox correspondiente

Como comenta Neftali, el codigo para insertar es el estandart para manejar operaciones en bases de datos, en realidad hay dos formas de hacerlo, una es usando SQL y la otra usando DataSets

Cita:
se me ocurrio que se podria guardan el caption del que se marca a la tabla y se elimine si se deselecciona pero no he conseguido hacerl
Pon el codigo asi vemos que es lo que esta mal
Responder Con Cita
  #6  
Antiguo 26-06-2017
Avatar de oscarac
[oscarac] oscarac is offline
Miembro Premium
 
Registrado: sep 2006
Ubicación: Lima - Perú
Posts: 2.010
Poder: 20
oscarac Va por buen camino
Cita:
Empezado por AgustinOrtu Ver Mensaje
Lo que podrias hacer es tener campos booleanos, estilo: ProblemaWifi, ProblemaSeñal, etc. Luego es cuestion de asignar en los registros el valor que tenga la propiedad Checked del TCheckBox correspondiente

Como comenta Neftali, el codigo para insertar es el estandart para manejar operaciones en bases de datos, en realidad hay dos formas de hacerlo, una es usando SQL y la otra usando DataSets



Pon el codigo asi vemos que es lo que esta mal
Pero que sucede si mas adelante, se registrara un nuevo problema, se tendría que modificar la tabla para agregar el campo, yo pienso que se deberia grabar un registro por cada problema (codificado)

pero si tienes mucha razón en que debe colocar el código, para poder entender un poco mas
__________________
Dulce Regalo que Satanas manda para mi.....
Responder Con Cita
  #7  
Antiguo 26-06-2017
rafaelon rafaelon is offline
Miembro
 
Registrado: sep 2010
Posts: 29
Poder: 0
rafaelon Va por buen camino
gracias a todos por responder , ante todo no tengo mucho programando y he estado leyendo libros de delphi hace unos 2 meses porque fue el lenguaje que vi en el instituto por si escribo cosas sin sentido o no muy optimas sepan disculparme, básicamente no he encontrado la manera de hacerlo




por ahora tengo esto en cada checkbox
Código:
procedure Tfrm_principal.CheckBox1Click(Sender: TObject);
begin
if CheckBox1.Checked = True then
begin MD.tblproblemas.insert;
MD.tblproblemas.fieldbyname('problema1').AsString:=checkbox1.caption;
end
else
buscarp(label42.Caption, encontrado);
  if encontrado then
  begin
    MD.tblproblemas.delete;

 end;
end;

end.
* tambien intente hacerlo desde el boton guardar pero no se como hacer un conjunto de if anidadados cuando las condiciones son siempre afirmativas (queria enviar una imagen del form pero no me lo permite)

* la tabla tengo como clave principal el "id_orden" (label42) y otros 17 campos donde iria cada problema y un 18 para problemas adicionales , la bd es en access
Responder Con Cita
  #8  
Antiguo 26-06-2017
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola.

Tal vez te resulte mas simple usando un TCheckListBox, v. gr.:
Código Delphi [-]
...
type
  TForm1 = class(TForm)
    CheckListBox1: TCheckListBox;
    btnGuardar: TButton;
    //...
    procedure FormCreate(Sender: TObject);
    procedure btnGuardarClick(Sender: TObject);
  private
    function HaveItemsChecked ( clb: TCheckListBox ): Boolean;
  public
  end;

implementation

// Podes evitar todo el código de FormCreate asignando los 17 ítems en tiempo de diseño 
procedure TForm1.FormCreate(Sender: TObject);
var
  clb: TCheckListBox;
begin  
  clb := CheckListBox1;   
  clb.Items.Add('Problema Wifi');
  clb.Items.Add('Problema Señal');
  clb.Items.Add('Problema Antena');
  clb.Items.Add('Problema Bateria');
  // cbl.Items.Add(...
end;

// devuelve verdadero si existe algún item marcado
function TForm1.HaveItemsChecked ( clb: TCheckListBox ): Boolean;
var
  i: Integer;
begin
  Result := False;
  for i := 0 to clb.Items.Count-1 do
  begin
    Result := clb.Checked[i];
    if Result then Exit;
  end;
end;

procedure TForm1.btnGuardarClick(Sender: TObject);
var
  i  : Integer;
begin
  if HaveItemsChecked( CheckListBox1 ) then
  begin
    MD.tblProblemas.Insert;
    for i := 0 to CheckListBox1.Items.Count-1 do
      if CheckListBox1.Checked[i] then
         MD.tblProblemas.FieldByName(Format('problema%d',[i+1])).AsString :=
          CheckListBox1.Items[i];
    //...
    MD.tblProblemas.Post;
  end
end;

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #9  
Antiguo 26-06-2017
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Cita:
Empezado por oscarac Ver Mensaje
Pero que sucede si mas adelante, se registrara un nuevo problema, se tendría que modificar la tabla para agregar el campo, yo pienso que se deberia grabar un registro por cada problema (codificado)
Estoy de acuerdo, pero esta aprendiendo y creo que de otra forma le va a costar mas. Al menos yo empece asi y luego me di cuenta, como bien dices, "mas adelante", de que hay soluciones mas elaboradas
Responder Con Cita
  #10  
Antiguo 27-06-2017
rafaelon rafaelon is offline
Miembro
 
Registrado: sep 2010
Posts: 29
Poder: 0
rafaelon Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola.

Tal vez te resulte mas simple usando un TCheckListBox, v. gr.:
Código Delphi [-]
...
type
  TForm1 = class(TForm)
    CheckListBox1: TCheckListBox;
    btnGuardar: TButton;
    //...
    procedure FormCreate(Sender: TObject);
    procedure btnGuardarClick(Sender: TObject);
  private
    function HaveItemsChecked ( clb: TCheckListBox ): Boolean;
  public
  end;

implementation

// Podes evitar todo el código de FormCreate asignando los 17 ítems en tiempo de diseño 
procedure TForm1.FormCreate(Sender: TObject);
var
  clb: TCheckListBox;
begin  
  clb := CheckListBox1;   
  clb.Items.Add('Problema Wifi');
  clb.Items.Add('Problema Señal');
  clb.Items.Add('Problema Antena');
  clb.Items.Add('Problema Bateria');
  // cbl.Items.Add(...
end;

// devuelve verdadero si existe algún item marcado
function TForm1.HaveItemsChecked ( clb: TCheckListBox ): Boolean;
var
  i: Integer;
begin
  Result := False;
  for i := 0 to clb.Items.Count-1 do
  begin
    Result := clb.Checked[i];
    if Result then Exit;
  end;
end;

procedure TForm1.btnGuardarClick(Sender: TObject);
var
  i  : Integer;
begin
  if HaveItemsChecked( CheckListBox1 ) then
  begin
    MD.tblProblemas.Insert;
    for i := 0 to CheckListBox1.Items.Count-1 do
      if CheckListBox1.Checked[i] then
         MD.tblProblemas.FieldByName(Format('problema%d',[i+1])).AsString :=
          CheckListBox1.Items[i];
    //...
    MD.tblProblemas.Post;
  end
end;

Saludos
Me sirve perfecto gracias , ya tenia otra solución, pero esta es mucho mejor , una ultima pregunta si mas adelante quisiera alimentar los datos de checkboxlist desde una tabla como podría hacer ?
Responder Con Cita
  #11  
Antiguo 27-06-2017
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola.
Cita:
Empezado por rafaelon Ver Mensaje
... si mas adelante quisiera alimentar los datos de checkboxlist desde una tabla como podría hacer ?
Código Delphi [-]
// al inicio del formulario del CheckListBox:
procedure TForm1.FormCreate(Sender: TObject);
var
  clb: TCheckListBox;
begin
  clb := CheckListBox1;

  clb.Items.Clear;
  unQuery.Close;
  unQuery.SQL.Text := 'SELECT DESCRIPCION FROM SINTOMAS'; // (*) 
  unQuery.Open;
  while not unQuery.Eof do
  begin
    clb.Items.Add( unQuery.FieldByName('DESCRIPCION').AsString );
    unQuery.Next;
  end;
end;
(*) Donde: DESCRIPCION sería el nombre del campo que detalla el problema y SINTOMAS el nombre de la tabla que los contiene.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #12  
Antiguo 28-06-2017
rafaelon rafaelon is offline
Miembro
 
Registrado: sep 2010
Posts: 29
Poder: 0
rafaelon Va por buen camino
gracias , me funciona bastante bien!
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
cambiar la propiedad checked de varios CheckBox fuego149 C++ Builder 2 14-07-2013 07:53:10
insertar datos de varios checkbox krewer Varios 6 23-04-2012 21:16:57
Agregar checkbox a un Dbgrid osmar OOP 13 18-03-2009 21:54:53
¿¿ como usar el tag con varios checkbox ?? gaston260 Varios 7 21-04-2008 06:19:02
marcar varios checkbox halizia HTML, Javascript y otros 3 18-01-2007 14:48:44


La franja horaria es GMT +2. Ahora son las 16:38:05.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi