Jump to content
Sign in to follow this  
D3POD

Criar Custom Datagridview

Recommended Posts

D3POD

Boas, preciso de mais uma ajuda...

Tenho um dtagridview que recebe os valores de duas tabelas.

Está a funcionar tudo bem, mas queria saber se existe uma forma de eu definir cada coluna infividualmente.

Basicamente o que pretendia era por exemplo definir via código a coluna[0], a coluna[1]... etc

Por exemplo... queria que a coluna [0] apresenta-se a coluna de valores que neste momento obriga-me a mexer na query e colocar o nome da coluna em primeiro lugar para que apareça na column[0].

Há alguma forma de colocar algo tipo dgv.columns[0]. (qualquer coisa) 

 

Cumprimentos

 

Share this post


Link to post
Share on other sites
N3lson

Preenche a datagrid com Datarow e adiciona as colunas manualmente, eu faço assim

            DataRow row = null;
            DataTable dtOrdens = new DataTable("Ultimas Ordens");
            this.gridview.DataSource = null;
            dtOrdens.Rows.Clear();    
			string query = "SELECT * FROM tabela WHERE xxx= yyyy";

                using (MySqlConnection con = new MySqlConnection(Controle.ConSql))
                {
                    using (MySqlCommand cmd = new MySqlCommand(query, con))
                    {
                        con.Open();

                        List<string> colunas = new List<string>() { "ID", "Equip", "Data", "Obs. da Avaria", "Operador","Estado" };

                        DataColumn Print = new DataColumn("Print", typeof(Bitmap));
                        DataColumn Ver   = new DataColumn("Ver", typeof(Bitmap));

                        dtOrdens.Columns.Add(Print);
                        dtOrdens.Columns.Add(Ver);

                        foreach (string coluna in colunas)
                        {
                            dtOrdens.Columns.Add(coluna);
                        }

                        MySqlDataReader readerOrd = readerOrd = cmd.ExecuteReader();

                        if (readerOrd.HasRows)
                        {
                            lblSemOrdens.Visible = false;

                            while (readerOrd.Read())
                            {
                                row = dtOrdens.NewRow();

                                Bitmap printed = new Bitmap(Manutencao.Properties.Resources.printed);
                                Bitmap notPrinted = new Bitmap(Manutencao.Properties.Resources.notPrinted);
                                Bitmap OrdId = new Bitmap(Manutencao.Properties.Resources.ver);

                                int estadoImpressao = Convert.ToInt16(readerOrd["print"]);

                                row[0] = estadoImpressao == 2 ? printed : notPrinted ;
                                row[1] = OrdId;
                                row[2] = readerOrd["id"];
                                row[3] = readerOrd["maquina"].ToString().ToUpper();
                                row[4] = funcao.DataPT(readerOrd["data_ord"].ToString());
                                row[5] = funcao.RemoverEnter(readerOrd["obs_avaria"].ToString()).ToUpper();
                                row[6] = funcao.RetornarOperador(readerOrd["operador"].ToString());
                                row[7] = funcao.RetornarPrint(estadoImpressao);

                                dtOrdens.Rows.Add(row);
                            }
                            readerOrd.Close();

                            this.gridview.DataSource = dtOrdens;

                            this.gridview.Columns["Print"].HeaderText = "";
                            this.gridview.Columns["Print"].FillWeight = 11;
                            this.gridview.Columns["Ver"].HeaderText = "";
                            this.GridOrdens.Columns["Ver"].FillWeight = 11;

                            this.gridview.Columns["ID"].Visible        = false;
                            this.gridview.Columns["Equip"].FillWeight  = 22;
                            this.gridview.Columns["Data"].FillWeight   = 40;
                            this.gridview.Columns["Data"].Visible = false;
                            this.gridview.Columns["Estado"].FillWeight = 40;
                       }
                       else
                       {
                            lblSemOrdens.Visible = true;
                       }
                    }
                    con.Close();
                }

 

Edited by N3lson

You can't do it, kid. But don't worry, my boy. You're not the only one. No one else can do it.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.