DataGrid en Mono

Lenguajes compilados, IDEs, compiladores...

Moderadores: frank, dxfiles

Responder
Avatar de Usuario
lrga1975
Mensajes: 8
Registrado: Mar, 08 Ene 2013, 16:51
Ubicación: Villa Clara

DataGrid en Mono

Mensaje por lrga1975 » Mié, 09 Ene 2013, 10:05

Amigos, quiero mostrar los datos de una tabla en un DataGrid en un proyecto de Mono... Como lo hago :?: EnVisualStudio es muy fácil, con solo arrastrar y cambiar dos propiedades, pero quiero despedirme de Win2...
"Imagina un mundo sin fronteras..."
John Lennon

Avatar de Usuario
lrga1975
Mensajes: 8
Registrado: Mar, 08 Ene 2013, 16:51
Ubicación: Villa Clara

Re: DataGrid en Mono

Mensaje por lrga1975 » Mar, 24 Sep 2013, 10:25

Hola amigos, tuve la oportunidad de navegar por internet y encontré esto:
http://develmono.blogspot.com/2009/03/c ... velop.html
se los transcribo aquí para los que como yo solo vemos la internet muy lejano en el tiempo


Hola a todos aquellos que lean este blog ojala que se unan mas personas a los seguidores como dije en la primera entrada colocaremos cosas deverdad valiosas para aquellos que gusten de la programacion en .net y por sobre todo quienes quieran voltear al lado del Open source.

Tema: Como conectarse a un servidor SQL y Obtener un Data Grid de ello.

Antes que nada debemos Tener listo nuestro entorno de desarrollo en este caso Mono develop V 1.0 o 2.0 alpha (Esta de maravilla).
Y ahora comenzemos.
Hiba yo a escribir n cantidad de cosas referentes a las librerias al momento que en mono project lleva la plataforma .net framework a SO no windows pero este link lo dice mucho mejor de lo que yo lo pudiera describir asi que por favor leanlo y nosotros vamos a lo nuestro.

Utilizaremos un proyecto del tipo GTK# con un formulario simple para contruir nuestr aplicacion.
En este proyecto de nombre:ConexionSqlServer utilizaremos los siguientes controles en la ventana pricipal.

Gtk.Fixed Conten;
Gtk.Label LbTitle;
Gtk.Fixed fixed2;
Gtk.Button btnexecute;
Gtk.Entry txtsrv;
Gtk.Entry txtdb;
Gtk.Label label2;
Gtk.Label label3;
Gtk.Label label4;
Gtk.Label label5;
Gtk.Entry txtusr;
Gtk.Entry txtpass;
Gtk.Entry txtsrt;
Gtk.Entry txterror;

Todos estos controles disponibles desde la barra de herramientas principal,teniendo como resultado la siguiente ventana. (o algo similar esperemos).
Una vez diseñado nuestro entorno Visual vallamos al codigo, utilizaremos una funcion privada de nuestra ventana principal que sera quien ejecute y devuelva nuestro dataset para poder implementar un datagird.

Código: Seleccionar todo

private Boolean FcnDevuelveDataSet(string str,ref System.Data.DataSet SeteDb)
{

//Cadena De conexion creada atravez de los parametros del form
String cstring="Data Source=" + txtsrv.Text + ";Initial Catalog=" + txtdb.Text + ";Persist Security Info=False;User ID=" + txtusr.Text + ";PASSWORD=" + txtpass.Text;

System.Data.SqlClient.SqlDataAdapter exec = new
System.Data.SqlClient.SqlDataAdapter();

System.Data.SqlClient.SqlConnection cnns = default(System.Data.SqlClient.SqlConnection);

if (string.IsNullOrEmpty(str))
{
txterror.Text="Query Invalid";
return false;
}

try {

SeteDb = new System.Data.DataSet();

cnns = new System.Data.SqlClient.SqlConnection(cstring);

cnns.Open();

exec = new System.Data.SqlClient.SqlDataAdapter(str, cnns);
//ejecuta el query
exec.Fill(SeteDb);
// llena el dataset

try {

cnns.Dispose();
}
catch (Exception ex) {

txterror.Text = "Error :" + ex.Message;
}
return true;
}
catch (Exception ex)
{
txterror.Text = "Error :" + ex.Message;
try
{
cnns.Dispose();
}
catch
{
}
return false;
}
}
De esta manera tendremos una funcion que reciba un query y devuelva el ersultado de un consulta en una variable del tipo dataset.
Notara que es exactamente las mismas librerias conceptos tipos y clases que si utilizaran el system de microsoft solo que en el proximo post les dire cual es la diferencia de estas librerias.
Con esta funcion diriamos "que aburrido este post eso tal vez ya lo sabia" la parte magica viene a continuacion. EL DATA GRID
Como tal no existe un datagrid para gtk# predifinido de echo se construlle las vistas de grid view basadas en un control Treeview (visiten este link).
Si revisaron ese link anterior se daran cuenta que construir el grid row by row asi como las estructuras de columnas seria demasiado lento.
Mucha gente al rededor del mundo se ha dado a la tarea de construir la siguiente clase que puede seer implemetada facilmente como un datagrid soportando las propiedades datasource y binding.
La clase la pueden desacargar de este link
y una vez descargado la cls Datagrid.cs

