La Terminal

Archive for the ‘Guías, Manuales y Tutoriales’ Category

Bueno estoy pensando seriamente comprarme una xbox360, siendo sinceros me agrada más la idea de comprar una PS3 pero es una inversión muy alta y soy un jugador ocasional, así que el punto medio entre la Wii y la PS3 es la XCaja 😄

Me he estado documentando, como con casi todo lo que compro así no me llevo sorpresas y aunque le tengo algo de temor al aro rojo de la desgracia pues los títulos que existen me han convencido, solo falta que la consola tenga la nueva placa Jasper con CPUy GPU de 65 nanómetros, la placa anterior Falcon es de CPU y GPU de 90 nanómetros.

Entiendo que será difícil encontrar una con la nueva placa pero no imposible, aunque tenga que esperar a principios del siguiente año prefiero esperar.

Ahora viene lo bueno como identificarlas de acuerdo al artículo de Engadget en Español donde citan a Ben Heck (sino has escuchado de él busca en google XD) solo debemos consultar la etiqueta donde se aprecia el código de barras, lo importante es ver el voltaje.

voltaje falcon

voltaje falcon

voltaje jasper

voltaje jasper

Fuente noticia y Fotos: Engadget en Español.

Aunque suene raro es increíble que lo mejor que pueda sacar MS para tunear su propio sistema operativo sean recomendaciones tan viejas que algunas las utilizo desde Windows 98.

La guía se centra en los siguientes apartados:

Realizar cambios de configuración que ayuden a sentir que el equipo responde mejor cuando se use.

Uso de hardware para aumentar la velocidad física actual de una computadora.

Realizar cambios de configuración que ayuden al equipo iniciar más rápido.

Hacer al equipo más seguro puede ayudar a incrementar el rendimiento.
Monitorear el rendimiento ocasionalmente puede ayudar a detener problemas que después pueden ser más grandes.

Para los iniciados puede ser muy útil pero si ya tienes algo de experiencia con Windows algunas de las recomendaciones son poco o nada novedosas.

Descargar el pdf.

Fuente: filenetworks.blogspot.com

mysql

Normalmente cuando se requiere un servidor de base de datos gratuito y de uso extendido pensamos en MySQL, pero ¿que pasa cuando una aplicación por cuestiones de compatibilidad no puede ejecutarse en las versiones más nuevas?

Eso es lo que ocurrió en un proyecto que se esta llevando a cabo, primero intentamos hacer correr la aplicación en realidad montar la BD (de una versión 4.0.12) en la versión 5.0.5 de Mysql pero debido a la gran cantidad de cambios no fue posible, de hecho se cambio la contraseña para adecuarla a la versión 4.0.12 pero solamente hasta ahí llegamos.

En ese punto me pone a pensar en el poco compromiso que tienen algunas compañías en ofrecer un producto cada vez mejor, es decir, el soporte de la versión 4 de Mysql ya acabo y lo de menos sería entender que están utilizando la versión 4.1 en el programa pero no es una versión más anterior. Pero ni hablar que acá se buscan soluciones y no culpables =P

Para hacer trabajar 2 versiones de Mysql solo necesitamos leer un poco en la documentación y listo, a continuación solo les proporcionare la forma en que se implemento en el proyecto pero existen variantes interesantes que pueden ser de más utilidad.

Enlaces utilizados

2.3 Instalar Mysql en Windows, pasando por todos los temas y subtemas.

No es indispensable la lectura de todo pero ayuda a comprender el funcionamiento.

5.11 Ejecutar más de un servidor MySQL en la misma máquina, pasando por todos los temas y subtemas.

Recomendación:

No se debería agregar el directorio bin de MySQL al PATH de Windows si se están ejecutando múltiples servidores MySQL en el mismo ordenador. Para comprobar esto consulte el enlace al tema 2.3.12. En caso de omitir este paso y el directorio bin de mysql se encuentra en el path el segundo mysql no trabajará.

Ya que los programas cliente y utilidades de Mysql no pueden localizar el archivo my.ini (configuración) y se intenta cargar desde el directorio de Windows. Si lo encuentra la configuración de ese archivo se utiliza para todas las versiones instaladas, en este caso como las versiones son 4 y 5 ocurre un error ante las diferencias.

NOTA: Estos pasos son solo una sugerencia, no me hago responsable de los errores que se puedan originar del mismo. Se probo en 2 versiones de Windows (XP Professional y 2003 Server Business) con una instalación previa y funcional de mysql 4.0.12. La información que muestro corresponde a una configuración, y por lo tanto se debe entender que solo una pequeña muestra de lo que se puede realizar con los archivos de configuración y comandos de mysql.

Instalación:

El tipo de instalación elegida fue por un archivo ZIP por hacer más sencillo (a mí parecer) el proceso.

Una vez que se ha descargado la versión se descomprime y se crea una carpeta, para este caso el nombre a utilizar será (Mysql5) y se ubicará en C:\.

La otra versión también se encuentra en C:\ hasta este paso debemos de tener 2 carpetas con mysql.

C:\

|_ mysql

|_ mysql5

Cada una con sus respectivos subdirectorios y bases de datos. Lo siguiente debería ser la instalación con la instrucción C:\mysql5\bin>mysqld -install desde la línea de comandos, sin embargo aunque se instale se obtendría un error al intentar ejecutarlo. De hecho lo más seguro es que generé un error al intentar instalarlo como un servicio si ya existe otra versión instalada. Más abajo se comenta el porque de esta situación.

Archivo de Configuración:

Las opciones por default son leídas de los siguientes archivos y en el siguiente orden:

C:\my.ini C:\my.cnf C:\WINDOWS\my.ini C:\WINDOWS\my.cnf C:\Archivos de programa\
MySQL\MySQL Server 5.0\my.ini C:\Archivos de programa\MySQL\MySQL Server 5.0\my.
cnf

En nuestro caso la ruta C:\Archivos de programa\MySQL\MySQL Server 5.0 se convierte a C:\mysql5, como se menciono en la recomendación al inicio en el path de windows no debe agregar la ruta de mysql, ¿pero entonces como le indicamos la configuración al nuevo mysql?

En la carpeta mysql5 encontraremos diferentes archivos INI (configuración), tomaremos el más simple (my.ini) y le haremos los cambios necesarios. Por default el servidor de mysql se instala como servicio con el nombre MySQL y en el puerto 3306, por lo tanto el nuevo mysql debe tener otro nombre y puerto para este ejemplo quedará con el nombre MySQL5 y el puerto 3307. Si no se cambian los valores se obtendrá un error o comportamiento anormal.

Además es necesario cambiar la ruta del servidor de base de datos y el directorio de los datos. El basedir y datadir respectivamente,

  • El primero quedaría: basedir= C:/mysql5
  • El segundo sería: datadir= C:/mysql5/data

A continuación lo guardaremos con otro nombre, para este ejemplo el nombre será my5.ini, en la misma carpeta C:\mysql5

El inicio (ejecución) de mysql puede ser desde la línea de comandos (ver 5.11.1.2) o como un servicio (ver 5.11.1.2) en este caso se instalo y se inicio como un servicio con la instrucción:

C:\mysql5\bin>mysqld –install MySQL5 –defaults-file=C:\mysql5\my5.ini.

Donde la instrucción –install le indica el nombre del servicio que tomará, además omite la lectura del archivo de opciones por default, donde el nombre es mysqld. Ver  5.11.1.2 para más detalles.

Mientras que la instrucción –defaults-file= Obliga  a leer las opciones por default del archivo dado en este caso my5.ini.

Ahora solo falta reiniciar (es Windows xDD) y listo. Las dos versiones de Mysql trabajarán sin problemas, existen configuraciones del archivo INI que permiten trabajar con diferentes versiones y los mismos datos pero eso queda fuera de esta guía, además que no es nada aconsejable.

Si te sirvió deja un comentario 😀 si lo quieres compartir solo cita la fuente o sea este blog 😉

Fuente: Mysql.

Imagen: http://www.lnds.net/images/

