JHenTai
English | 简体中文
Description
An E-Hentai app for Android & iOS & Windows & MacOS & Linux.
Still in development stage, welcome to submit issues or feature requests.
Download & Install
Install for Android: download .apk according to your device architecture and install.
- arm64-v8a:Suitable for Android phones with 8th generation ARM processor(common choice)
- armeabiv-v7a:Suitable for Android phones with 7th generation ARM processor
- x86_64:rare
Install for iOS: download .ipa, then use AltStore or SideLoadly to sign.
Install for Windows: download Windows_xxx.zip, then unpack it. If you use a proxy server, set proxy address at network setting page. If you're using Windows 11 and can't launch app, try to run jhentai.exe in compatibility mode. If it's blocked by Windows Defender, Please trust it.
Install for MacOS: download .dmg. If you use a proxy server, set proxy address at network setting page.
Install for Linux(No maintenance): download Linux_xxx.zip, then unpack it. If you use a proxy server, set proxy address at network setting page.
Help With Translation
Please submit a PR if you want to help with translation.
Develop Motivation
My first project With Flutter. I aim at getting familiar with Flutter during development. Devices I use include Android phone, Ipad and Windows computer. E-hentai apps I used before have several bugs, and I don't understand source code because I have no development experience with Android or ios, so I choose JHenTai to become my first Flutter Project.
2022.08.20 After five months of development, JHenTai has gradually become more and more strong, and I have completely refactored some codes for gallery page, reading page, download, etc. which are written at the beginning stage. I tried my best to extract the commonality between different page and style to reduce coupling, in order to benefit the development of new features. I would be very grateful if any kind of you could give me some advice on coding style, design patterns and anything related to Flutter development or participate in the development of JHenTai.
2022.10.29 I have been more familiar with basic Flutter development, and I'll focus on another area from now on. So updates for JHenTai will be less than previous, but I'll still handle bugs or issues in time。
References & Thanks
Layout and style references:
Tag translation:
App translation:
- andyching168 繁體中文(台灣)
- lucas-04 Português brasileiro
mush thanks to these projects and people🙇
Screenshots
Mobile Layout
Tablet Layout
Desktop Layout
Gallery & Search
Gallery Detail
Setting & Download
Read
Main Features
- Mobile, tablet, desktop layout(3 kinds)
- Vertical, horizontal, double column read page layout(4 kinds)
- GalleryPage, Popular, Favorite, Watched, History, support multiple gallery list style
- search, search suggestion, tap tag to search, file search, jump to a certain page
- online reading and download, support restore download task, support synchronize updates after the uploader has uploaded a new version
- archive download and automatic unpacking and reading
- support loading local images and read
- support assign priority to download task manually
- support assign group to gallery and archive
- favorite, rating, torrent, archive, statistics, share
- password login, Cookie login, web login
- support EX site(domain fronting optional)
- vote for Tag, watch and hidden tags
- comment, vote for comment
- Fingerprint unlock
- Support shortcut keys like 'Tab' and 'Arrow keys' in desktop layout
Translation
- Copy
/lib/src/l18n/en_US.dart
and rename to{your_languageCode}_{your_countryCode}.dart
- Rename classname in new file(optional)
- Modify k-v pairs in method
keys
,translate values to your language
Now you can submit your PR, I'll do the remaining things. Or you can go on with:
- Enter
/lib/src/l18n/locale_text.dart
, add a new k-v pair in methodkeys
=>{your_languageCode}_{your_countryCode} : {your_className}.keys()
- Enter
/lib/src/consts/locale_consts.dart
, add a new k-v pair in propertylocaleCode2Description
:{your_languageCode}_{your_countryCode} : {languageDescription}
to describe your language.
Bug
- Operations related to the clipboard may not work properly on Samsung devices due to a bug in Flutter itself.
- Change download path to SD card is not supported now.
About compiling
- You need to manage your Android signing by yourself, check https://docs.flutter.dev/deployment/android#signing-the-app
Main Dart Dependencies
- get: dependency management, state management, l18n, NoSQL
- dio: network
- extendedImage: image
- drift: database