2010-10-01 9 views
14

C'è un modo rapido e semplice per centrare gli oggetti allineati all'interno dell'oggetto Document? Senza eseguire alcuna logica di calcolo, ad es. Ottieni larghezza della pagina, larghezza del contenuto, divisione per due, ecc.Centro iTextSharp allinea gli oggetti all'interno dell'oggetto Document

Ho un oggetto PdfPTable all'interno di un oggetto Paragraph, all'interno dell'oggetto Document. Vorrei centrare l'oggetto Paragrafo.

Grazie!

risposta

6
PDFPTable.HorizontalAlignment = Element.ALIGN_CENTER; 
+0

Non funziona, forse intendete "ALIGN_CENTER" invece di "CENTER_ALIGN' –

8

questo iText (probabilmente uguale per iTextSharp):

paragraph.setAlignment(Element.ALIGN_CENTER); 

e si potrebbe desiderare di impostare il rientro in modo che esso sta piacevolmente:

paragraph.setIndentationLeft(100); 
paragraph.setIndentationRight(100); 
+0

Sembra squittire il tavolo. Hai un modo per impedirgli di farlo? – Kukoy

+0

stai usando i due metodi setIndentation sopra? Riduci le dimensioni dei rientri o rimuovili completamente. –

+0

PDFPTable ha i metodi setWidthPercentage e setTotalWidth, che possono essere d'aiuto per –

28

la sostituzione equivalente per iTextSharp:

paragraph.Alignment = Element.ALIGN_CENTER; 

oppure t ry questo modo

paragraph.IndentationRight = 100; 
paragraph.IndentationLeft = 100; 
+0

Sintassi iTextSharp corretta rispetto a iText – al3xnull

2

Per l'allineamento immagine:

iTextSharp.text.Image image1 = iTextSharp.text.Image.GetInstance(MapPath("~/images/HKVictoriaHarbour.png")); 
image1.Alignment = iTextSharp.text.Image.ALIGN_CENTER; 
doc.Add(image1); 
1

Il modo più semplice per allineare il paragrafo sarà Penso

Dim para = New Paragraph("Header") 
    para.SpacingBefore = 20 
    para.SpacingAfter = 20 
    para.Alignment = 1 '0-Left, 1 middle,2 Right 
    Document.Add(para) 
-2

Per fare qualcosa di simile

To do something like this

questo è il codice