Ok, esto debió salir ayer pero hasta hoy me dí el tiempo necesario para publicarlo.

Indagando un poco sobre frameworks me encontré con uno interesante de nombre CodeIgniter, no he tenido grandes complicaciones para echarlo andar y seguir ejemplos, tiene una documentación clara aunque muy concentrada (muy corta para mi gusto).

Así que buscando más sobre el tema llegue al blog de Isern Palaus el cual se centra en los siguientes temas Música, Programación y Diseño.

De hecho ya tuve la oportunidad de tratar con él por email (a causa de unos post sobre CodeIgniter) y es una gran persona, me respondió en horas unas dudas. Desde ayer ya forma parte de Los Blogs que visitó. Así que los invito a que lo conozcan.

Por cierto tiene unos post de iniciación en el framework interesantes como este Codeigniter iniciación y configuración.

Saludos.

Etiquetas:

En ocasiones necesitamos que nuestro PDF generado con la clase FPDF o derivadas tengo una mejor presentación con el uso de la fuentes, pero las fuentes que tiene la clase son muy pocas, si revisamos la documentación encontramos que la instrucción SetFont explica lo siguiente:

“Establece la fuente usada para imprimir cadenas de carácteres. Es obligatorio invocar este método por lo menos una vez antes de imprimir texto o el documento resultante no será válido.

La fuente puede ser una estándar o una adicionada via el método AddFont().”

Es decir, las fuentes estándar son aquellas que vienen con la clase y para su uso se debe tener acceso a los ficheros de medida. No podemos usar las fuentes de forma directa.

El método AddFont describe de forma muy clara aunque a la vez escueta la forma de agregar fuentes.

“Importa una fuente TrueType o Type1 y la hace disponible. Es necesario primero generar un archivo de definición de fuente con la utilidad makefont.php.

El archivo de definición (y el archivo de fuente mismo cuando es incorporado) debe estar presente en el directorio de fuentes. Si no puede ser encontrado, es generado el error <Could not include font definition file>.”

Bueno agregar una fuente de acuerdo al Tutorial 7 no es tan fácil como agregarla con un define(‘ruta’), ya que se requiere un fichero de medidas y un archivo de definición de fuente. Si hay otra forma más sencilla adelante expreselo en los comentarios 😀

Añadir una nueva fuente requiere tres pasos para las TrueType (las comunes):
* Generación del fichero de medidas (.afm)
* Generación del fichero de definición de la fuente (.php)
* Declaración de la fuente en el script

En el tutorial esta muy bien explicado y el archivo de la clase viene acompañado con un ejemplo, de todas formas hice la prueba con una fuente y no tuve mayor problema.

Para el ejemplo NO manejo la misma cantidad de pasos pero el resultado es el mismo, además utilizo la siguiente <Ruta: C:\servidor_web\fpdf> y tengo la siguiente estructura de directorios:

servidor_web <localhost>
|_genera_fuente.php
|__ FPDF
|____ afm
|____ doc
|____ font
|____ makefont
|_______ makefont.php
|____ pfm
|____ tutorial

El directorio AFM (Adobe Font Metrics) contiene el programa tff2pt1 del proyecto “True Type Font to Postscript Type 1 Converter“. Puede descargarse desde la página del proyecto o desde la liga de FPDF, antes de descargar cualquier cosa sigan leyendo hasta terminar el paso uno.

El directorio PFM (Printer Font Metrics) contiene el programa pfm2afm una utilidad para convertir ficheros de medidas. Se puede descargar desde la liga de FPDF, por cierto no encontré referencia hacia alguna página oficial de la utileria y la fecha que muestra el archivo es de 1991 😦

El directorio Makefont tiene el archivo makefont.php que genera el archivo de definición de fuente y que podemos utilizar a través de un archivo php.

IDENTIFICACIÓN DEL TIPO.
El paso 1 es identificar el tipo de fuente a utilizar (TrueType o Type1), ya que si se tratase del segundo caso (Type1) ya nos ahorramos algo de trabajo y pasaremos al paso 3, sino es así continuar en el paso 2-b.

