Flutter 本地小说阅读器

1、功能

本地导入小说文本浏览

已有功能:

  1. 导入txt小说

  2. 分析小说文本,分章节存入数据库

  3. 浏览小说文本,简单翻页功能。

2、使用技术

使用flutter框架

sqlite存储

gbk2utf对gbk编码支持

file_picker文件选择器

等..

3、使用说明


 

  1. 点击书架下方+号,选择后可导入
  2. 导入后,等待完成提示后,可点开页面进行阅读。
  3. 点击找书界面,可以去下载小说。

代码传送门

apk传送门

Flutter中,你可以使用shared_preferences插件来实现本地存储。对于macOS平台,shared_preferences会将数据保存到本地系统文件库中的FileSystem中。你可以按照以下步骤来使用shared_preferences进行本地存储: 1. 首先,在你的Flutter项目中添加shared_preferences插件的依赖。 2. 然后,在你的Dart文件中导入shared_preferences库,通过SharedPreferences.getInstance()方法获取SharedPreferences实例。 3. 通过SharedPreferences实例,你可以使用setString()、setInt()、setDouble()、setBool()等方法将数据存储到本地。 4. 使用getString()、getInt()、getDouble()、getBool()等方法从本地获取存储的数据。 5. 如果你想要清除本地存储的数据,可以使用clear()方法。 以下是一个示例代码,展示了如何使用shared_preferences来实现本地存储: ```dart import 'package:flutter/material.dart'; import 'package:shared_preferences/shared_preferences.dart'; class MyHomePage extends StatefulWidget { @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { // 获取SharedPreferences实例 Future<SharedPreferences> _prefs = SharedPreferences.getInstance(); late SharedPreferences _sharedPreferences; @override void initState() { super.initState(); _initSharedPreferences(); } // 初始化SharedPreferences实例 void _initSharedPreferences() async { _sharedPreferences = await _prefs; } // 存储数据到本地 void _saveData(String key, String value) async { await _sharedPreferences.setString(key, value); } // 从本地获取数据 String _getData(String key) { return _sharedPreferences.getString(key) ?? ''; } // 清除本地存储的数据 void _clearData() async { await _sharedPreferences.clear(); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('Flutter本地存储'), ), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ ElevatedButton( onPressed: () { _saveData('name', 'John'); }, child: Text('存储数据'), ), ElevatedButton( onPressed: () { String name = _getData('name'); showDialog( context: context, builder: (BuildContext context) { return AlertDialog( title: Text('从本地获取的数据'), content: Text(name), actions: <Widget>[ TextButton( child: Text('关闭'), onPressed: () { Navigator.of(context).pop(); }, ), ], ); }, ); }, child: Text('获取数据'), ), ElevatedButton( onPressed: () { _clearData(); }, child: Text('清除数据'), ), ], ), ), ); } } void main() { runApp(MaterialApp( home: MyHomePage(), )); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值