-
Notifications
You must be signed in to change notification settings - Fork 109
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
Can the instructions for how to use this please be updated? #137
Comments
I don't know anything about nuget, but you can The win64 patch is always needed. It is for incompatibility between c# and c, really. |
I downloaded that whole project and grabbed those folders, and it worked fine on my machine but when I deployed it to another machine it failed to load freetype6 dlls. I ensured that the entire dll directory was there. |
Do you know if you are using a 32-bit or a 64-bit dotnet runtime? The c# part does not care, but when it calls back to c code as in this care, you need to use the matching one. Maybe your machine and the other machine differs this way. |
I have both and have some auto dispatch code to find the right one : https://github.com/HinTak/Font-Validator/blob/435ec1e2b49bba82231442bdebf63bcad28c70b1/Compat/Compat.cs#L72 |
I really haven't had any time to maintain this project over the last few years so I'm not really sure where it stands with the modern C# ecosystem. At a glance it looks like that should be working, I see that you already have Dependency Walker, did you see any issues related to a missing CRT dll dependency on freetype6.dll? Most likely scenario is that one machine had the right VC++ redistributable installed and the other didn't. I tried to build the dll for a bunch of different CRT versions but that requires a lot of maintenance. |
That screenshot tells a different story - the presence of libgcc_s* means it is gcc compiled (and possibly cross compiled), and the presence of libharfbuzz is worrying: harfbuzz is a large c++ library (as opposite to c), and brings in a hell lot of other dependencies like libglib* and stuff. Gcc compiled freetype does not depend on msvc runtime but on libgcc_s* (you need the matching one - it is different for win32 vs win64) The above screenshot is missing zlib1.dll . It is very common (and bundled by many software) but could be missing on your depol machine. I spent a lot of time making the minimum (and without harfbuzz!) number of dlls. Gcc compiled / cross-compiled follows Unix build instructions. |
I am recopying everything and will update. I am also going to add your if statement for dll based off of which version of windows. |
@tbandtg at the moment most likely you are missing zlib1.dll on your depol machine, especially if your depol machine is new/clean and your dev machine older and much used. zlib1.dll is quite commonly bundled by many other software and some of them copies it to system32 and make it available to other software. As you see fontval bundles it too, but keeps it local. Your screenshot does not show it. |
This all actually worked, thanks allot. The only thing I noticed is that it renders some glyphs slightly differently depending on if using sharp font or a program that was developed a long time ago using free type. I do not know if the rendering algorithm has changed, as of right now I am not worried about it but I do find it curious. Notice the third line. |
Are you talking about same backend invoked via SharpFont vs something else, or just two different runs on different platforms/versions? Especially at the lower resolution, 1-pixel changes like that shown is quite common - maybe not for changing compiler options, but you know, it happens when a number is just above 0.5 done in one way, and below 0.5 in a different way. The actual rendering, especially for Arial (a Microsoft font, known to be heavily hand-hinted) the hinting algorithm has changed a bit between 2.6 and 2.7, and also somewhat recently too (2.10?). |
Different runs on different versions. thanks for clearing it up. As I said it hadnt been a show stopper. It is clearly just a bit different. |
I shouldn't write "common"; "not unheard of" is more like it. At low resolution, when the curves are grid-fitted etc, part of it can cross-over the centre of a pixel, between version/platform/different rounding from compiler, and turn it from "on" to "off" or vice versa. Anyway, both look acceptable and neither is obviously wrong, where the edge of the Q curves around. |
I forced x64
and then just ended up putting the dll I needed into This project needs to be published with the libraries in the correct RID folder structure so that it pulls correctly. I do this in https://github.com/tilkinsc/Lua.NET if anyone wants to tackle this. |
I have been struggling with this for days. I finally was able to get the spacewizards version to work with a .netcore app for windows after I downloaded someone elses freetype6.dll. But then when I zipped that up and tried it on another computer and bam it complains about the freetype6.dll.
I have downloaded and built freetype, does it still need the patch ran? I mean it now has an x64 build option does that take care of it? Anyway even after building freetype it didnt work.
If there is a way to get started quickly from the nuget package and have everything working, that would be great. I dont need deep functionality just the ability to open a ttl file and extract glyph info to create a bmp.
The text was updated successfully, but these errors were encountered: