-
-
Notifications
You must be signed in to change notification settings - Fork 90
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
Looking for translators #261
Comments
Good job bro! I can provide translation contributions in Simplified Chinese(zh-CN) and Traditional Chinese(zh-TW)~ |
Very good idea, my team on discord would be ready to work for the French part ^^ |
cc @spreedated who worked on translations in #253 |
My fork is still up and running. |
Starting with 6.0 the new GUI also builds for mac, linux and android making Windows projects specific stuff like resx either unapplicable or a pain to use which is why i was proposing jsons. Android in particular is a very annoying platform to support properly. Most notably we lose winforms magic font support that just works and have to manually manage fonts and character ranges. This is the reason why localization didn't make it into the 6.0 release. |
Indeed, I share your view on this one and I guess an XML style or JSON is the best practice approach for it. However, I'm way too technical here, as for the translators, I could provide translation in German and Polish. |
As for design, we are constrained by the lowest common denominator for cross platform. Essentially, the application is a console app with sdl and imgui, which is an immediate mode gui that runs in a loop, kinda like a game engine. Such is the unfortunate state of cross platform user interfaces that are not a web browser. |
Depending on which platforms you aim for, MAUI (former XAMARIN) is also a good approach, it aims at MVVM which implies cross-platform compatibility by strict encapsulation. AOT is common all over the .NET framework anyways and native Java library is used in the android part of MAUI. However, with your approach using SDL/OpenGL makes it somehow independent and more versatile, but also more work to do since you have to build the layout, pages, behaviors (which imgui helps alot with) etc. yourself, also the architecture of the application. Tbh, I am not familiar with the latest state of the project and I just saw that you released 6.0 last week so I'll definitely give it a shot. Keep up the good work! |
Last time i tried MAUI it did not feel stable yet, i did considering trying UNO or Avalonia though. The main problem that made me pick SDL in the end is the video renderer. Truns out there is no "batteries included" library that allows playing raw video data without a proper container so i had to manually use ffmpeg which produces a framebuffer for each frame decoded. SDL gives me the low level flexibility of making a double buffered GPU renderer that does not allocate memory for each frame, other WPF-like frameworks did not seem to support this in a cross-platform way at the time i looked into it. |
pl-PL here if needed! |
I made some initial work in the translation-support branch. This is still experimental, do not start translating yet. Translation files will look like this: {
"translationName": "English",
"translationAuthor": "SysDVR",
"systemLocale": [
"en-us"
],
"imGuiGlyphRange": "Default", // optional
"fontName": "OpenSans.ttf", // optional
"mainGUI_ChannelLabel": "Select the streaming mode",
"mainGUI_ChannelVideo": "Video only",
"mainGUI_ChannelAudio": "Audio only",
// etc...
} Of particular interest are the The To be included in SysDVR, fonts will have to be distributed under an open license, a good example is Google Noto which seems to implement most alphabets. Any objections to this design ? Once this is done i'll start to think about what to do with the on-console settings app since that does have some text as well, but uses a different architecture. |
No objections and instant help if needed. |
Just my two cents, but instead of using prefixes for the categories, we could use objects. {
"localeInfo":
{
"author": "SysDVR",
"imGuiGlyphRange": "Default", // optional
"fontName": "OpenSans.ttf" // optional
},
"localization":
{
"mainGui":
{
"channelLabel": "Select the streaming mode",
"channelVideo": "Video only",
"channelAudio": "Audio only"
},
"settings":
{
"settings": "Settings",
}
//etc.
}
} Another thing about encapsulation comes to the locale array; imho it's better to have separate files for each locale and named it properly inside the locale folder like "en-US.json" "de-DE.json" etc. (filenaming by languagecode) so they can be identified this way. |
I figured one might want the same language file for multiple locales, on start the app will load all the jsons (deserializing only the metadat fields) and pick the matching locale. As for encapsulation, I'll think about it, don't see any real advantage cause I can't use fancy techniques like dependency injection or auto mapping to pages. Meant the prefixes as context for translators cause I happened to do some software translating and the lack of context in string files reduces the overall quality if the translator is not paying attention. |
Translation support is now functional for the client, you can find the default strings file in https://github.com/exelix11/SysDVR/blob/translation-support/Client/Platform/Resources/resources/strings/english.json You can submit a pull request to the translation-support branch or just provide your translated file here or on discord. Let me know if any issue pops up., in the meantime i'll look into adding translation support to the console settings app as well. |
Happens 6/10 times trying to debug. public void Clear()
{
ImGuiNative.ImFontGlyphRangesBuilder_Clear((ImFontGlyphRangesBuilder*)(NativePtr));
} Maybe |
Are you using latest commit ? i think I fixed this already. Also provide a stack trace of the crash. |
Re-reading the code it may also be non zeroed memory in the font builder constructor, but it's weird it didn't trip at all for me during development on both windows and android. I'll look into it but not before this weekend as I'm busy irl. |
Okay, I think I fixed it by changing the You can find it within my PR for the german translation: |
only now found some time to look at your fix, I had completely missed that cimgui exposed a wrapper for the constructor. I did some debugging and the issue was indeed not zeroing memory but your fix is probably better. |
I just added translation support for the on-console settings app, you can find the strings json file here: https://github.com/exelix11/SysDVR/blob/translation-support/SysDVRConfig/romfs/strings/english.json |
I can help with the translation into Russian |
I can help with the spanish translation |
This issue is stale because it has been open for 30 days with no activity. |
I'm planning to release v6.1 in a week or two. If anyone is working on a translation please let me know so i can plan the release accordingly. The hopefully definitive files to translate are:
For the people who already submitted a translation i'd like a quick update for a few strings i added recently, see the diff with the new strings here: 4061998#diff-5815bfc9da2e5f091a0e5ace0807c764709d073a1db152be041946d90048259a I think only @spreedated is on github, the others DM'd me on discord |
I can help with the brazilian portuguese translation 😄 |
Multiple users requested the ability to localize this project in their own native languages.
I'm planning to implement this feature for the next release and as such i'm gathering people interested in translating this application.
I'm opening this before starting work on this feature to gather feedback on how many people are interested in providing translations and any suggestions before i take a fatally wrong design decision. If you are interested reply here with the language(s) you are willing to add support for.
I will be posting any updates directly here so if you are interested enable notifications for new posts so you can keep up with the discussion.
The way i'm planning to implement this right now is the following:
The text was updated successfully, but these errors were encountered: