C#フォームのDataGridViewにチェックボックス列を追加しました。この機能は動的である必要があります。顧客を選択すると、サービス対象のすべてのアイテムが表示され、今回はサービス対象のアイテムを選択します。
とにかく、コードはDGVの先頭にchckboxを追加します。私が知る必要があるのは次のとおりです。
1)デフォルトで列全体が「チェック」されるようにするにはどうすればよいですか? 2)DGVのすぐ下のボタンをクリックしたときに、「チェック済み」行からのみ値を取得していることを確認するにはどうすればよいですか?
列を挿入するコードは次のとおりです。
DataGridViewCheckBoxColumn doWork = new DataGridViewCheckBoxColumn();
doWork.HeaderText = "Include Dog";
doWork.FalseValue = "0";
doWork.TrueValue = "1";
dataGridView1.Columns.Insert(0, doWork);
それでは、次は何ですか?どんな助けも大歓迎です!
それを直接行う方法はありません。データをグリッドに入れたら、行をループして、次のように各ボックスをチェックできます。
foreach (DataGridViewRow row in dataGridView1.Rows)
{
row.Cells[CheckBoxColumn1.Name].Value = true;
}
Clickイベントは次のようになります。
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
}
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のチェックボックスがチェックされているかどうかを見つける最適なソリューション。
この質問に対する1つのライナーの回答を次に示します。
List<DataGridViewRow> list = DataGridView1.Rows.Cast<DataGridViewRow>().Where(k => Convert.ToBoolean(k.Cells[CheckBoxColumn1.Name].Value) == true).ToList();
すべてのレコードをループすることなくこれを行う方法を見つけるのに長い時間がかかりました。バインドされたdatagridview-sourceがあり、チェックボックス列を除くすべてのフィールドがバインドされています。したがって、各行を追加するためのループはありません/必要ありませんし、この目的のためだけにループを作成したくありませんでした。たくさんのことを試した後、ようやく手に入れました。また、実際には非常に簡単です。
最初に、カスタムチェックボックスセルを使用して新しい.csファイルをプロジェクトに追加します。
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);
以上です!チェックボックスが新しい行に追加されるたびに、trueに設定されます。楽しい!
CellContentClick
イベントで試してみると
つかいます:
dataGridView1.EndEdit(); //Stop editing of cell.
MessageBox.Show("0 = " + dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString());
複数のチェックボックスを含むグリッドビューがある場合は....これを試してください....
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());
}
}
}
とても簡単です
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;
}
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);
uデータ型として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);
列がチェックされているかどうかをテストするには:
for (int i = 0; i < dgvName.Rows.Count; i++)
{
if ((bool)dgvName.Rows[i].Cells[8].Value)
{
// Column is checked
}
}
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
}
}