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

Android support #82

Closed
TheLastProject opened this issue Apr 3, 2021 · 10 comments
Closed

Android support #82

TheLastProject opened this issue Apr 3, 2021 · 10 comments

Comments

@TheLastProject
Copy link

Hey devs!

I'd like to try this library on Android because it supports outputting way more barcode formats than zxing support, so I am hoping I can fix CatimaLoyalty/Android#181 using this library.

I however can't seem to use this library because all the renderers depend on java.awt, which is not supported on Android.

Are there any plans on perhaps supporting Android? I sadly do not think I can help much myself, given I am not very knowledgeable at image drawing, but a renderer that creates an Android Bitmap would most likely be the most convenient way for Android users to be able to use this library too.

@gredler
Copy link
Collaborator

gredler commented Apr 3, 2021

This would be an interesting enhancement, but not something that I'm likely to implement myself. It would probably be just another uk.org.okapibarcode.output.SymbolRenderer implementation, similar to uk.org.okapibarcode.output.Java2DRenderer.

I wonder if we start requiring Java 11 or Java 17 in the next few years, whether that closes the door on any Android support in the future?

@TheLastProject
Copy link
Author

I understand. Right now Android is supporting partial Java 8 syntax, so it will definitely always be behind in version support: https://developer.android.com/studio/write/java8-support.

So supporting Android will sadly mean having to support lower Java versions for longer, yes.

@lT1161558158
Copy link

not only provide uk.org.okapibarcode.output.SymbolRenderer implementation ,also to provide the Symbol refrence awt class
eg java.awt.geom.Ellipse2D and java.awt.geom.Rectangle2D

@gredler
Copy link
Collaborator

gredler commented Feb 12, 2024

Just an update: Some work was already done in release 0.4.0 to remove most of the AWT class usage (except in the Java2D renderer). This should go a long way to helping users to more easily incorporate Okapi into Android projects.

@kratho
Copy link

kratho commented Feb 22, 2024

You can use the SvgRenderer on Android and convert the svg result to a Bitmap using androidsvg for example.

@gredler
Copy link
Collaborator

gredler commented Feb 22, 2024

Thanks for the suggestion, have you used this approach yourself in an application?

The only possible gap I see is that the text element is only partially supported by AndroidSVG, and I'm not sure if all of the text attributes used by Okapi are supported.

@kratho
Copy link

kratho commented Feb 22, 2024

Yes i tried this approach and it is working fine!

Regarding the text element: you are right, according to AndroidSvg this might be a limitation. For my use case this is not relevant as i am hiding the human-readable text anyway. But there are multiple other svg to bitmap libraries available which may support this.

@gredler
Copy link
Collaborator

gredler commented Feb 22, 2024

Great, thanks for the confirmation! Hopefully it will help others who have similar needs.

One last question, if you don't mind: if you're using Okapi version 0.4.x (with most of the references to the AWT classes removed), did you have to fork and customize Okapi in order to use it on Android? Or did it work out of the box for you? I'm not very familiar with Android development, so I'm not sure how easy or hard it is to use Okapi 0.4.x on Android, or where the remaining roadblocks are (if any).

@kratho
Copy link

kratho commented Feb 23, 2024

No i didn't have to fork or customize Okapi in order to use it on Android. This is working out of the box as, in contrary to the Java2D renderer, there are no java.awt references in the SvgRenderer.

@gredler
Copy link
Collaborator

gredler commented Feb 23, 2024

That's great to hear! I'll add a blurb to the README with this recommendation for Android developers, close this ticket out, and if anyone runs into more specific Android issues then we can address them in a separate ticket.

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

No branches or pull requests

4 participants