Nota: Además de la fuente Type1 se necesita un archivo AFM, si en lugar de este último se tiene un archivo PFM continuar en el paso 2-a.

GENERACIÓN DEL FICHERO DE MEDIDAS.
El paso 2 consiste en generar un archivo AFM (el fichero de medidas).

2-a. Si su archivo de medidas esta en formato PFM se debe convertir con la ayuda de la utilidad PFM2AFM, el enlace en párrafos anteriores.

En una ventana de DOS (si esa pantallita en negro sin soporte para ratón y sin iconos xDD) escribir:
pfm2afm infile [outfile] -a = pfm2afm evanescence.pfm evanescence.afm -a

infile corrresponde al nombre del archivo PFM
outfile corresponde al nombre del archivo AFM que será generado.
El parámetro -a se los quedo a deber 😛
Como resultado tendremos el archivo de medidas en formato AFM.

2-b. Se debe generar un archivo AFM con la utilidad ttf2pt1, el enlace en párrafos anteriores.

En una venta de DOS escribir:
ttf2pt1 -a infile.ext [outfile] = ttf2pt1 -a impact.ttf impact

infile corresponde al nombre del archivo con su extensión TTF (Fuente TrueType)
outfile el nombre que tendrá el archivo de medidas, no es necesario indicar la extensión.
El parámetro -a se los quedo a deber 😛

Como resultado obtendremos una lista extensa como salida en la pantalla y el mensaje Finished – font files created. Se generan dos archivos el AFM que nos interesa y otro con extensión T1A que podemos borrar con toda confianza.

Nota: Las fuentes se encuentran en las respectivas carpetas para evitar problemas de rutas, los archivos resultantes también se generan en las respectivas carpetas.

El tutorial 7 tiene como ejemplo la fuente Comic Sans y la ruta c:\windows\fonts\comic.ttf, la cual no probe pero los invito a intentarlo 🙂


GENERACIÓN DEL FICHERO DE DEFINICIÓN DE LA FUENTE
.
El paso 3 ya que se tiene el archivo de medidas AFM es generar la definición de la fuente con ayuda del archivo makefont.php. Aunque su uso es sencillo tal vez la fuente o el idioma en el que se utilice requiera ciertos ajustes en los parámetros de la función que realiza la definición (Como el uso del símbolo del Euro € o caracteres aún más especiales).

La función MakeFont tiene los siguientes parámetros para su uso.
MakeFont(string fontfile, string afmfile [, string enc [, array patch [, string type]]])

fontfile: Ubicación del fichero .ttf o .pfb.
afmfile: Ubicación del fichero .afm.
enc: Nombre de la codificación. Valor por defecto: cp1252 codificación (Europa Occidental).
patch: Modificación opcionar de la codificación. Vacío por defecto.
type: Tipo de la fuente (TrueType o Type1). Valor por defecto: TrueType.

Como esto es un ejemplo y no me quiero complicar la existencia usaremos lo mínimo de parámetros, para eso genere el archivo “genera_fuente.php” no quedo muy elegante pero todo es cuestión de que ustedes le agreguen una interfaz para seleccionar la ruta y fuente, el fichero AFM y la codificación. NO prometo nada pero si tengo tiempo luego lo mejoro.

<.?php
require(‘fpdf/font/makefont/makefont.php’);
MakeFont(‘c:\\windows\\fonts\\impact.ttf’, ‘fpdf/afm/impact.afm’, ‘cp1252’);

//como la fuente es nativa de windows intente utilizar el directorio y no hubo problemas.

//La ruta con la estructura de carpetas es C:\\servidor_web\\fpdf\\impact.ttf

?.>

Por favor eliminen los puntos antes y después de los signos de interrogación, lo puse porque wordpress me edita los códigos 😛

La salida del archivo es la siguiente:
Font file compressed (impact.z)

Font definition file generated (impact.php)

Recuerden solo se genera el archivo Z si tienen activa la librería de compresión ZLIB. El activarla queda fuera de esta explicación, esa es otra historia 😄

