DataGridView колонки флажок - значение и функциональные возможности

голоса
17

Я добавил столбец флажка к DataGridView в моей C # форме. Функция должна быть динамичным - вы выбираете клиент, и что воспитывает все их элементы, которые могут обслуживаться, и вы выбираете, какой из них вы хотите, чтобы обслужить этот раз.

Во всяком случае, код теперь будет добавить chckbox к началу DGV. Что мне нужно знать следующее:

1) Как сделать так, чтобы вся колонна «проверяется» по умолчанию? 2) Как я могу убедиться, что я только получать значения от «проверенных» строк при щелчке на кнопке чуть ниже DGV?

Вот код, чтобы получить колонку вставленный:

DataGridViewCheckBoxColumn doWork = new DataGridViewCheckBoxColumn();
            doWork.HeaderText = Include Dog;
            doWork.FalseValue = 0;
            doWork.TrueValue = 1;
            dataGridView1.Columns.Insert(0, doWork);

Так, что дальше? Любая помощь будет принята с благодарностью!

Задан 06/08/2009 в 10:17
источник пользователем
На других языках...                            


11 ответов

голоса
37

  1. Там нет никакого способа сделать это непосредственно. Если у вас есть данные в сетке, вы можете Переберите строк и проверить каждое окно, как это:

    foreach (DataGridViewRow row in dataGridView1.Rows)
    {
        row.Cells[CheckBoxColumn1.Name].Value = true;
    }
    
  2. Нажмите событие может выглядеть следующим образом:

    private void button1_Click(object sender, EventArgs e)
    {
        List<DataGridViewRow> rows_with_checked_column = new List<DataGridViewRow>();
        foreach (DataGridViewRow row in dataGridView1.Rows)
        {
            if (Convert.ToBoolean(row.Cells[CheckBoxColumn1.Name].Value) == true)
            {
                rows_with_checked_column.Add(row);
            }
        }
        // Do what you want with the check rows
    }
    
Ответил 06/08/2009 в 13:17
источник пользователем

голоса
14
private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
    DataGridViewCheckBoxCell ch1 = new DataGridViewCheckBoxCell();
    ch1 = (DataGridViewCheckBoxCell)dataGridView1.Rows[dataGridView1.CurrentRow.Index].Cells[0];

    if (ch1.Value == null)
        ch1.Value=false;
    switch (ch1.Value.ToString())
    {
        case "True":
            ch1.Value = false;
            break;
        case "False":
            ch1.Value = true;
            break;
    }
    MessageBox.Show(ch1.Value.ToString());
}

Лучшее решение, чтобы найти, если флажок в DataGridView проверяется или нет.

Ответил 29/08/2010 в 18:39
источник пользователем

голоса
3

это мне потребовалось много времени, чтобы понять, как сделать это без перебора всех записей. У меня есть связанный DataGridView-источник, и все поля связаны для CheckBox-колонки, за исключением. Так что у меня нет / нужен цикл, чтобы добавить каждую строку, и я не хочу, чтобы создать один раз для этого purpuse. Таким образом, после многих попыток я, наконец, получил его. И это на самом деле очень просто тоже:

Сначала добавьте новый .cs файл к вашему проекту с специально CheckBox клетки, например,

DataGridViewCheckboxCellFilter.cs:

using System.Windows.Forms;

namespace MyNamespace {
    public class DataGridViewCheckboxCellFilter : DataGridViewCheckBoxCell {
        public DataGridViewCheckboxCellFilter() : base() {
            this.FalseValue = 0;
            this.TrueValue = 1;
            this.Value = TrueValue;
        }
    }
}

После этого на вашем GridView, где вы добавите флажок колонки, вы:

// add checkboxes
DataGridViewCheckBoxColumn col_chkbox = new DataGridViewCheckBoxColumn();
{
    col_chkbox.HeaderText = "X";
    col_chkbox.Name = "checked";
    col_chkbox.CellTemplate = new DataGridViewCheckboxCellFilter();                
}
this.Columns.Add(col_chkbox);

Вот и все! Everytime ваших Флажки добавляются в новой строке, они будут устанавливаться в действительность. Наслаждайтесь!

Ответил 23/05/2011 в 00:35
источник пользователем

голоса
4

Вот один вкладыш ответ на этот вопрос

List<DataGridViewRow> list = DataGridView1.Rows.Cast<DataGridViewRow>().Where(k => Convert.ToBoolean(k.Cells[CheckBoxColumn1.Name].Value) == true).ToList();
Ответил 24/01/2012 в 07:37
источник пользователем

