1

コントロールでドロップダウン リストを使用していDataGridViewますが、最初にドロップダウンをクリックすると、リストをドロップダウンして表示するのに 2 回クリックする必要がありますが、その後は正常に動作します。

 private void ViewActiveJobs_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            if (e.RowIndex>=0)
            {
                jobCardId = int.Parse(ViewActiveJobs.Rows[ViewActiveJobs.CurrentCell.RowIndex].Cells["Job Card Number"].Value.ToString());
                RegNo = ViewActiveJobs.Rows[ViewActiveJobs.CurrentCell.RowIndex].Cells["Registeration Number"].Value.ToString();
                SelectedRow = e.RowIndex;                
            }
        }

        private void ViewActiveJobs_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
        {
            try
            {
                ComboBox cbox = (ComboBox)e.Control;
                cbox.SelectedIndexChanged -= new EventHandler(comboBOX_SelectedIndexChanged);
                cbox.SelectedIndexChanged += new EventHandler(comboBOX_SelectedIndexChanged);
            }
            catch(Exception)
            {
            }
        }
        private void comboBOX_SelectedIndexChanged(object sender, EventArgs e)
        {
            ComboBox combo = sender as ComboBox;
            string str = combo.SelectedIndex.ToString();
           if (combo.SelectedIndex ==1)
                pdf = new MakePDF(jobCardId,RegNo);
           if (combo.SelectedIndex == 2)
           {
               PdfJobCard = new MakePDFJobCard(jobCardId);
           }
            if (combo.SelectedIndex == 3)
           {
               if (MessageBox.Show("Are you Sure you want to Close Job Card ?", "Are you Sure",
                        MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.Yes)
               {
                   cmd = new SqlCommand();
                   cmd.Connection = con;

                   cmd.Parameters.Add("@jCard", SqlDbType.VarChar).Value = jobCardId;
                   cmd.Parameters.Add("@stat", SqlDbType.VarChar).Value = "Closed";
                   cmd.CommandText = "UPDATE JobCard SET status = @stat WHERE Id = @jCard";

                   try
                   {
                       cmd.ExecuteNonQuery();
                       ViewActiveJobs.Visible = false;
                       ViewActiveJobs.AllowUserToAddRows = true;
                       ViewActiveJobs.Rows.RemoveAt(SelectedRow);
                       //ViewActiveJobs.Visible = true;
                   }
                   catch (Exception c)
                   {
                       MessageBox.Show(c.Message);
                   }
               }
           }
        }
4

1 に答える 1

4

これは予想される動作です。コンボボックスにフォーカスを設定するには、最初のクリックが必要です。コントロールにフォーカスがあると、2回目のクリックでドロップダウンリストが表示されます。

それはあなたの質問に答えますか?または、デフォルトの動作をオーバーライドする必要があると思いますか?DataGridView「はい」と答える前に、キーボードユーザーと、矢印キーを使用してセル間を移動するユーザーを検討してください。

それでも答えが「はい」の場合は、この関連する質問に対する私の答えを参照してください。基本的に、コントロールのプロパティが「EditOnEnter」に設定されていることを確認してから、EditModeイベントハンドラーのキーをDataGridView仮想的に「押して」コンボボックスをドロップダウンする必要があります。F4EditingControlShowing


余談ですが、コードに空のブロックを含めないでください。Catchそれを修正します。

于 2010-12-25T09:20:39.190 に答える