Los archivos generados deben buscarlos en la misma carpeta donde tienen el archivo genera_fuente.php o en su caso el archivo que hace la llamada a la función MakeFont.

Bueno ya tenemos 2 archivos (impact.z, impact.php), lo menos que pueden obtener es 1 archivo (impact.php).

Ahora hay que copiar los ficheros generados (menos el AFM) en el directorio de fuentes (de la clase NO de windows). Si el fichero de la fuente no pudo ser comprimido (impact.z), copie el .ttf o .pbf en lugar del .z.

Como en mi caso se genero el archivo comprimido (Z) solo copie los archivos impact.z y el archivo impact.php. Si no me hubiera generado el comprimido habría tenido que copiar los archivos impact.ttf y el archivo impact.php.

Nota: Si por alguna razón pierden el archivo Z y no tienen, no saben o no quieren instalar la librería ZLIB editen el archivo PHP y cambien la línea $file=’impact.z’; en lugar de hacer referencia al archivo Z debe hacer referencia al archivo TTF.

En el archivo PDF solo hay que establecer las fuentes a utilizar e indicar en que momento.
El método AddFont puede llevar por lo menos un parámetro (El nombre de la fuente) para trabajar.

El nombre de la fuente la puede obtener al ver las propiedades de la misma (en windows Abrir), si el nombre no es correcto la fuente no se cargará y el pdf generará un error. Como referencia revisen la fuente que incluye la clase calligra.ttf (nombre: Calligrapher).

$pdf->AddFont(‘Calligrapher’,”,’calligra.php’); //Fuente de ejemplo que incluye la Clase.
$pdf->AddFont(‘Impact’,”,’impact.php’); //Fuente de windows convertida con el proceso.


$pdf->SetFont(‘Impact’,”,15);
$pdf->Cell(0,4,’Soy Una Fuente muy Impactante’,0,1,’C’);

$pdf->Ln(10);
$pdf->SetFont(‘Calligrapher’,”,25);
$pdf->Cell(0,4,’Mi caligrafía puede mejorar’,0,1,’C’);

Anexo el mismo documento PDF del ejemplo el cual usa dos fuentes incorporadas Calligrapher <fuente demo del zip> y la fuente Impact nativa de Windows.

Click en la imagen para ver más grande.

Uso de Fuente Impact

Uso de Fuente Calligrapher

Archivo de Ejemplo click para bajar.

Si alguien desea los archivos de la fuente Impact o los cambios al archivo de ejemplo por favor deje un mensaje.

Saludos.

Etiquetas: , , ,

Dando lectura al post del fpdf del que no creía que llegaría a tener muchos comentarios =p me encuentro con una solicitud de una persona de nombre Jean, la cual hasta hoy no me había planteado en el uso de esta clase o derivadas.

El tiene que aplicar formato (negritas) a una porción de texto que envía como salida al pdf, sin embargo no conozco una forma de hacer eso =S digamos que el quiere hacer algo así:

Dos Elefantes se columpiaban sobre la tela de una araña.

No me culpen, fue lo primero que se me ocurrió =D además agreguen que desea hacerlo en un Multicell así que la propuesta es interesante. Ahora imaginen que luego le piden que algunas palabras de ese mismo párrafo usen itálicas (cursivas), otras usen un color rojo, algunas palabras deben ser más grandes para resaltar o más pequeñas (como el porcentaje de cobro xDD).

Todo eso se puede encontrar en la clase JLPDF de Juan Luis a continuación una imagen (tomada de El Ticus) de lo que se puede hacer:

Es visita obligada la página para usar la clase, aunque no tiene mayor complicación su manejo y aprendizaje es más rápido leyendo el sitio y consultando los ejemplos.

Espero que sea de utilidad para esos casos especiales =) Saludos.

Fuente: El Ticus.

Después de leer el comentario de Luis me puse a probar unas cosas que tenía ganas de agregarle a la clase y el resultado fue este pequeño post, que espero sirva de algo, aunque sea de referencia xD.

El ejemplo básico de fpdf es el siguiente:

