![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Всем доброго времени суток!  
		
	
		
		
		
		
		
		
			Помогите, пожалуйста, со вставкой DBCombobox в DBGrid Задача стоит чтобы в одной из колонок ДБГрид2 отображался Комбобокс с данными одной из колонок ДБГрид1 ![]() На данный момент код такой (ошибок при компиляции не дает)   Код: 
	procedure TForm1.DBGrid2DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
  if (gdFocused in State) then
    if (Column.Field.FieldName = dbcombobox1.DataField) then begin
      DBCombobox1.Left := Rect.Left + DBGrid2.Left;
      DBCombobox1.Top := Rect.Top + DBGrid2.top;
      DBCombobox1.Width := Rect.Right - Rect.Left + 2;
      DBCombobox1.Visible := True;
    end;
end;
procedure TForm1.DBGrid2ColExit(Sender: TObject);
begin
 if DBGrid2.SelectedField.FieldName = DBCombobox1.DataField then
    DBCombobox1.Visible := false;
end; 
procedure TForm1.DBGrid2KeyPress(Sender: TObject; var Key: Char);
begin
  if (Key <> chr(9)) then
    if (DBGrid2.SelectedField.FieldName = DBCombobox1.DataField) then begin
      DBCombobox1.SetFocus;
      SendMessage(DBCombobox1.Handle, WM_CHAR, word(Key), 0);
    end;
end;  Код: 
	begin for I:=0 to Pred(DBGrid1.Columns.Count) do if DBGrid1.Columns[i].Field.FieldName = DBCombobox1.DataField then begin DBCombobox1.Items.Assign(DBGrid1.Columns[i].PickList); Break; end; Пробовала вначале вставить Комбобокс в ДБгрид2. Вставляет, но списка самого как не было так и нет. Еще проблема стоит в том, что при ручном вводе данных в комбобокс, он печатает справа на лево ![]() Последний раз редактировалось Admin, 13.04.2012 в 09:59.  | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Не понимаю зачем так усложнять себе жизнь - она и без этого штука сложная. Если Вам нужно брать данные поля из DBGrid1 (точнее, даже, не из сетки (грида), а из набора данных (таблицы, запроса), к которому он подключен), а потом в виде поля со списком их вставлять в таблицу, отображаемую DBGrid2, то тут разумнее и проще в той таблице создать подстановочное поле, значения списка которого будут выбираться из первой таблицы, в соответствии с каким-то числом во второй. Иными словами во второй таблице будет поле числового значения, ссылающегося на ключевое поле первой таблицы, а списком будет нужное Вам поле этой таблицы. Но во второй таблице придётся ограничиться списком, т. к. это будет список имеющихся записей в первой таблице. Если непонятно объяснил, пишите в личку. 
		
	
		
		
		
		
			
		
		
		
		
	
		
		
	
	
	 |