Ceci est probablement facile pour les experts, mais j'essaie de trouver comment ajuster les colonnes d'une grille de données dans une application Windows en utilisant C# dans Visual Studio 2015Redimensionnement automatique des colonnes dans une grille de données à partir de SQL en C#
Mon code est ci-dessous. J'ai lu des commandes comme AutoResize mais je ne peux pas comprendre comment et où le mettre dans mon code. Tout ce que je viens d'essayer arrive avec des erreurs de syntaxe ou il n'y a pas la possibilité de redimensionner:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace WindowsFormsApplication5
{
public partial class Main : Form
{
int BugID = 0;
public Main()
{
InitializeComponent();
}
private void txtUser_TextChanged(object sender, EventArgs e)
{
}
Reset();
FillDataGridView();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "There is an error. Please review");
}
finally
{
sqlCon.Close(); // close the connection
}
}
void FillDataGridView() // The below is to display the search results in the Data Grid View box using the stored procedure for search results
{
if (sqlCon.State == ConnectionState.Closed)
sqlCon.Open();
SqlDataAdapter sqlDa = new SqlDataAdapter("BugViewOrSearch", sqlCon);
sqlDa.SelectCommand.CommandType = CommandType.StoredProcedure;
sqlDa.SelectCommand.Parameters.AddWithValue("@BugIssue", txtSearch.Text.Trim());
DataTable dtbl = new DataTable();
sqlDa.Fill(dtbl);
dgvIssues.DataSource = dtbl;
sqlCon.Close();
}
private void textBox1_TextChanged(object sender, EventArgs e)
{
}
private void btnSearch_Click(object sender, EventArgs e)
{
try
{
FillDataGridView();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "There is an error. Please review");
}
}
private void dgvIssues_DoubleClick(object sender, EventArgs e)
{
if(dgvIssues.CurrentRow.Index != -1) // For updating an issue when double clicking on a row/issue
{
BugID = Convert.ToInt32(dgvIssues.CurrentRow.Cells[0].Value.ToString());
txtUser.Text = dgvIssues.CurrentRow.Cells[1].Value.ToString();
txtSubject.Text = dgvIssues.CurrentRow.Cells[2].Value.ToString();
txtDescription.Text = dgvIssues.CurrentRow.Cells[3].Value.ToString();
btnCreate.Text = "Update Issue"; // Changes the button from 'Create Issue' to 'Update Issue'
btnDelete.Enabled = true;
}
}
void Reset() // To reset all field of the form
{
txtUser.Text = txtSubject.Text = txtDescription.Text = "";
btnCreate.Text = "Create Issue";
BugID = 0;
btnDelete.Enabled = false;
}
private void btnRefresh_Click(object sender, EventArgs e)
{
Reset(); // Calls the reset function above
}
private void Main_Load(object sender, EventArgs e)
{
Reset();
FillDataGridView();
// To show all bugs/issues in the database
}
}
}
J'ai besoin des colonnes pour adapter le texte ou au moins remplir l'espace gris.
Tous les conseils seraient utiles.
Merci
Vous voudrez peut-être supprimer tout ce qui a trait à SQL à partir de votre exemple de code, pour le rendre concis. En ce qui concerne vos problèmes, peu importe d'où proviennent les données. – uncoder
** [Méthode DataGridView.AutoResizeColumns] (https://msdn.microsoft.com/en-us/library/system.windows.forms.datagridview.autoresizecolumns (v = vs.110) .aspx) ** La saisie dans le méthode (aka "commande") et en appuyant sur F1 vous dira tout ce que vous devez savoir – Plutonix
Je vois que vous avez remarqué que je ne suis pas tout cela avec la terminologie de la programmation. Laisse-moi tranquille. J'essaie –