Añadir lineas en REPORT

Añadir lineas en REPORT

Postby Manuel Aranda » Wed Sep 11, 2013 5:36 pm

Necesito añadir varias lineas al final de un report con oReport:bPostEnd . La particularidad es que tienen que ir todas juntas y si no caben no escribir ninguna y pasar a escribirlas todas en la página siguiente. ¿Podeis ayudarme?
Un saludo,
Manuel

xH 1.2.3, FWH 23.07 32 bits, BC++ 7.4, xVerce CW 1.0, PellesC
User avatar
Manuel Aranda
 
Posts: 604
Joined: Wed Oct 19, 2005 8:20 pm
Location: España

Re: Añadir lineas en REPORT

Postby Marcelo Via Giglio » Wed Sep 11, 2013 6:23 pm

Manuel,

revisando el código de la clase report, hay este método que te orienta como saber las líneas restante de impresión

METHOD NeedNewPage() INLINE ( ::nRow >= ::nBottomRow )

con esa información puedes utilizar otro método NewLine para añadir líneas manualmente

espero sea de ayuda

saludos

Marcelo
Marcelo Via Giglio
 
Posts: 1071
Joined: Fri Oct 07, 2005 3:33 pm
Location: Cochabamba - Bolivia

Re: Añadir lineas en REPORT

Postby Manuel Aranda » Thu Sep 12, 2013 7:41 am

Gracias, Marcelo. Voy a probarlo.
Un saludo,
Manuel

xH 1.2.3, FWH 23.07 32 bits, BC++ 7.4, xVerce CW 1.0, PellesC
User avatar
Manuel Aranda
 
Posts: 604
Joined: Wed Oct 19, 2005 8:20 pm
Location: España

Re: Añadir lineas en REPORT

Postby Armando » Thu Sep 12, 2013 2:14 pm

Manuel y amigos:

Voy a meter un poquito de más rollo en esto, Manuel, cual es la necesidad de imprimir las líneas en
otra página si es que no caben?.

Lo pregunto porque pienso que si pretendes imprimirlas en la misma página y no caben te tira un error, cierto?

El error es que no se puede borrar el meta file, cierto?

Saludos
SOI, s.a. de c.v.
estbucarm@gmail.com
http://www.soisa.mex.tl/
http://sqlcmd.blogspot.com/
Tel. (722) 174 44 45
Carpe diem quam minimum credula postero
User avatar
Armando
 
Posts: 3242
Joined: Fri Oct 07, 2005 8:20 pm
Location: Toluca, México

Re: Añadir lineas en REPORT

Postby FranciscoA » Thu Sep 12, 2013 3:23 pm

Hola Manuel.
Si tienes definidas que cantidad de lineas vas a agregar en el bPstEnd, entonces creo que este codigo te puede servir:
//--------------------------------------------------------------//
Function ResumenCaja(oReport,nTContado,nTRcaja,nEfectivo,nVauchers)
local nLinAdic:=5

oReport:lGrid := .f.

CkNewPage(oReport,nLinAdic) //chequear si necesita nueva pagina
oReport:NewLine()

oReport:Say( 1, "RESUMEN DE CAJA:")
oReport:Say( 2, "FACT CONTADO: "+Transform(nTContado,"9,999,999.99") )
oReport:Say( 3, "RECIBOS CAJA: "+Transform(nTRCaja,"9,999,999.99") )
oReport:Say( 4, "VAUCHERS: "+Transform(nVauchers,"9,999,999.99") )
oReport:Say( 5, "EFECTIVO: "+Transform(nEfectivo,"9,999,999.99") )

return nil
//------------------------------
Function CkNewPage(oReport,nLinAdic)
if (oReport:nRow() + (oReport:nStdLineHeight()*nLinAdic)) >= oReport:nBottomRow()
oReport:EndPage()
oReport:StartPage()
endif
return nil

Saludos.
Francisco J. Alegría P.
Chinandega, Nicaragua.

Fwxh-MySql-TMySql
User avatar
FranciscoA
 
Posts: 2159
Joined: Fri Jul 18, 2008 1:24 am
Location: Chinandega, Nicaragua, C.A.

Re: Añadir lineas en REPORT

Postby Manuel Aranda » Thu Sep 12, 2013 5:02 pm

