При открытии диплинка в мертвом приложении у меня просто черный экран?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 При открытии диплинка в мертвом приложении у меня просто черный экран?

Сообщение Anonymous »

Я пытаюсь заставить приложение открывать глубокие ссылки, такие как «appname:///loadgame/gameid», но когда мы пытаемся открыть ссылки, когда приложение закрыто, оно просто переходит на черный экран.
Я пробовал ждать загрузки приложения, задерживать навигацию по gorouter на несколько секунд и выполнять еще несколько действий, но это просто не работает.
GoRouter называется appRouter.
/>Когда приложение находится в фоновом режиме, оно работает нормально, но оно должно работать и когда оно не работает.

Код: Выделить всё

class MyApp extends StatefulWidget {
const MyApp({super.key});

@override
State createState() => _MyAppState();
}

class _MyAppState extends State {
late AppLinks _appLinks;
late dynamic _sub;
Uri? _pendingInitialUri;
bool deadStartHandled = false;

@override
void initState() {
super.initState();
_initAppLinks();
}

Future _initAppLinks() async {
_appLinks = AppLinks();

// cold start
final initialUri = await _appLinks.getInitialLink();
if (initialUri != null) {
_pendingInitialUri = initialUri;

if (!mounted) return;
_handleIncomingLink(_pendingInitialUri!, true);
deadStartHandled = true;
_pendingInitialUri = null;
} else {
// app is running
_sub = _appLinks.uriLinkStream.listen(
(Uri? uri) {
if (uri != null) {
deadStartHandled = false;
_handleIncomingLink(uri, false);
}
},
);
}
}

void _handleIncomingLink(Uri uri, bool appStart) {
if (uri.scheme == 'appname' &&
(uri.path == '/' || uri.toString() == 'appname://')) {
debugPrint('Custom scheme URL intercepted: $uri');
return;
} else {
if (appStart) {
//this one sends directly to '/' but nothing happens
context.go(uri.path);

//this one shows a black screen
//appRouter.go(uri.path);
} else {
appRouter.go(uri.path);
}

return;
}
}

@override
void dispose() {
super.dispose();
_sub.cancel();
}

// This widget is the root of your application.
@override
Widget build(BuildContext context) {
context.read();

return MaterialApp.router(
localizationsDelegates: const [
AppLocalizations.delegate,
GlobalMaterialLocalizations.delegate,
GlobalWidgetsLocalizations.delegate,
GlobalCupertinoLocalizations.delegate,
],
supportedLocales: const [
Locale('sv'),
],
title: 'AppName',
theme: AppTheme().getTheme(),
routerConfig: appRouter,
builder: (context, child) {
return Stack(
children: [
child!,
if (context.watch().shouldShowLoader)
LoadingScreen(context: context),
],
);
},
);
}
}
Я также пытался установить что-то подобное в инициализации, но выдает ту же ошибку, просто черный экран.

Код: Выделить всё

WidgetsBinding.instance.addPostFrameCallback((_) {
if (_pendingInitialUri != null) {
_handleIncomingLink(_pendingInitialUri!, deadStartHandled);
_pendingInitialUri = null;
}
});
ОБНОВЛЕНИЕ: https://github.com/flutter/flutter/issues/142988
Похоже, что это постоянная проблема с Flutter как для IOS, так и для Android.


Подробнее здесь: https://stackoverflow.com/questions/798 ... een-for-me
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»