#flutter #dart
#flutter #dart
Вопрос:
Я пытаюсь сделать так, чтобы мое приложение поддерживало множество разных языков, чтобы пользователь мог выбрать свой любимый из них. Я использую следующий метод для работы с языками:
easy_localization: ^2.3.2
EasyLocalization(
saveLocale: true,
supportedLocales: [
Locale('en', 'US'),
Locale('ar', 'SA')
],
path: 'assets/translations',
fallbackLocale: Locale('en', 'US'),
child: LoginScreen(),
),
Мне нужно изменить направление содержимого страницы, если арабский язык слева направо, а в случае, если это английский справа налево.
Как я могу это сделать, если у кого-то есть решение, пожалуйста, помогите мне. Я новый программист flutter
Ответ №1:
Вам нужно добавить условия для каждого виджета, который вы хотите настроить в зависимости от локализации. Что-то вроде этого:
context.locale == Locale('en', 'US')
? Text(LocaleKeys.title).tr(context: context)
: Text('Test'),
Завершенный код с небольшими изменениями отсюда:
import 'dart:developer';
import 'dart:ui';
import 'lang_view.dart';
import 'package:flutter/material.dart';
import 'package:easy_localization/easy_localization.dart';
import 'package:easy_localization_loader/easy_localization_loader.dart';
import 'package:flutter_icons/flutter_icons.dart';
import 'generated/locale_keys.g.dart';
void main() {
runApp(EasyLocalization(
child: MyApp(),
supportedLocales: [
Locale('en', 'US'),
Locale('ar', 'DZ'),
Locale('de', 'DE'),
Locale('ru', 'RU')
],
path: 'resources/langs/langs.csv',
assetLoader: CsvAssetLoader()));
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
log(context.locale.toString(), name: '${this} # locale Context');
log('title'.tr().toString(), name: '${this} # locale');
return MaterialApp(
title: 'title'.tr(),
localizationsDelegates: context.localizationDelegates,
supportedLocales: context.supportedLocales,
locale: context.locale,
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Easy localization'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
int counter = 0;
bool _gender = true;
void incrementCounter() {
setState(() {
counter ;
});
}
void switchGender(bool val) {
setState(() {
_gender = val;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
// Like in here!
title: context.locale == Locale('en', 'US')
? Text(LocaleKeys.title).tr(context: context)
: Text('Test'),
//Text(AppLocalizations.of(context).tr('title')),
actions: <Widget>[
FlatButton(
child: Icon(Icons.language),
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (_) => LanguageView(), fullscreenDialog: true),
);
},
),
],
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Spacer(
flex: 1,
),
Text(
LocaleKeys.gender_with_arg,
style: TextStyle(
color: Colors.grey.shade600,
fontSize: 19,
fontWeight: FontWeight.bold),
).tr(args: ['aissat'], gender: _gender ? 'female' : 'male'),
Text(
tr(LocaleKeys.gender, gender: _gender ? 'female' : 'male'),
style: TextStyle(
color: Colors.grey.shade600,
fontSize: 15,
fontWeight: FontWeight.bold),
),
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Icon(FontAwesome.male),
Switch(value: _gender, onChanged: switchGender),
Icon(FontAwesome.female),
],
),
Spacer(
flex: 1,
),
Text(LocaleKeys.msg).tr(args: ['aissat', 'Flutter']),
Text(LocaleKeys.msg_named)
.tr(namedArgs: {'lang': 'Dart'}, args: ['Easy localization']),
Text(LocaleKeys.clicked).plural(counter),
FlatButton(
onPressed: () {
incrementCounter();
},
child: Text(LocaleKeys.clickMe).tr(),
),
SizedBox(
height: 15,
),
Text(
plural(LocaleKeys.amount, counter,
format: NumberFormat.currency(
locale: Intl.defaultLocale, symbol: '€')),
style: TextStyle(
color: Colors.grey.shade900,
fontSize: 18,
fontWeight: FontWeight.bold)),
SizedBox(
height: 20,
),
RaisedButton(
onPressed: () {
context.deleteSaveLocale();
},
child: Text(LocaleKeys.reset_locale).tr(),
),
Spacer(
flex: 1,
),
],
),
),
floatingActionButton: FloatingActionButton(
onPressed: incrementCounter,
child: Text(' 1'),
),
);
}
}
class CustomPreloaderWidget extends StatelessWidget {
const CustomPreloaderWidget({Key key}) : super(key: key);
@override
Widget build(BuildContext context) {
log('Loading custom preloder widget');
return Container(
child: Center(child: CircularProgressIndicator()),
);
}
}
Ответ №2:
вы можете использовать Platform.LocaleName.contains(‘en’) внутри условия
import 'dart:io';
if (Platform.localeName.contains('ar'))
Icon(
Icons.arrow_back_ios_outlined,
size: 25,
),
if (Platform.localeName.contains('en'))
Icon(
Icons.arrow_forward_ios_outlined,
size: 25,
),