Sub Crea_Contrato_PDF() 
    Dim T0 As String = "CONTRATO INDIVIDUAL DE TRABAJO " & vbCrLf & vbCrLf 

    Dim T1 As String = "JORGE MARIO DEL CID SANCHEZ de cincuenta y un años de edad, casado, guatemalteco, Licenciado, con domicilio en el departamento de Guatemala, con dirección en séptima avenida once guión sesenta y tres zona nueve edificio Galerías España; con Documento Personal De Identificación (DPI) código único número 1766 73121 0101 extendido por el Registro Nacional de las Personas “ & "RENAP" & ”, actuando en representación de la entidad SAFARI SEGURIDAD, SOCIEDAD ANÓNIMA ubicada en granja Rosilú kilómetro noventa y uno punto cinco municipio de Santa Lucía Cotzumalguapa del departamento de Escuintla, por una parte; y por la otra: " 

    '  Dim T2 As String = " de " & TextBox72.Text & " años de edad, sexo " 
    Dim t3 As String = " con nacionalidad guatemalteca, con dirección en " 

    Dim t3a As String = " con Documento Personal de Identificación código único número " 

    Dim t4 As String = " del Registro Nacional de las Personas –RENAP-; quienes para los efectos de este contrato se denominarán empleador o empresa y trabajador o empleado respectivamente; celebrando el CONTRATO INDIVIDUAL DE TRABAJO contenido en las siguientes cláusulas: " 

    Dim T5 As String = " La relación de trabajo inicia el: " 

    'Dim T6 As String = " SEGUNDA: El trabajador prestará los servicios de: " & TextBox61.Text 
    Dim T6 As String = " El trabajador prestará los servicios de: " 

    ' Dim T7 As String = " TERCERA: Los servicios serán prestados en: uno de los distintos puntos o puestos dentro de la República de Guatemala en donde la empresa brinda sus servicios." 

    Dim T7 As String = " Los servicios serán prestados en: uno de los distintos puntos o puestos dentro de la República de Guatemala en donde la empresa brinda sus servicios." 

    'Dim T8 As String = " CUARTA: La vigencia o duración del presente contrato es por tiempo indefinido. " 
    Dim T8 As String = " La vigencia o duración del presente contrato es por tiempo indefinido. " 

    'Dim T9 As String = " QUINTA: La jornada de trabajo será así: de lunes a viernes de seis a catorce horas, y día sábado de seis a diez horas, para complementar las 44 horas de la jornada semanal; dicha jornada es meramente enunciada y no taxativa ya que por la naturaleza de los servicios que la empresa presta se podrá modificar la misma previo acuerdo con el trabajador, velando siempre que no se contravengan los derechos que las leyes laborales otorguen a éste. " 
    Dim T9 As String = " La jornada de trabajo será así: de lunes a viernes de seis a catorce horas, y día sábado de seis a diez horas, para complementar las 44 horas de la jornada semanal; dicha jornada es meramente enunciada y no taxativa ya que por la naturaleza de los servicios que la empresa presta se podrá modificar la misma previo acuerdo con el trabajador, velando siempre que no se contravengan los derechos que las leyes laborales otorguen a éste. " 

    Dim T10 As String = " El salario será de " 
    Dim T10A As String = " mensuales más la Bonificación Incentivo de Decreto 37-2001 del Congreso de la República por " 

    Dim T10B As String = ". El mismo se cancelará el último día de cada mes, en las instalaciones de la empresa por medio cheque bancario o depositado a la cuenta bancaria del trabajador, conforme el artículo 3 del Convenio Internacional de Trabajo ratificado por la República de Guatemala y el artículo 102 literal t) de la Constitución Política de la República. " 

    'Dim T11 As String = " SEPTIMA: Las horas extras, el séptimo y los días de asueto, le serán pagados de conformidad con los artículos 121, 124, 126 y 127 del Código de Trabajo. " 
    Dim T11 As String = " Las horas extras, el séptimo y los días de asueto, le serán pagados de conformidad con los artículos 121, 124, 126 y 127 del Código de Trabajo. " 

    'Dim T12 As String = " OCTAVA: Debido a la naturaleza especial de la actividad de la empresa la cual brinda seguridad privada a personas jurídicas o individuales, conforme el artículo 136 del Código de Trabajo el empleador podrá dividir el período de vacaciones en dos partes como máximo por la índole especial mencionada. " 
    Dim T12 As String = " Debido a la naturaleza especial de la actividad de la empresa la cual brinda seguridad privada a personas jurídicas o individuales, conforme el artículo 136 del Código de Trabajo el empleador podrá dividir el período de vacaciones en dos partes como máximo por la índole especial mencionada. " 

    Dim T13 As String = " El trabajador se compromete a cumplir todas las obligaciones que le atañe e impone la Ley que Regula los Servicios de Seguridad Privada según DECRETO NÚMERO 52-2010 DEL CONGRESO DE LA REPÚBLICA DE GUATEMALA; y en caso de incumplimiento a una de tales disposiciones se considera falta grave en el trabajo y la empresa podrá dar finalizada la relación laboral con el trabajador sin responsabilidad alguna para la misma. " 

    'Dim T14 As String = " DÉCIMA: Es entendido que de conformidad con los artículos 122 y 124 del Código de trabajo la jornada ordinaria y extraordinaria no puede exceder de una suma total de 12 horas diarias. El presente contrato se suscribe en Granja Rosilú kilómetro noventa y uno punto cinco carretera del Pacífico municipio de Santa Lucía Cotzumalguapa del departamento de Escuintla; a los " & TextBox16.Text & " días del mes de " & TextBox17.Text & " del año dos mil dieciséis" 
    Dim T14 As String = " Es entendido que de conformidad con los artículos 122 y 124 del Código de trabajo la jornada ordinaria y extraordinaria no puede exceder de una suma total de 12 horas diarias. El presente contrato se suscribe en Granja Rosilú kilómetro noventa y uno punto cinco, carretera del Pacífico, municipio de Santa Lucía Cotzumalguapa del departamento de Escuintla; a los _____ días del mes de __________________ del año __________." & vbCrLf & vbCrLf 

    Dim T15 As String = "          ___________________________   _________________________" & vbCrLf 
    Dim T16 As String = "              Empleador            Trabajador" & vbCrLf 

    Dim txt_cc As String = "CONTRATO_CC_" & txt_CCosto.Text & "_EMP_" & TextBox1.Text & ".pdf" 

    ''//The main folder that we are working in 
    Dim WorkingFolder = Environment.GetFolderPath(Environment.SpecialFolder.Desktop) 

    ''//The file that we are creating 
    'Dim WorkingFile = Path.Combine(WorkingFolder, txt_FileName.Text) 
    Dim WorkingFile = Path.Combine("D:\CONTRATOS\", txt_cc) 

    'Dim SampleImage = Path.Combine(WorkingFolder, "LOGO_c.PNG") 
    Dim SampleImage = Path.Combine("C:\Aplicaciones\SafariSis\", "LOGO_c.PNG") 

    ''//Create our file with an exclusive writer lock 
    Using FS As New FileStream(WorkingFile, FileMode.Create, FileAccess.Write, FileShare.None) 
     ''//Create our PDF document 
     Using Doc As New Document(PageSize.LETTER) 
      ''//Bind our PDF object to the physical file using a PdfWriter 
      Using Writer = PdfWriter.GetInstance(Doc, FS) 
       ''//Open our document for writing 
       Doc.Open() 

       ''//Insert a blank page 
       Doc.NewPage() 

       ''//Create a PDF image object from our physical image 
       Dim ThisImage = iTextSharp.text.Image.GetInstance(SampleImage) 

       ''//Use standard ratio resizing algorithms to calculate new image dimensions based on the documents dimensions. This will shrink or grow documents to fit 

       ''//Will hold our new image dimensions 
       ''//Documents sometimes have margins (and this sample does) so subtract them so that our image in centered in the page 
       Dim NewW, NewH As Single 

       NewW = Doc.PageSize.Width - (Doc.LeftMargin + Doc.RightMargin) 
       NewH = Doc.PageSize.Height - (Doc.TopMargin + Doc.BottomMargin) 

       ''//Scale the image 
       ' ThisImage.ScaleToFit(NewW, NewH) 

       ''//Add the image to the document **************************** 
       'Doc.Add(ThisImage) 

       Dim ppp0 As New Paragraph(T0, LFont2) 
       ppp0.Font.Size = 12 
       ppp0.Alignment = Element.ALIGN_CENTER 
       ppp0.Font = LFont2 
       Doc.Add(ppp0) 

       Dim ppp1 As New Chunk(T1, LFont) 
       ppp1.Font.Size = 10 
       Dim ppp2 As New Chunk(TextBox74.Text, LFont2) 
       Dim ppp3 As New Chunk(" de ", LFont) 
       Dim ppp4 As New Chunk(TextBox72.Text, LFont2) 
       Dim ppp5 As New Chunk(" años de edad, sexo ", LFont) 
       Dim ppp6 As New Chunk(TextBox71.Text, LFont2) 
       Dim ppp7 As New Chunk(" estado civil ", LFont) 
       Dim ppp8 As New Chunk(TextBox70.Text, LFont2) 
       Dim ppp9 As New Chunk(t3, LFont) 
       Dim ppp9A As New Chunk(TextBox69.Text, LFont2) 
       Dim ppp10 As New Chunk(" vecino de ", LFont) 
       Dim ppp11 As New Chunk(TextBox68.Text, LFont2) 
       Dim ppp12 As New Chunk(t3a, LFont) 
       Dim ppp13 As New Chunk(TextBox67.Text, LFont2) 
       Dim ppp14 As New Chunk(t4, LFont) 
       Dim ppp15 As New Chunk(" PRIMERA:", LFont2) 
       Dim ppp16 As New Chunk(T5, LFont) 
       Dim ppp17 As New Chunk(TextBox66.Text & ". SEGUNDA:", LFont2) 
       Dim ppp18 As New Chunk(T6, LFont) 
       Dim ppp19 As New Chunk(TextBox61.Text & ". TERCERA:", LFont2) 
       Dim ppp20 As New Chunk(T7, LFont) 
       Dim ppp21 As New Chunk(" CUARTA: ", LFont2) 
       Dim ppp22 As New Chunk(T8, LFont) 
       Dim ppp23 As New Chunk(" QUINTA: ", LFont2) 
       Dim ppp24 As New Chunk(T9, LFont) 
       Dim ppp25 As New Chunk(" SEXTA: ", LFont2) 
       Dim ppp26 As New Chunk(T10, LFont) 
       Dim ppp27 As New Chunk(TextBox65.Text, LFont2) 
       Dim ppp28 As New Chunk(T10A, LFont) 
       Dim ppp29 As New Chunk(TextBox64.Text, LFont2) 
       Dim ppp30 As New Chunk(T10B, LFont) 
       Dim ppp31 As New Chunk(" SEPTIMA: ", LFont2) 
       Dim ppp32 As New Chunk(T11, LFont) 
       Dim ppp33 As New Chunk(" OCTAVA: ", LFont2) 
       Dim ppp34 As New Chunk(T12, LFont) 
       Dim ppp35 As New Chunk(" NOVENA: ", LFont2) 
       Dim ppp36 As New Chunk(T13, LFont) 

       Dim ppp37 As New Chunk(" DECIMA: ", LFont2) 
       Dim ppp38 As New Chunk(T14, LFont) 

       Dim ppp39 As New Chunk(T15, LFont) 
       Dim ppp40 As New Chunk(T16, LFont) 

       ppp15.Font.Size = 10 
       ppp16.Font.Size = 10 
       ppp17.Font.Size = 10 
       ppp18.Font.Size = 10 
       ppp19.Font.Size = 10 
       ppp20.Font.Size = 10 
       ppp21.Font.Size = 10 
       ppp22.Font.Size = 10 

       Dim ppp00 As New Chunk("", LFont) 
       ppp1.Font.Size = 10 

       Dim body As New Phrase(12, ppp00) 

       body.Add(ppp1) 
       body.Add(ppp2) 
       body.Add(ppp3) 
       body.Add(ppp4) 
       body.Add(ppp5) 
       body.Add(ppp6) 
       body.Add(ppp7) 
       body.Add(ppp8) 
       body.Add(ppp9) 
       body.Add(ppp9A) 
       body.Add(ppp10) 
       body.Add(ppp11) 
       body.Add(ppp12) 
       body.Add(ppp13) 
       body.Add(ppp14) 
       body.Add(ppp15) 
       body.Add(ppp16) 
       body.Add(ppp17) 
       body.Add(ppp18) 
       body.Add(ppp19) 
       body.Add(ppp20) 
       body.Add(ppp21) 
       body.Add(ppp22) 
       body.Add(ppp23) 
       body.Add(ppp24) 
       body.Add(ppp25) 
       body.Add(ppp26) 
       body.Add(ppp27) 
       body.Add(ppp28) 
       body.Add(ppp29) 
       body.Add(ppp30) 
       body.Add(ppp31) 
       body.Add(ppp32) 
       body.Add(ppp33) 
       body.Add(ppp34) 
       body.Add(ppp35) 
       body.Add(ppp36) 
       body.Add(ppp37) 
       body.Add(ppp38) 
       body.Add(ppp39) 
       body.Add(ppp40) 

       Dim p As New Paragraph(" ", LFont) 
       p.Font.Size = 10 
       p.Alignment = Element.ALIGN_JUSTIFIED 

       p.Add(body) 
       Doc.Add(p) 

       ''//Close our document 
       Doc.Close() 
      End Using 
     End Using 
    End Using 

End Sub 
+3

molti dettagli Si prega di abbreviare il codice per le parti importanti e includere una descrizione migliore della tua domanda. –

Problemi correlati