Implementando el control dataGrid.

Código: Seleccionar todo

private ConexionSqlServer.DataGrid Grid;

//data Grid
this.Grid= new ConexionSqlServer.DataGrid();
this.Grid.Name="Grid";
this.Grid.SetSizeRequest(500,220);
this.Conten.Add(this.Grid);
Gtk.Fixed.FixedChild w15 = ((Gtk.Fixed.FixedChild)(this.Conten[this.Grid]));
w15.X = 33;
w15.Y = 250;
Lo cual agregara el control Datagrid dentro de nuestro formulario principal.


Por ultimo nuestra funcion Onclik de implementacion.

Código: Seleccionar todo

protected virtual void OnBtnexecuteClicked (object sender, System.EventArgs e)
{
System.Data.DataSet sete=null;
if (ValidaDatos())
{
FcnDevuelveDataSet(txtsrt.Text,ref sete);
if (sete.Tables.Count!=0)
{
Grid.DataSource=sete.Tables[0];
Grid.DataBind();
}
else
{
Grid.DataSource=null;
//Grid.DataBind();
}
}
}

Obteniendo nuestro pkño sql query :-D .



Bueno para todos aquellos que han llegado a este punto del post muchas felicidades tienen ahora una aplicacion de conexion a sql server desde una plataforma libre monodevelop la cual podran enpaquetar para usar en cualquier SO .

Si tienen dudas o si quieren el codigo fuente de la aplicacion escribambe o unanse al Blog.
Mi correo chavallb@gmail.com. un saludo y bye

Recuerden dibulguen el blog para lograr un mejor aprendizaje y

"FELICEZ CLASES.CS"






Publicado 18th March 2009 por Memo Chavez
"Imagina un mundo sin fronteras..."
John Lennon

Avatar de Usuario
lrga1975
Mensajes: 8
Registrado: Mar, 08 Ene 2013, 16:51
Ubicación: Villa Clara

Re: DataGrid en Mono

Mensaje por lrga1975 » Mar, 24 Sep 2013, 10:27

En un post anterior hago referencia a una clase DataGrid... también la encontré en internet y aquí la dejo:

Código: Seleccionar todo