голоса
1

Если у вас есть GridView, содержащий более одного флажка .... Вы должны попробовать это ....

Object[] o=new Object[6];

for (int i = 0; i < dgverlist.RowCount; i++)
{
    for (int j = 2; j < dgverlist.ColumnCount; j++)
    {
        DataGridViewCheckBoxCell ch1 = new DataGridViewCheckBoxCell();
        ch1 = (DataGridViewCheckBoxCell)dgverlist.Rows[i].Cells[j];

        if (ch1.Value != null)
        {
           o[i] = ch1.OwningColumn.HeaderText.ToString();

            MessageBox.Show(o[i].ToString());
        }
    }
}
Ответил 16/02/2012 в 07:29
источник пользователем

голоса
3

Если вы попробуете это на CellContentClickсобытие

Использование:

dataGridView1.EndEdit();  //Stop editing of cell.
MessageBox.Show("0 = " + dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString());
Ответил 03/10/2012 в 15:24
источник пользователем

голоса
0

Для того, чтобы проверить, если столбец проверяется или нет:

for (int i = 0; i < dgvName.Rows.Count; i++)
{
    if ((bool)dgvName.Rows[i].Cells[8].Value)
    {
    // Column is checked
    }
}
Ответил 12/01/2013 в 07:25
источник пользователем

голоса
1

1) Как сделать так, чтобы вся колонна «проверяется» по умолчанию?

var doWork = new DataGridViewCheckBoxColumn();
doWork.Name = "IncludeDog" //Added so you can find the column in a row
doWork.HeaderText = "Include Dog";
doWork.FalseValue = "0";
doWork.TrueValue = "1";

//Make the default checked
doWork.CellTemplate.Value = true;
doWork.CellTemplate.Style.NullValue = true;

dataGridView1.Columns.Insert(0, doWork);

2) Как я могу убедиться, что я только получать значения от «проверенных» строк?

foreach (DataGridViewRow row in dataGridView1.Rows)
{
    if (row.IsNewRow) continue;//If editing is enabled, skip the new row

    //The Cell's Value gets it wrong with the true default, it will return         
    //false until the cell changes so use FormattedValue instead.
    if (Convert.ToBoolean(row.Cells["IncludeDog"].FormattedValue))
    {
        //Do stuff with row
    }
}
Ответил 30/10/2014 в 05:31
источник пользователем

голоса
0

если и сделать этот столбец в базе данных SQL (бит) в качестве типа данных и должны изменить этот код

DataGridViewCheckBoxColumn doWork = new DataGridViewCheckBoxColumn();
            doWork.HeaderText = "Include Dog";
            doWork.FalseValue = "0";
            doWork.TrueValue = "1";
            dataGridView1.Columns.Insert(0, doWork);

с этим

DataGridViewCheckBoxColumn doWork = new DataGridViewCheckBoxColumn();
            doWork.HeaderText = "Include Dog";
            doWork.FalseValue = "False";
            doWork.TrueValue = "True";
            dataGridView1.Columns.Insert(0, doWork);
Ответил 01/06/2016 в 23:10
источник пользователем

голоса
0

Это довольно просто

DataGridViewCheckBoxCell checkedCell = (DataGridViewCheckBoxCell) grdData.Rows[e.RowIndex].Cells["grdChkEnable"];

                bool isEnabled = false;
                if (checkedCell.AccessibilityObject.State.HasFlag(AccessibleStates.Checked))
                {
                    isEnabled = true;
                }
if(isEnabled)
 {
   // do your business process;
 }
Ответил 30/06/2019 в 09:40
источник пользователем

голоса
0

Если столбец был уже создан за счет связывания с записями типа BIT, тип столбца будет текст в любом случае. Решение я нашел, чтобы удалить этот столбец и заменить его на «DataGridViewCheckBoxColumn», имеющего те же данные связывания.

            DataGridViewColumn oldCol = dgViewCategory.Columns["mycolumn"];
            int chkIdx = oldCol.Index;
            DataGridViewCheckBoxColumn chkCol = new DataGridViewCheckBoxColumn();
            chkCol.HeaderText = oldCol.HeaderText;
            chkCol.FalseValue = "False";
            chkCol.TrueValue = "True";
            chkCol.DataPropertyName = oldCol.DataPropertyName;
            chkCol.Name = oldCol.Name;
            dgViewCategory.Columns.RemoveAt(chkIdx);
            dgViewCategory.Columns.Insert(chkIdx, chkCol);
Ответил 15/07/2019 в 17:25
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more