Francisco, muchas gracias por el código. Con algunos ajustes y pruebas he logrado lo que pretendía.
Armando, efectivamente, es cierto lo que comentas del error al eliminar el metafile. Usando el código de Francisco lo he podido ajustar para que no se produzca ese error. Tengo que añadir 12 lineas en bloque y he tenido que poner nLinAdic a 13 para que no se produzca el error. No se si es una solución muy ortodoxa pero, de momento, funciona.
Un saludo,
Manuel

xH 1.2.3, FWH 23.07 32 bits, BC++ 7.4, xVerce CW 1.0, PellesC
User avatar
Manuel Aranda
 
Posts: 604
Joined: Wed Oct 19, 2005 8:20 pm
Location: España

Re: Añadir lineas en REPORT

Postby Armando » Thu Sep 12, 2013 5:18 pm

Manuel:

Lo sospeche desde un principio (El chavo), :)

Mira esta función a ver que te parece.

Code: Select all  Expand view  RUN

FUNCTION OverFlow(oReporte)
    IF (oReporte:nRow + (oReporte:nStdLineHeight * 2)) >= oReporte:nBottomRow
        oReporte:EndPage()
        oReporte:StartPage()
    ENDIF
RETURN NIL
 


Después de imprimir, o antes si así lo prefieres, cada una de las líneas adicionales mando llamar
a esta función y así acabe con el famoso error.

Saludos
SOI, s.a. de c.v.
estbucarm@gmail.com
http://www.soisa.mex.tl/
http://sqlcmd.blogspot.com/
Tel. (722) 174 44 45
Carpe diem quam minimum credula postero
User avatar
Armando
 
Posts: 3242
Joined: Fri Oct 07, 2005 8:20 pm
Location: Toluca, México

Re: Añadir lineas en REPORT

Postby Manuel Aranda » Thu Sep 12, 2013 5:34 pm

Armando, gracias de nuevo.
Un saludo,
Manuel

xH 1.2.3, FWH 23.07 32 bits, BC++ 7.4, xVerce CW 1.0, PellesC
User avatar
Manuel Aranda
 
Posts: 604
Joined: Wed Oct 19, 2005 8:20 pm
Location: España

Re: Añadir lineas en REPORT

Postby RSalazarU » Thu Sep 12, 2013 5:46 pm

Manuel:

Yo tengo algo parecido al de Armando, que agregue a la clase tReport
Code: Select all  Expand view  RUN
METHOD NewPageIfNeed( nRow )  INLINE  if(nRow >= ::nBottomRow, ::EndPage(), NIL)
 

por cierto, yo usaba tb EndPage() y StartPage() pero ::EndPage() hace eso y algo mas...

Y como dice armando ".. la llama Después de imprimir, o antes si así lo prefieres, ..."

Ejemplo:
En este caso yo tengo que imprimir 6 lineas de distinto tamaño y le doy un espacio mas extra.
Code: Select all  Expand view  RUN
oRpt:NewPageIfNeed(oRpt:nStdLineHeight*2.00 + ;
                   oRpt:nStdLineHeight*1.05 + ;
                   oRpt:nStdLineHeight*1.15 + ;
                   oRpt:nStdLineHeight*1.15 + ;
                   oRpt:nStdLineHeight*1.30 + ;
                   oRpt:nStdLineHeight*1.05 + ;
                   oRpt:nStdLineHeight)

 


Seria ideal incorporar este metodo a la clase tReport


Atentamente,

Rolando
Cochabamba - Bolivia
FWH 1109 - xHarbour 1.1.0 (SimpLex) - BCC58
RSalazarU
 
Posts: 211
Joined: Wed Jul 16, 2008 12:59 pm
Location: Cochabamba-Bolivia

Re: Añadir lineas en REPORT

Postby Armando » Thu Sep 12, 2013 6:44 pm

Amigos:

Tal vez llamando a estos dos métodos ayude en algo, se describen por sí solos.

Code: Select all  Expand view  RUN

        oReporte:EndLine()
        oReporte:StartLine()
 


Saludos
SOI, s.a. de c.v.
estbucarm@gmail.com
http://www.soisa.mex.tl/
http://sqlcmd.blogspot.com/
Tel. (722) 174 44 45
Carpe diem quam minimum credula postero
User avatar
Armando
 
Posts: 3242
Joined: Fri Oct 07, 2005 8:20 pm
Location: Toluca, México


Return to FiveWin para Harbour/xHarbour

Who is online

Users browsing this forum: No registered users and 26 guests