Ir para conteúdo
Fórum Script Brasil
  • 0

Imprimir dados do DataGridView já carregado


Paty007

Pergunta

Muito boa noite, pessoal.

Estou precisando imprimir os dados que estão sendo exibidos em um DataGridView e não sei como usar o System.Drawing.Printing direito. Até assisti a algumas aulas, mas nada que suprisse a minha necessidade.

Alguém poderia me ajudar?

Estou usando o vb. Net 2012 ultimate e Access como bando de dados.

 

Desde já agradeço.

Link para o comentário
Compartilhar em outros sites

3 respostass a esta questão

Posts Recomendados

  • 0

Salve,

Precisa mesmo ser em .net? 

Não seria melhor jogar este conteúdo em uma div e depois chamar o método "Print()" do objeto "Window" em javascript ?

Exemplo:

Default.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace Impressao
{
    public partial class Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            List<string> content = new List<string>() { "estou com preguiça", "de pensar no momento" };
            GridView1.DataSource = content;
            GridView1.DataBind();
        }
    }
}

Default.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="Impressao.Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script   src="https://code.jquery.com/jquery-1.12.1.js"   integrity="sha256-VuhDpmsr9xiKwvTIHfYWCIQ84US9WqZsLfR4P7qF6O8="   crossorigin="anonymous"></script>
</head>
<body>
    <form id="form1" runat="server">
    <div id="relatorio">
        <asp:GridView ID="GridView1" runat="server">
        </asp:GridView>    
    </div>
    <input id="btnImprimir" type="button" value="Imprimir" />
    </form>
</body>
</html>
<script>
    $(document).ready(function () {
        $('#btnImprimir').on('click', function (event) {
            event.preventDefault();
            event.stopPropagation();
            window.open('Impressao.aspx', 'Impressao', null, true);
            return false;
        });
    });
</script>

Impressao.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Impressao.aspx.cs" Inherits="Impressao.Impressao" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script   src="https://code.jquery.com/jquery-1.12.1.js"   integrity="sha256-VuhDpmsr9xiKwvTIHfYWCIQ84US9WqZsLfR4P7qF6O8="   crossorigin="anonymous"></script>
</head>
<body>
    <form id="form1" runat="server">
    <div id="conteudo_relatorio"></div>
    </form>
</body>
</html>
<script>
    $(document).ready(function () {
        if (window.opener != null) {
            var relatorio = window.opener.document.getElementById('relatorio');
            if (relatorio) {
                document.getElementById('conteudo_relatorio').innerHTML = relatorio.innerHTML;
                window.print();
            }
        }
    });
</script>

 

Link para o comentário
Compartilhar em outros sites

  • 0

Oi Paty,

Agora que observei sua pergunta melhor...."DataGridView" (WindowsForms).... vou pensar em algo por aqui e posto depois.

 

[]s

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            using (var conn = new SqlConnection("Data Source=WELLINGTON-PC\\SQLEXPRESS; Initial Catalog=Northwind; Integrated Security=true;"))
            {
                var da = new SqlDataAdapter("SELECT CategoryId, CategoryName, Description FROM Categories ORDER BY CategoryName", conn);
                var ds = new DataSet();
                da.Fill(ds, "Categories");
                dataGridView1.DataSource = ds;
                dataGridView1.DataMember = "Categories";
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            printDocument1.Print();
        }

        private void printDocument1_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)
        {
            Bitmap bm = new Bitmap(this.dataGridView1.Width, this.dataGridView1.Height);
            dataGridView1.DrawToBitmap(bm, new Rectangle(0, 0, this.dataGridView1.Width, this.dataGridView1.Height));
            e.Graphics.DrawImage(bm, 0, 0);
        }
    }

 

Link para o comentário
Compartilhar em outros sites

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,4k
×
×
  • Criar Novo...