Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

ammazzo

Gerar Carteirinha em PDF

Recommended Posts

Olá galera, 

 

Estou com problemas pra gerar Carteirinha de membros em PDF. 

Eu utilizo o Phpjasperxml em todos os relatórios e consigo um resultado quase excelente, a não ser por algumas limitações como o não funcionamento de subrelatórios e gráficos mas não me fez falta. 

 

O meu problema na geração de carteiras é que a imagem dinâmica das fotos dos membros , vindo do BD,  faz com que o pdf não seja gerado.

 

Gostaria de saber se alguém tem uma solução pra este problema do Phpjasperxml ou se tem uma maneira mais prática pra fazer carteirinha em PDF usando mPdf, Tcpdf e etc... Pois já tenho o layout das carteira e tá bem complexo ajustar os campos que serão preenchidos na mão. Obrigado. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Tenta quebrar as responsabilidades.

 

Ex:

 

Você faz 2 rotinas:

 

1 - Gerar Imagem a partir do DB,

2 - Pegar essa imagem já feita e simplesmente juntar no Phpjasperxml.

 

--------

Se possível detalhe mais...

 

Ex

"faz com que o pdf não seja gerado."

 

Não gera pq?

Da erro?

Fica em branco?

 

 

 

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Valeu pela atenção Gabriel. 

 

Dá erro 500 no browser. 

 

Pra gerar uma carteira individual, sem problemas,  porque eu passo o caminho da foto por parâmetro. Eu busco a foto no banco pelo id do membro e envio o caminho completo por parâmetro. 

 

Meu problema está na geração de todas as carteirinhas ou de um grupo determinado (ex: da 50 a 100). O problema acontece  na field da foto em Text Expression 

 

Ex: "localhost/sgc/membros/fotos/" +$F{foto}

 

Essa field  $F{foto}  se eu colocar pra exibir como texto, traz o nome da imagem corretamente. Mas se ela estiver na Text Expression da imagem da ruim.

 

Só reforçando que sem foto o PDF com todas as carteirinhas é gerado tranquilamente. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá Mykel, obrigado pela atenção. 

 

O log não tem erro. 

 

Criei até pra testar,  um código simples, procedural, só chamando o jxml pra gerar o PDF. Inclusive usando outra conexão de banco e uma tabela simples. É o problema persiste. 

 

Tô começando a acreditar que seja bug no phpjasperxml. Por isso peço que se alguém o utilize, faça esse teste pra de imagens dinâmica pra sanar qualquer dúvida. 

 

Obrigado mais uma vez. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

[RESOLVIDO] 

 

Gabriel e Mykel, 

 

Meu muito obrigado pela atenção. 

Consegui resolver. 

 

Após várias tentativas, como suspeitava era uma limitação do phpjasperxml. Lembre que há uns 3 anos atrás tive um problema com o logotipo de um relatório. E descobri em um fórum tailandês que imagens. png não são processadas pelo phpjasperxml. 

 

Esse era o problema! Agora vou excluir a extensão png da regra de permitidas para upload de fotos de membros e readaptar onde for necessário. 

 

Muito obrigado mais uma vez! 

 

Solução : imagens com extensão png não são suportadas pelo phpjasperxml. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Legal q deu certo.

 

Sobre restringir png, acho meio zoado...

 

Uma opção seria você converter:

https://stackoverflow.com/questions/1201798/use-php-to-convert-png-to-jpg-with-compression

 

Lembrando q perde a transparência (camada alpha).

 

Abs.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Valeu Gabriel, vou seguir a dica sim. Melhor que restringir. Mas como são só as fotos do rosto dos membros a camada alpha não vai importar. 

 

Valeu, grande abraço!

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.