How many people suffer the flicker in C# Winforms Controls? I think a lot of it. There are a lot of solutions, but almost all of it are subclassing the control. But i found a simplier way, especially when you have your Form/UserControl already designed.
miércoles, 9 de septiembre de 2015
TableLayoutPanel without Flicker
Etiquetas:
C#,
code,
codigo,
DataGridView,
DoubleBuffered,
flickering,
method,
metodo,
programacion,
programar,
programming,
property,
reflection,
SetStyle,
TableLayoutPanel
miércoles, 1 de julio de 2015
Más Patrón estrategia
Hace tiempo que no escribo pero hace poco hicimos entrevistas en mi trabajo para contratar a alguien. Le propusimos un algoritmo tan sencillo como recorrer números del 1 al 100 y si son múltiplos de 3 mostrar fizz, si lo son de 5 buzz, si lo son de ambos fizzbuzz y si no mostrar simplemente el número. Obviamente, si el número es 15 por ejemplo, solo se mostraría fizz buzz. Aquí algunos ejemplos de los algoritmos que vi:
Etiquetas:
clase anonima,
clase interna anonima,
clases,
codigo,
Eclipse,
funcional,
interface,
java,
lambda,
lenguajes,
morethansimplycode,
NetBeans,
patron,
patron estrategia,
pattern,
programacion,
programar,
strategy
lunes, 11 de mayo de 2015
Expresiones Regulares para Números (StackOverflow)
Hace unos días encontré esta respuesta en StackOverflow:
Me llamo muchísimo la atención así que he decidido añadirlo al blog para no perderle. Quiero hacer hincapié en el final, en el que habla sobre la claridad del código de los patrones y como indentarlo correctamente. Estos patrones son al estilo PERL, puede que no funcionen correctamente en JAVA, aunque no debería haber problema. Copio la respuesta a continuación:
jueves, 5 de febrero de 2015
Enums y el Patrón Estrategia
Hoy toca hablar de los enums en Java y de cómo usarlos junto con el Patrón Estrategia. En Java, los enums son mucho más potentes que en la mayoría de los lenguajes, en los que solo se guarda una palabra con un número.
Etiquetas:
Android,
clase anonima,
clase interna anonima,
clases,
codigo,
Enum,
estatico,
funcional,
interface,
java,
patron estrategia,
programa,
programacion,
programar,
strategy
domingo, 11 de enero de 2015
Interfaces funcionales, Clases anónimas y Lambdas
Todo el mundo sabe que existen las interfaces pero… ¿Sabemos cuándo usarlas? Aquí mostraré uno de sus usos: Las Interfaces funcionales. También aprovecharé para hacer una pequeña introducción a las Lambdas.
Etiquetas:
aprender,
clase anonima,
clase interna anonima,
clases,
codigo,
funcional,
interface,
java,
lambda,
lenguajes,
metodo,
morethansimplycode,
programa,
programacion,
programar
viernes, 9 de enero de 2015
Trabajando con Graphics
El funcionamiento de la clase Graphics, que es la encargada de pintar las cosas en pantalla, es muy sencillo, lo ilustraré pintando un cuadrado en una ventana. Usaré este método de Graphics: fillRect(int x, int y, int width, int height). Para usarlo, debemos obtener una instancia de Graphics, puesto que no podemos instanciarla directamente. Para hacer esto, colocaremos un JPanel dentro de un JFrame y un JButon. Al pulsar el botón ejecutaremos este método:
private void bPintarActionPerformed(java.awt.event.ActionEvent evt) { // Obtenemos el graphics del panel en el que dibujaremos Graphics g = panel.getGraphics(); // Decimos lo que dibujar y que color queremos g.setColor(Color.RED); g.fillRect(10, 10, 100, 100); // Lo pintamos en el panel panel.paintComponents(g); }
Y veremos que pinta correctamente un cuadrado rojo.
Etiquetas:
clases,
codigo,
graficos,
Graphics,
informatica,
java,
metodo,
morethansimplycode,
NetBeans,
programa,
programacion,
programar
jueves, 8 de enero de 2015
Construyendo tu programa IV: Persistencia I: Ficheros
Como es normal, un programa de gestión que cuando lo cierras no guarda datos no es muy útil, así que toca hablar de la persistencia. Empezaremos por la persistencia en ficheros. Para empezar hay que hablar del concepto de Stream. Un Stream es un flujo de datos entre dos aplicaciones, en este caso el sistema de archivos. Hay varios Objetos Stream en java que representan, hoy hablaré solo del ObjectStream, que guarda objetos. Hay otros que se encargan de tipos primitivos etc.. pero eso lo veré en otra entrada.
Etiquetas:
aprender,
blog,
codigo,
construye tu programa,
construyendo tu programa,
Empleados,
III,
informatica,
java,
morethansimplycode,
NetBeans,
programa,
programacion,
programar
viernes, 2 de enero de 2015
Métodos Estáticos
Todos hemos leído la palabra static y hemos pensado que por que la voy a usar, si sin ponerla funciona. O la hemos puesto en todos lados por simple comodidad para programar sin objetos. Recordemos que los métodos estáticos son métodos que pertenecen a la clase, y con su nombre se pueden ejecutar, mientras que los no estáticos pertenecen a un objeto instanciado de esa clase. Y dicho esto voy a dar una sencilla regla:
Si el método en el que estamos trabajando, no usa ningún campo de un objeto de la clase en la que está, debería ser static. Por ejemplo:
Si tuviéramos este método:
Hasta aquí este breve post. Comentad más casos si se os ocurren.
Si el método en el que estamos trabajando, no usa ningún campo de un objeto de la clase en la que está, debería ser static. Por ejemplo:
Si tuviéramos este método:
public class Utilidades { public int calcularCuadrado(int i){ return i*i; } }Y, si quisiéramos usarlo, tendríamos que hacer esto:
public class Pruebas { public static void main(String[] args) { // Podríamos hacer esto (si lo vamos a usar más de una vez) Utilidades util = new Utilidades(); System.out.println(util.calcularCuadrado(2)); // O esto (si solo lo usamos aquí): System.out.println(new Utilidades().calcularCuadrado(2)); } }Pero si lo declaramos como static, puesto que no usamos ningún campo del objeto:
public static int calcularCuadrado(int i){return i*i;} public static void main(String[] args) { // Ahora nos da igual usarlo una o más veces, que así podremos hacerlo System.out.println(Utilidades.calcularCuadrado(2)); }Puede haber más casos en los que se podría usar, de hecho, seguro que los hay, pero con esto tenemos de sobra para discernir rápidamente cuando un método debería ser estático y cuando no. Usar constantes no cuenta cómo usar campos de un objeto instanciado, asique seguiría siendo static en ese caso.
Hasta aquí este breve post. Comentad más casos si se os ocurren.
Etiquetas:
aprender,
blog,
clases,
codigo,
estatico,
informatica,
java,
metodo,
morethansimplycode,
NetBeans,
programa,
programacion,
programar,
static
Suscribirse a:
Entradas (Atom)