A cross-platform app made for e-hentai & exhentai by Flutter

  Flutter App

Description

An E-Hentai app for Android & iOS & Windows & MacOS & Linux.

Still in the development stage, welcome to submit issues or feature requests.

Download & Install

Download

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.

steps

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:

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

languageCode

countryCode

  1. Copy /lib/src/l18n/en_US.dart and rename to {your_languageCode}_{your_countryCode}.dart
  2. Rename classname in new file(optional)
  3. 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:

  1. Enter /lib/src/l18n/locale_text.dart , add a new k-v pair in method keys => {your_languageCode}_{your_countryCode} : {your_className}.keys()
  2. Enter /lib/src/consts/locale_consts.dart, add a new k-v pair in property localeCode2Description{your_languageCode}_{your_countryCode} : {languageDescription} to describe your language.

Bug

  1. Operations related to the clipboard may not work properly on Samsung devices due to a bug in Flutter itself.
  2. Change download path to SD card is not supported now.

About compiling

  1. You need to manage your Android signing by yourself, check https://docs.flutter.dev/deployment/android#signing-the-app

Main Dart Dependencies

Download source code on GitHub