Как выполнить поиск в хранилище по значению члена? - PullRequest
0 голосов
/ 29 июня 2018

Как мне установить текст в repositoryLookupedit путем поиска значения элемента? То, что я хочу, находится в столбце grade, когда я набираю элемент значения, он отображает элемент отображения. E.g когда я набираю 1, он устанавливает столбец оценки в D

enter image description here

вот мой код

   private void Form1_Load(object sender, EventArgs e)
    {
        DataTable dt = new DataTable();
        dt.Columns.Add("Grade", typeof(string));
        dt.Columns.Add("Value", typeof(int));
        dt.Rows.Add("A", 4);
        dt.Rows.Add("B", 3);
        dt.Rows.Add("C", 2);
        dt.Rows.Add("D", 1);
        repositoryItemLookUpEdit1.DataSource = dt;
        repositoryItemLookUpEdit1.DisplayMember = dt.Columns["Grade"].ToString();
        repositoryItemLookUpEdit1.ValueMember = dt.Columns["Value"].ToString();
        repositoryItemLookUpEdit1.NullText = "";
        repositoryItemLookUpEdit1.PopupFormMinSize = new Size(100, 50);

        DataTable dt2 = new DataTable();
        dt2.Columns.Add("colA", typeof(String));
        dt2.Columns.Add("colB", typeof(String));
        dt2.Columns.Add("colC", typeof(String));
        for(int i =0; i < 15; i++)
        {
            dt2.Rows.Add(i.ToString() + "a", i.ToString() + "b", i.ToString()+"c");
        }
        gridControl1.DataSource = dt2;
        gridView1.BeginUpdate();
        DataColumn col2 = dt2.Columns.Add("Grade", typeof(int));
        GridColumn column2 = gridView1.Columns.AddVisible(col2.ColumnName);
        column2.Caption = col2.Caption;
        column2.Name = col2.ColumnName;
        gridView1.EndUpdate();
        gridView1.Columns["Grade"].ColumnEdit = repositoryItemLookUpEdit1;
    }

я пытался поместить код в событие gridview. но это не сработало

 private void gridView1_KeyDown(object sender, KeyEventArgs e)
    {            
        if(e.KeyValue == 49)
        {
            gridView1.SetFocusedRowCellValue("Grade", 1);
        }
    }

Ответы [ 2 ]

0 голосов
/ 29 июня 2018

Вы можете попробовать SearchLookUpEdit вместо простого LookUpEdit. SearchLookUpEdit предоставляет множество вариантов поиска.

0 голосов
/ 29 июня 2018

сначала установите режим поиска для хранилища в всплывающее окно

repositoryItemLookUpEdit1.SearchMode = DevExpress.XtraEditors.Controls.SearchMode.OnlyInPopup;

, а затем добавить код в gridview и repositoryitemlookupedit события keydown

  private void gridView1_KeyDown(object sender, KeyEventArgs e)
    {
        if (e.KeyCode == Keys.NumPad1 || e.KeyCode == Keys.D || e.KeyValue == 49)
        {
            gridView1.SetFocusedRowCellValue("Grade", 1);
        }
        if (e.KeyCode == Keys.NumPad2 || e.KeyCode == Keys.C || e.KeyValue == 50)
        {
            gridView1.SetFocusedRowCellValue("Grade", 2);
        }
        if (e.KeyCode == Keys.NumPad3 || e.KeyCode == Keys.B || e.KeyValue == 51)
        {
            gridView1.SetFocusedRowCellValue("Grade", 3);
        }
        if (e.KeyCode == Keys.NumPad4 || e.KeyCode == Keys.A || e.KeyValue == 52)
        {
            gridView1.SetFocusedRowCellValue("Grade", 4);
        }
    }
    private void repositoryItemLookUpEdit1_KeyDown(object sender, KeyEventArgs e)
    {
        if (e.KeyCode == Keys.NumPad1 || e.KeyCode == Keys.D || e.KeyValue == 49)
        {
            gridView1.SetFocusedRowCellValue("Grade", 1);
        }
        if (e.KeyCode == Keys.NumPad2 || e.KeyCode == Keys.C || e.KeyValue == 50)
        {
            gridView1.SetFocusedRowCellValue("Grade", 2);
        }
        if (e.KeyCode == Keys.NumPad3 || e.KeyCode == Keys.B || e.KeyValue == 51)
        {
            gridView1.SetFocusedRowCellValue("Grade", 3);
        }
        if (e.KeyCode == Keys.NumPad4 || e.KeyCode == Keys.A || e.KeyValue == 52)
        {
            gridView1.SetFocusedRowCellValue("Grade", 4);
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...