<?php
require(‘fpdf.php’);

$pdf=new FPDF();
$pdf->AddPage();
$pdf->SetFont(‘Arial’,’B’,16);
$pdf->Cell(40,10,’¡Hola, Mundo!’);
$pdf->Output();
?>

Si deseamos cambiar la orientación del papel, tamaño o unidad de medida solo tenemos que indicarlo en los parametros que se pasan al constructor.

FPDF([string orientation [, string unit [, mixed format]]])
Por defecto el constructor tiene los siguientes valores:
FPDF($orientation=’P’,$unit=’mm’,$format=’A4′)

Si queremos generar un pdf en forma horizontal con una hoja tamaño legal y con dimensiones en centímetros tendríamos que pasar los siguientes parámetros:
$pdf=new FPDF(‘L’,’cm’,’Legal’);
Orientación:
* P o Portrait (normal) por defecto
* L o Landscape (apaisado)

Unidad
* pt: punto
* mm: milimetro por defecto
* cm: centimetro
* in: pulgada

Un punto es igual a 1/72 de pulgada, es decir cerca de 0.35 mm (siendo una pulgada 2.54 cm). Esta es una unidad muy común en tipografía; los tamaños de fuentes son expresados en esa unidad.

Formato (texto sensible a minúscula/mayúscula)
* A3
* A4
* A5
* Letter
* Legal

Un formato personalizado en la forma de un array de dos elementos conteniedo el ancho y el alto (expresado en la unidad dada por unit).

La clase tiene por defecto una serie de opciones, pero eso no es una limitante para ampliarlas =) Por ejemplo si quisieramos manejar un tamaño no contemplado en la clase tendremos que agregar la descripción y luego comparar el valor recibido.

La sección es Formato de Página:

//Page format
if(is_string($format))
{
$format=strtolower($format);
if($format==’letter’)
$format=array(612,792);
elseif($format==’a4′)
$format=array(595.28,841.89);

elseif($format==’mcarta‘) //media carta
$format=array(311,396);

$this->fwPt=$format[0];//ancho del formato de página en puntos
$this->fhPt=$format[1];//alto del formato de página en puntos
}

Con eso debería bastar para tener otra formato de página, en el caso que se desee pasar un tamaño personalizado, el constructor tendría que alterarse un poco más.

Recibiendo los valores de ancho, alto de la página y válidando el formato con la cadena recibida como en el caso de arriba, asignado al Array los valores de ancho y alto.

FPDF($orientation=’P’,$unit=’mm’,$format=’A4′, $wcustom=0, $hcustom=0)

elseif($format==’custom’) //Personalizado
$format=array($wcustom,$hcustom);

y lo demás es historia je, je.. Por lo tanto el código al inicio del post solo cambiara en una línea: $pdf=new FPDF(‘P’,’cm’,’mcarta’);

Fuente: fpdf.org, tutorial constructor.

P.D.  Obtención de medidas

Pulgada – 2.54 cm
Punto – 1/72 pulgada
Punto – 0.35 mm – 0.03527 7777 (valor tomado en los calculos)
Por defecto es mm

Ejemplo Tamaño Carta medidas w 21.59| h 27.94.
612 x 72 = 44064
792 x 72 = 57024

21.59 / 612 = 0.03527 7777
27.94 / 792 = 0.03527 7777

21.59 / 0.03527 7777 = 612.0000135
27.94 / 0.03527 7777 = 792.0000175

Tomando el valor en mm las medidas aumentan un poco, queda a criterio de cada uno

21.59 / 0.035 = 616.86
27.94 / 0.035 = 798.29

Media Carta
10.79 / 0.03527 7777 = 311 – 310.9606368
13.97 / 0.03527 7777 = 396


mayo 2017
L M X J V S D
« Feb    
1234567
891011121314
15161718192021
22232425262728
293031  

Blog Stats

  • 1,096,840 hits

FeedBurner

Flickr Photos

Torre Pemex

Miercoles Jarocho2

Miercoles Jarocho

Los músicos

Jaraneros y Arpa

Más fotos