Skip to content

Latest commit

 

History

History
61 lines (44 loc) · 4.4 KB

README.MD

File metadata and controls

61 lines (44 loc) · 4.4 KB

RagecomicToPDF

To practice a bit real programming, I programmed a tool to convert ragecomics to PDFs in C#.

It takes .xml files from ragemaker.net and outputs PDFs. The benefit is that each face/image in them retains full quality, whereas ragemaker's normal png output rasterizes the image to a fixed and small resolution.

Text is vector-based too.

So you can print ragecomics as giant posters in best possible quality.

I know it's of limited real life use, but it was fun to make and it taught me a lot about C# and some libraries, most of all iTextSharp.

Features:

  • Creates Zip file full of any individual png faces/graphics that are saved as base64 bytes in the .xml
  • Takes rotation into account (I found this particularly difficult for text, which doesn't have as straightforward rotation and boundingbox-calculation functions as images do)
  • Takes opacity into account (but is imperfect for text that has a background color, because the opacity is set separately for text and background, instead of setting it for both as a whole.
  • Takes color of text and background color into account.
  • Draws a grid and sets document size depending on the number of panels
  • Reads grayscale JPEGs with a special library, because the normal library, for whatever reason, creates weird dithering artifacts on grayscale JPEGs.
  • Takes detailed grid settings into account, for example disabled gridlines and diagonal gridlines.
  • Supports AnyFont areas (those textareas where you can choose any font you like)

Under the hood:

  • Somewhat object-oriented, with objects representing the comic and the individual items in it
  • Extended List for the items in the ragecomic, so that it can count a particular type of them (individual graphics) to know whether a Zip file must be generated
  • Uses FluxJPEG, DotNetZip, iTextSharp libraries
  • Has a GUI with a simple scrolling status window and a button that allows file selection
  • Conversion is done asynchronously, which means that the status updates are in realtime instead of all coming at once in the end. In other words, it uses threading.
  • Uses .NET Framework 4.5. Not really a feature, but interesting. I tried 4.0 first, but it lacked some async (threading) functions I wanted to use.
  • Uses .NET's XMLReader for parsing the XML. Also a good experience.
  • Uses WPF with a XAML interface. Nothing fancy, really basic, but it's a nice upgrade over commandline.

Overall lots of aspects about C# programming that this allowed me to learn, so I'm pretty happy.

The image in this post shows the improvement in the png (left) over the native png (right).

Known issues

  • Sadly there is one bug I can't solve, which is that transparency often results in a weird grey border in some places, which can destroy some of the comics. Apparently this is due to how PDFs work, but I believe there must be a solution to it. Couldn't find it yet tho.
  • Positioning isn't perfect, some rare arrangements of text can result in big text positioning errors. Probably not hard to solve, but oh well.
  • Not sure I have 100% the correct font faces, but it's pretty close.

Requirements/Dependencies

Runtime:

  • .NET Framework 4.5
  • images folder containing all the rage faces (with subfolders based on category, as on ragemaker.net) in the same folder as the main .exe file. I am including this in the main folder here, just copy it into the .exe folder. This is just the images from ragemaker.net, no changes. If you own any of these images and want them taken down, please let me know.
  • Courier New Regular, Courier New Bold and Tahoma Bold font faces must be installed on the system you're using this software on. Since they are default Windows fonts, that should not be a problem.
  • For AnyFont fields, any font that was used in the comic needs to be installed.

Compilation:

  • DotNetZip.1.13.3
  • Flux.Jpeg.Core.0.8.0
  • iTextSharp.5.5.13

Examples

There are a few sample .xml files from my own comics in the examples folder. You can use these for testing. The .png files are also included for reference.

Interesting

  • When you rotate an imported image or drawing on ragemaker.net, it will be saved with the rotation value in the .xml, but it will also be baked into the embedded base64 png. When you load such an .xml file back into ragemaker.net, the rotation will be wrong. This is a bug. For this reason I simply ignore rotation for such elements, thus they appear the correct way (since they have that information already baked in).