// DataGrid.cs
namespace Mono.Data.GtkSharp
{
// notice System.Data is not references here

using System;
using System.Collections;
using System.ComponentModel;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Text;

using GLib;
using Gtk;

public class DataGridColumn
{
private string columnName = "";
private TreeViewColumn treeViewColumn = null;
public CellRendererText Renderer = null; // should be
internal

public string ColumnName {
get {
return columnName;
}
set {
columnName = value;
}
}

public TreeViewColumn TreeViewColumn {
get {
return treeViewColumn;
}
set {
treeViewColumn = value;
}
}
}

public class DataGrid : VBox {
private ListStore store;
private TreeView treeView;

public ArrayList gridColumns; // TODO: make Columns a
collection

public DataGrid () : base(false, 4) {
ScrolledWindow sw = new ScrolledWindow ();
this.PackStart (sw, true, true, 0);

treeView = new TreeView (store);
treeView.HeadersVisible = true;
//treeView.ModifyFont
(Pango.FontDescription.FromString ("courier new"));

gridColumns = new ArrayList(0);

sw.Add (treeView);

store = new ListStore (GLib.GType.String);

treeView.EnableSearch = true;
treeView.HeadersClickable = true;
dataMember = "";
dataSource = null;


}

ArrayList bindrows = null;
object resolvedDataSource = null;

private bool editable = true;

private object dataSource;

private string dataMember;

public int SelectedRow {
get {
TreeIter iter;
TreeModel model;
TreeSelection selection = treeView.Selection;
if (selection.GetSelected (out model, out
iter)) {
TreePath[] path =
selection.GetSelectedRows (out model);
return path[0].Indices[0]; // return
selected row
}
else
return -1; // not selected
}
}

public TreeIter SelectedIter {
get {
TreeIter iter;
TreeModel model;
TreeSelection selection = treeView.Selection;
if (selection.GetSelected (out model, out
iter))
return iter; // return seelcted iter
else
return TreeIter.Zero; // not selected
}

}

public TreeView View
{
get
{
return treeView;
}
}

public object DataSource
{
get
{
return dataSource;
}
set
{
dataSource = value;
}
}

public string DataMember
{
get
{
return dataMember;
}
set
{
dataMember = value;
}
}

public ListStore Store
{
get
{
return store;
}
}

public ArrayList Columns
{
get
{
return gridColumns;
}
}

public bool Editable {
get {
return editable; // not a good way to see if
its editable or not
// because various columns could be editable
and others non-editable
}

set {
editable = value;
if (value == true) {
for(int c = 0; c < gridColumns.Count;
c++) {
DataGridColumn col =
(DataGridColumn) gridColumns[c];
col.TreeViewColumn.Clickable
= true;
col.Renderer.Mode =
CellRendererMode.Editable;
col.Renderer.Editable = true;
}
treeView.RulesHint = true;
treeView.Selection.Mode =
SelectionMode.Single;
}
else {
for(int c = 0; c < gridColumns.Count;
c++) {
DataGridColumn col =
(DataGridColumn) gridColumns[c];
col.TreeViewColumn.Clickable
= false;
col.Renderer.Mode =
CellRendererMode.Inert;
col.Renderer.Editable =
false;
}
treeView.RulesHint = false;
treeView.Selection.Mode =
SelectionMode.Single;
}
}
}

public int AddNew()
{
// TODO: need to check if resolved data source is not
null

IBindingList b = (IBindingList) resolvedDataSource;

if (b.AllowNew) {
object obj = b.AddNew();
if (obj == null) {
//Console.Error.WriteLine("obj is
null");
}
else {

//Console.Error.WriteLine("Type: " +
obj.GetType().ToString());
bindrows.Add(obj);

TreeIter iter = NewRow();
for(int i = 0; i < gridColumns.Count;
i++)
SetColumnValue (iter, i,
String.Empty);

return bindrows.Count - 1;
}
}

return -1;
}

public int DeleteRow(int row)
{
if (row < 0)
return -1; // should throw an exception - out
of range

TreeIter iter = TreeIter.Zero;
if (store.IterNthChild(out iter, row) == false)
return -1;

IBindingList b = (IBindingList) resolvedDataSource;
if (b.AllowRemove) {
IList list = (IList) resolvedDataSource;
bindrows.RemoveAt(row);
store.Remove (ref iter);
list.RemoveAt (row);

return row;
}

return -1;
}

// sets the column count. beware, it clears
// use this if you are going to load each column and row
yourself
// instead of using DataBind() or DataLoad()
public void SetColumnCount (int columnCount)
{
Clear ();
dataMember = "";
dataSource = null;

GLib.GType[] theTypes = new GLib.GType[columnCount];
gridColumns = new ArrayList ();
for (int col = 0; col < columnCount; col++)
{
theTypes[col] = GLib.GType.String;
gridColumns.Add (new DataGridColumn ());
}
store.ColumnTypes = theTypes;
}

// load data from a data table or data set
public long DataBind ()
{
long rowsRetrieved = 0;

Clear ();

System.Object o = null;
o = GetResolvedDataSource (DataSource, DataMember);
resolvedDataSource = o;
IEnumerable ie = (IEnumerable) o;
ITypedList tlist = (ITypedList) o;
TreeIter iter = new TreeIter ();

PropertyDescriptorCollection pdc =
tlist.GetItemProperties (new PropertyDescriptor[0]);
gridColumns = new ArrayList(pdc.Count);

// define the columns in the treeview store
// based on the schema of the result
GLib.GType[] theTypes = new GLib.GType[pdc.Count];
for (int col = 0; col < pdc.Count; col++) {
theTypes[col] = GLib.GType.String;
}
store.ColumnTypes = theTypes;

bindrows = new ArrayList();

int colndx = -1;
foreach (PropertyDescriptor pd in pdc) {

colndx ++;

DataGridColumn gridCol = new DataGridColumn
();
gridCol.ColumnName = pd.Name;
gridColumns.Add (gridCol);
}

bindrows = new ArrayList();

foreach (System.Object obj in ie) {
ICustomTypeDescriptor custom =
(ICustomTypeDescriptor) obj;
PropertyDescriptorCollection properties =
custom.GetProperties ();

bindrows.Add(obj);

rowsRetrieved ++;
iter = NewRow ();
int cv = 0;
foreach (PropertyDescriptor property in
properties) {
object oPropValue = property.GetValue
(obj);
string sPropValue = "";
if (oPropValue.GetType ().ToString
().Equals("System.Byte[]")) {
//sPropValue =
SqlSharpGtk.GetHexString ((byte[]) oPropValue);

Console.Error.WriteLine("Byte[] value");
}
else
sPropValue =
oPropValue.ToString ();

SetColumnValue (iter, cv,
sPropValue);
cv++;
}
}

treeView.Model = store;
AutoCreateTreeViewColumns ();
return rowsRetrieved;
}

// borrowed from Mono's System.Web implementation
protected IEnumerable GetResolvedDataSource(object source,
string member)
{
if (source != null && source is IListSource) {
IListSource src = (IListSource) source;
IList list = src.GetList ();
if (!src.ContainsListCollection) {
return list;
}
if (list != null && list is ITypedList) {

ITypedList tlist = (ITypedList) list;
PropertyDescriptorCollection pdc =
tlist.GetItemProperties (new PropertyDescriptor[0]);
if (pdc != null && pdc.Count > 0) {
PropertyDescriptor pd = null;
if (member != null &&
member.Length > 0) {
pd = pdc.Find
(member, true);
} else {
pd = pdc[0];
}
if (pd != null) {
object rv =
pd.GetValue (list[0]);
if (rv != null && rv
is IEnumerable) {
return
(IEnumerable)rv;
}
}
throw new Exception
("ListSource_Missing_DataMember");
}
throw new Exception
("ListSource_Without_DataMembers");
}
}
if (source is IEnumerable) {
return (IEnumerable)source;
}
return null;
}

public void Clear ()
{
if (store != null)
{
store.Clear ();
store = null;
store = new ListStore (GLib.GType.String);
}
else
store = new ListStore (GLib.GType.String);

if (gridColumns != null)
{
for (int c = 0; c < gridColumns.Count; c++)
{
DataGridColumn gridCol =
(DataGridColumn) gridColumns[c];
if (gridCol.TreeViewColumn != null)
{
treeView.RemoveColumn
(gridCol.TreeViewColumn);
gridCol.TreeViewColumn =
null;
}
}
gridColumns.Clear ();
gridColumns = null;
}
}

public TreeIter NewRow ()
{
return store.Append();
}

public void AddRow (object[] columnValues)
{
TreeIter iter = NewRow ();
for(int col = 0; col < columnValues.Length; col++) {
string cellValue = columnValues[col].ToString
();
SetColumnValue (iter, col, cellValue);
}
}

public void SetColumnValue (TreeIter iter, int column, string
value)
{
GLib.Value cell = new GLib.Value (value);
store.SetValue (iter, column, cell);
}

public void SetColumnValue (TreeIter iter, int column, byte[]
value)
{
//string svalue = SqlSharpGtk.GetHexString (value);
//SetColumnValue (iter, column, svalue);
}

private void AutoCreateTreeViewColumns ()
{
for(int col = 0; col < gridColumns.Count; col++) {
// escape underscore _ because it is used
// as the underline in menus and labels
StringBuilder name = new StringBuilder ();
foreach (char ch in ((DataGridColumn)
gridColumns[col]).ColumnName) {
if (ch == '_')
name.Append ("__");
else
name.Append (ch);
}
TreeViewColumn tvc = CreateColumn (col,
name.ToString ());
AppendColumn (tvc);
}
}

public int AppendColumn(TreeViewColumn tvc)
{
return treeView.AppendColumn (tvc);
}

private void TextCellEdited (object o, EditedArgs args)
{
IBindingList b = (IBindingList) resolvedDataSource;
if (b.AllowEdit) {
// ITypedList may help you figure out how to
convert
// between different data types
// such as, how to display numbers, dates,
etc...

TreePath path = new TreePath (args.Path);
TreeIter iter;
store.GetIter (out iter, path);
int i = path.Indices[0];

TreePath cpath;
string cellValue = args.NewText;

TreeViewColumn tvcolumn;
treeView.GetCursor (out cpath, out tvcolumn);
int c = 0;
for(c = 0; c < gridColumns.Count; c++) {
TreeViewColumn tvc =
((DataGridColumn) gridColumns[c]).TreeViewColumn;
if (tvcolumn == tvc) {

Console.Error.WriteLine("Column clicked: Column Name: " + tvcolumn.Title);
Console.Error.WriteLine("
Ordinal: " + c.ToString());
break;
}
}

if (c >= gridColumns.Count)
Console.Error.WriteLine("tv col not
found");

ICustomTypeDescriptor custom =
(ICustomTypeDescriptor) bindrows[i];
PropertyDescriptorCollection properties =
custom.GetProperties ();
PropertyDescriptor pd = properties[c];
pd.SetValue(bindrows[i], cellValue);

Console.Error.WriteLine(" Row number: " +
path.Indices[0].ToString());
Console.Error.WriteLine(" Cell Value: " +
cellValue);

((IEditableObject) bindrows[i]).BeginEdit();
SetColumnValue(iter, c, cellValue);
((IEditableObject) bindrows[i]).EndEdit();
}
}

public TreeViewColumn CreateColumn (int columnNum, string
columnName)
{
TreeViewColumn treeViewCol = new TreeViewColumn ();
CellRendererText renderer = new CellRendererText ();
treeViewCol.Clickable = true;
treeView.RulesHint = true;

treeView.Selection.Mode = SelectionMode.Single;
//treeView.Selection.Mode = SelectionMode.Multiple;

// Editable, Activatable, Inert
renderer.Mode = CellRendererMode.Editable;
//renderer.Family = "courier new";
renderer.Editable = true;
renderer.Edited += new EditedHandler
(TextCellEdited);
treeViewCol.Title = columnName;
treeViewCol.PackStart (renderer, true);
treeViewCol.AddAttribute (renderer, "text",
columnNum);

DataGridColumn gridCol = (DataGridColumn)
gridColumns[columnNum];
gridCol.Renderer = renderer;
gridCol.TreeViewColumn = treeViewCol;

return treeViewCol;
}
}
}



// $ mcs /out:TestDataGrid.exe TestDataGrid.cs DataGrid.cs
-pkg:gtk-sharp-2.0 /r:System.Data.dll
// TestDataGrid.cs
namespace Mono.Data.GtkSharp
{
using System;
using System.Collections;
using System.Collections.Specialized;
using System.Configuration;
using System.Data;
using System.Data.Common;
using System.Data.SqlTypes;
using System.Text;
using System.IO;
using System.Reflection;
using System.Runtime.Remoting;
using System.Runtime.InteropServices;
using System.Diagnostics;

using Gdk;
using Gtk;

public class TestDataGrid
{
private DataTable table;
private Gtk.Window win;
private DataGrid grid;
//private TextView textView;

public static readonly string ApplicationName = "Gtk#
DataGrid Test";

public TestDataGrid ()
{
CreateGui ();
}

public DataGrid Grid {
get {
return grid;
}
}

public void Show ()
{
win.ShowAll ();
}

public void CreateGui ()
{
win = new Gtk.Window (ApplicationName);
win.DeleteEvent += new Gtk.DeleteEventHandler
(OnWindow_Delete);
win.BorderWidth = 4;
win.SetDefaultSize (600, 500);

VBox vbox = new VBox (false, 4);
win.Add (vbox);

MenuBar mb = CreateMenuBar ();
vbox.PackStart (mb, false, false, 0);

VPaned vpaned = new VPaned ();
vbox.PackStart (vpaned, true, true, 0);
grid = CreateOutputResultsDataGrid();
vpaned.Add1 (grid);
}

DataGrid CreateOutputResultsDataGrid ()
{
DataGrid grid = new DataGrid ();

//grid.View.ButtonReleaseEvent +=
// new Gtk.ButtonReleaseEventHandler
(OnDataGridButtonRelease);
//grid.Editable = false;

return grid;
}

void OnWindow_Delete (object o, Gtk.DeleteEventArgs args)
{
QuitApplication();
}

void QuitApplication ()
{
Application.Quit ();
}

public static void DoEvents ()
{
while (Application.EventsPending ())
Application.RunIteration ();
}

public DataTable BuildDataTableSample()
{
table = new DataTable();

int maxColumns = 5;
int maxRows = 3;

for(int i = 0; i < maxColumns; i++) {
string columnName =
String.Format("Column{0}", i);
table.Columns.Add(columnName);
}

for(int r = 0; r < maxRows; r++) {
DataRow row = table.NewRow();
for(int c = 0; c < table.Columns.Count; c++)
{
string cellValue =
String.Format("(Row{0},Column{1})", r, c);
row[c] = cellValue;
}
table.Rows.Add(row);
}

return table;
}

void OnMenu_DumpTable (object o, EventArgs args)
{
Console.Error.WriteLine("__=========== T a b l e
D u m p =========__");
Console.Error.WriteLine("Row Count: " +
table.Rows.Count.ToString());
for(int r = 0; r < table.Rows.Count; r++) {
DataRow row = table.Rows[r];
StringBuilder sb = new StringBuilder();
for(int c = 0; c < table.Columns.Count; c++)
{
string s = row[c].ToString();
sb.Append(s);
sb.Append(" ");
}
Console.Error.WriteLine(sb.ToString());
}

Console.Error.WriteLine("=-----------------------------------------------=");
}

void OnMenu_Editable (object o, EventArgs args)
{
grid.Editable = !grid.Editable;
}

void OnMenu_AddNew (object o, EventArgs args)
{
AddNew();
}

void OnMenu_DeleteSelectedRow (object o, EventArgs args)
{
int selectedRow = 0;
selectedRow = grid.SelectedRow;
if (selectedRow >= 0)
grid.DeleteRow (selectedRow);
}

void AddNew()
{
grid.AddNew();
}

public MenuBar CreateMenuBar () {
MenuBar menuBar = new MenuBar ();
Menu menu;
MenuItem item;
MenuItem barItem;

menu = new Menu ();

item = new MenuItem ("Add Row");
item.Activated += new EventHandler (OnMenu_AddNew);
menu.Append (item);

item = new MenuItem ("Dump Table");
item.Activated += new EventHandler
(OnMenu_DumpTable);
menu.Append (item);

item = new MenuItem ("Editable");
item.Activated += new EventHandler (OnMenu_Editable);
menu.Append (item);

item = new MenuItem ("Delete Selected Row");
item.Activated += new EventHandler
(OnMenu_DeleteSelectedRow);
menu.Append (item);

barItem = new MenuItem ("Test");
barItem.Submenu = menu;
menuBar.Append (barItem);

return menuBar;
}

public static int Main (string[] args)
{
Application.Init ();
TestDataGrid test = new TestDataGrid ();
DataTable sampleTable = test.BuildDataTableSample();
test.Grid.DataSource = sampleTable;
test.Grid.DataBind();
test.Show ();
DoEvents ();
//test.Grid.Editable = false;
Application.Run ();
return 0;
}
}
}
"Imagina un mundo sin fronteras..."
John Lennon

Avatar de Usuario
hugo
Mensajes: 1430
Registrado: Sab, 07 Ago 2010, 14:09
Ubicación: La Habana
Contactar:

Re: DataGrid en Mono

Mensaje por hugo » Dom, 29 Sep 2013, 20:00

lrga1975, por favor para la próxima utiliza el botón Code al citar código fuente, lo cual facilita la lectura. Por lo demás, gracias por tu participación y aporte
Lo único que necesita el mal para triunfar es que los hombres buenos no hagan nada.
- Edmund Burke

Responder