Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature Request] Adding PDF as output #354

Open
tobiasfalk opened this issue May 20, 2024 · 10 comments
Open

[Feature Request] Adding PDF as output #354

tobiasfalk opened this issue May 20, 2024 · 10 comments

Comments

@tobiasfalk
Copy link

We may already have SVG as a vector graphics output, but it still would be nice if PDF would also be available.

@martinrieder
Copy link
Contributor

martinrieder commented May 20, 2024

This has been in development for some time. Check #32 and the associated feature branch.
The new CLI offers a switch to request PDF output format, but it is not implemented yet.

I noticed your repo https://github.com/tobiasfalk/KiCAD-FreeCAD-TechDraw-Template-Generator.
It seems that you have some experience in that area. Feel free to contribute to #304 as well. ^^

@tobiasfalk
Copy link
Author

tobiasfalk commented May 20, 2024

@martinrieder
I took a look at #32 and #304, and I am a bit confused, is it now possible to draw the wiring plan in to a drawing frame with title block or not, if yes how, since there is no mention I found in the doc or examples.
If the whole drawing frame with title block inclusion is not stated or though out I would recommend using an already existing template format, like the FreeCAD SVG, this would bring the benefit that there are already some templates existing and that in its base form it is just an SVG that can be rendered normally.
In that the fields that are meant to be edited have the XML attribute freecad:editable with a variable name and some like the title or the author/creator have the additional attribute freecad:autofill with a specified value in it to identified what it is (FreeCAD #13005 and #13790).
With these ids the text that is in them can be changed before handing the template/svg over to the drawing engine to use.

When it comes to coding I would polity decline, since I not only do not really have too much experience with Python and especially not with graphvis (even when the issues I opened in the last view day would sugset otherwise I never used graphviz before that).
What I am happily do is help with question where I can and with ideas on improving things.

@kvid
Copy link
Collaborator

kvid commented May 20, 2024

Take a look at demo02

@martinrieder
Copy link
Contributor

@kvid I was thinking of something like #227. The table that is contained in the HTML output of Demo02 could well be implemented in a GV node.

@tobiasfalk there are many ways that the frame and title blocks could be drawn. What do you suggest? Only add it for "printable" formats like PDF?

I do not consider HTML to be truly printable, though it should be possible to convert it into PDF.

@tobiasfalk
Copy link
Author

@tobiasfalk there are many ways that the frame and title blocks could be drawn. What do you suggest? Only add it for "printable" formats like PDF?

I would add it to all Formats, since the user may want to use it in Programs like word where imprting a PDF as a page is not possible(theoretically yes but I have tried for weeks and was not able to do it).
So giving the user the ability to export this as a PNG with tilteblock is defenetly a good idea, has also the benefit of being able to use it in issues and not rely on the reader to open a link to a file or so.

I do not have the ability to do something for a while(not at home), but could one of you try to import one SVG from the FreeCAD templates as image in the background?

@tobiasfalk
Copy link
Author

Take a look at demo02

If I see this correctly, you are drawing this frame amd titleblock internally, wich is cald by the template tag.
This limits the user to only the templates that are integrated in to WireViz, so to get a new formate that the user wants he needs to program it in to wireviz.

I would recommend a external template file formate, like svg and maybe even freecad svgs since there a lot of work is already done and for users that use both it reduces work

@kvid
Copy link
Collaborator

kvid commented May 21, 2024

@tobiasfalk wrote:

Take a look at demo02

If I see this correctly, you are drawing this frame amd titleblock internally, wich is cald by the template tag. This limits the user to only the templates that are integrated in to WireViz, so to get a new formate that the user wants he needs to program it in to wireviz.

No, the HTML template might also be located at the same folder as any YAML source. In addition, the template might be specified with a relative or absolute path.

I would recommend a external template file formate, like svg and maybe even freecad svgs since there a lot of work is already done and for users that use both it reduces work

I agree, there are different existing template solutions available (including other HTML based templates), but currently, an internal HTML template format is implemented. Other suggestions are welcome, and I encourage you to describe some criteria we should aim for to enable comparing different alternatives.

@martinrieder
Copy link
Contributor

martinrieder commented Jun 5, 2024

I do not have the ability to do something for a while(not at home), but could one of you try to import one SVG from the FreeCAD templates as image in the background?

Merging two SVG files seems like a simple task. Converting this into PDF can be solved with other tools.

I would reverse the process and feed HTML into Graphviz. If you put this into a graph that only contains a single node, you can use it as a tool for SVG conversion.

By putting the BOM table into a dedicated node on the WireViz output, it could also assure that this does not overlap with the graph. Positioning and scaling might be an issue though.

Do you know if it is possible to predefine a container or an anchor in some SVG template files that could be used for merging?

@tobiasfalk
Copy link
Author

https://forum.graphviz.org/t/background-image-frame-for-the-graph/2232

@martinrieder
Copy link
Contributor

martinrieder commented Jul 12, 2024

I would reverse the process and feed HTML into Graphviz. If you put this into a graph that only contains a single node, you can use it as a tool for SVG conversion.
By putting the BOM table into a dedicated node on the WireViz output, it could also assure that this does not overlap with the graph. Positioning and scaling might be an issue though.

As a PoC, I manually created the .gv files to render the HTML tables using Graphviz dot into SVG files. Note that it can also render those into xdot format.

Demo02 GV BOM

graph {
    BOM [margin=0 fontname="Arial" fillcolor="#FFFFFF" shape=box style=filled label=<
<table border="1" cellspacing="0" cellpadding="3" cellborder="1">
  <tr>
    <td>12</td>
    <td>Wire, 0.14 mm², YE</td>
    <td>0.6</td>
    <td>m</td>
    <td>W1, W2</td>
  </tr>
  <tr>
    <td>11</td>
    <td>Wire, 0.14 mm², VT</td>
    <td>0.3</td>
    <td>m</td>
    <td>W3</td>
  </tr>
  <tr>
    <td>10</td>
    <td>Wire, 0.14 mm², RD</td>
    <td>0.6</td>
    <td>m</td>
    <td>W1, W2</td>
  </tr>
  <tr>
    <td>9</td>
    <td>Wire, 0.14 mm², OG</td>
    <td>0.3</td>
    <td>m</td>
    <td>W3</td>
  </tr>
  <tr>
    <td>8</td>
    <td>Wire, 0.14 mm², GN</td>
    <td>0.6</td>
    <td>m</td>
    <td>W1, W2</td>
  </tr>
  <tr>
    <td>7</td>
    <td>Wire, 0.14 mm², BU</td>
    <td>0.3</td>
    <td>m</td>
    <td>W3</td>
  </tr>
  <tr>
    <td>6</td>
    <td>Wire, 0.14 mm², BK</td>
    <td>0.9</td>
    <td>m</td>
    <td>W1, W2, W3</td>
  </tr>
  <tr>
    <td>5</td>
    <td>Connector, Molex KK 254, female, 8 pins</td>
    <td>1</td>
    <td></td>
    <td>X1</td>
  </tr>
  <tr>
    <td>4</td>
    <td>Connector, Molex KK 254, female, 5 pins</td>
    <td>1</td>
    <td></td>
    <td>X4</td>
  </tr>
  <tr>
    <td>3</td>
    <td>Connector, Molex KK 254, female, 4 pins</td>
    <td>2</td>
    <td></td>
    <td>X2, X3</td>
  </tr>
  <tr>
    <td>2</td>
    <td>Connector, Crimp ferrule, 0.25 mm², YE</td>
    <td>2</td>
    <td></td>
    <td></td>
  </tr>
  <tr>
    <td>1</td>
    <td>Cable, 2 x 0.25 mm²</td>
    <td>0.3</td>
    <td>m</td>
    <td>W4</td>
  </tr>
  <tr>
    <td>Id</td>
    <td>Description</td>
    <td>Qty</td>
    <td>Unit</td>
    <td>Designators</td>
  </tr>
</table>
    >]
}

Demo02 GV Title Block

graph {
    BOM [margin=0 fontname="Arial" fillcolor="#FFFFFF" shape=box style=filled label=<
<table border="1" cellspacing="0" cellpadding="3" cellborder="1">
  <tr>
    <td><!-- %revisions_8% --></td>
    <td><!-- %revisions_8_changelog% --></td>
    <td><!-- %revisions_8_date% --></td>
    <td><!-- %revisions_8_name% --></td>
    <td></td>
    <td>Date</td>
    <td>Name</td>
    <td colspan="3" rowspan="5">WireViz Demo 2</td>
  </tr>
  <tr>
    <td><!-- %revisions_7% --></td>
    <td><!-- %revisions_7_changelog% --></td>
    <td><!-- %revisions_7_date% --></td>
    <td><!-- %revisions_7_name% --></td>
    <td>Created</td>
    <td>2020-05-20</td>
    <td>D. Rojas</td>
  </tr>
  <tr>
    <td><!-- %revisions_6% --></td>
    <td><!-- %revisions_6_changelog% --></td>
    <td><!-- %revisions_6_date% --></td>
    <td><!-- %revisions_6_name% --></td>
    <td>Approved</td>
    <td>2020-05-20</td>
    <td>D. Rojas</td>
  </tr>
  <tr>
    <td><!-- %revisions_5% --></td>
    <td><!-- %revisions_5_changelog% --></td>
    <td><!-- %revisions_5_date% --></td>
    <td><!-- %revisions_5_name% --></td>
    <td><!-- %authors_3% --></td>
    <td><!-- %authors_3_date% --></td>
    <td><!-- %authors_3_name% --></td>
  </tr>
  <tr>
    <td><!-- %revisions_4% --></td>
    <td><!-- %revisions_4_changelog% --></td>
    <td><!-- %revisions_4_date% --></td>
    <td><!-- %revisions_4_name% --></td>
    <td colspan="2"></td>
    <td></td>
  </tr>
  <tr>
    <td><!-- %revisions_3% --></td>
    <td><!-- %revisions_3_changelog% --></td>
    <td><!-- %revisions_3_date% --></td>
    <td><!-- %revisions_3_name% --></td>
    <td colspan="3" rowspan="3"><!-- %company% --></td>
    <td colspan="2" rowspan="3">WV-DEMO-02</td>
    <td rowspan="2">Sheet<br />1</td>
  </tr>
  <tr>
    <td><!-- %revisions_2% --></td>
    <td><!-- %revisions_2_changelog% --></td>
    <td><!-- %revisions_2_date% --></td>
    <td><!-- %revisions_2_name% --></td>
  </tr>
  <tr>
    <td>A</td>
    <td>WireViz 0.2 release</td>
    <td>2020-10-17</td>
    <td>D. Rojas</td>
    <td>of 1</td>
  </tr>
  <tr>
    <td>Rev</td>
    <td>Changelog</td>
    <td>Date</td>
    <td>Name</td>
    <td colspan="3"></td>
    <td></td>
    <td colspan="2"></td>
  </tr>
</table>
 
     >]
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants