Flutter SDK Встановити фонове зображення


122

Я намагаюся встановити фонове зображення для домашньої сторінки. Я отримую місце зображення з початку екрана і заповнюю ширину, але не висоту. Я щось пропускаю в своєму коді? Чи є стандарти зображення для трепету? Чи масштабують зображення залежно від роздільної здатності екрана кожного телефону?

class BaseLayout extends StatelessWidget{
  @override
  Widget build(BuildContext context){
    return new Scaffold(
      body: new Container(
        child: new Column(
          mainAxisAlignment: MainAxisAlignment.start,
          children: [
            new Image.asset("assets/images/bulb.jpg") 
          ]
        )
      )
    );
  }
}

яким має бути розмір зображення? ширина висота?
ArgaPK

Хтось може навести приклад із дзвінками із мережевого зображення
The Dead Guy

1
@TheDeadGuy Image.network (' example.com/path/to/image.jpg' )?
SacWebDeveloper

замовлення замовлення тут за цим посиланням stackoverflow.com/a/62245570/9955978
Shubham Sharma

Жоден із згаданих коментарів у моєму випадку не допоміг - будь ласка, не питайте, чому. Ось корисне посилання з поясненнями: educity.app/flutter/…
boldnik

Відповіді:


332

Я не впевнений, що я розумію ваше запитання, але якщо ви хочете, щоб зображення заповнило весь екран, ви можете скористатися DecorationImageформою BoxFit.cover.

class BaseLayout extends StatelessWidget{
  @override
  Widget build(BuildContext context){
    return Scaffold(
      body: Container(
        decoration: BoxDecoration(
          image: DecorationImage(
            image: AssetImage("assets/images/bulb.jpg"),
            fit: BoxFit.cover,
          ),
        ),
        child: null /* add child content here */,
      ),
    );
  }
}

Що стосується вашого другого питання, ось посилання на документацію про те, як вставити зображення активів, залежних від роздільної здатності, у ваш додаток.


8
Це працює, поки у вас немає жодної дитини. Якщо ви додасте дитину, розмір контейнера зменшується до розміру його дитини. Чи знаєте ви, як змусити контейнер заповнити весь екран незалежно від розміру його дитини?
HyLian

@ColinJackson яким має бути розмір зображення? ширина висота?
ArgaPK

4
@HyLian встановив властивість обмежень контейнера,constraints: BoxConstraints.expand()
Рустем Какімов,

2
Для мережевого зображення можна використовуватиDecorationImage(image: Image.network("http://example.com/image.jpg").image, ...)
Євген Гр. Філіппов

@HyLian додати width: double.infinityдо контейнера із зображенням.
jkoech

45

Якщо ви використовуєте Containerяк тіло тіла Scaffold, його розмір буде відповідати розміру дочірньої дитини, і зазвичай це не те, що ви хочете, коли ви намагаєтесь додати фонове зображення у свій додаток.

Дивлячись на це інше питання, @ collin-jackson також пропонував використовувати Stackзамість Containerцього не тіло, Scaffoldа воно, безумовно, робить те, що ви хочете досягти.

Ось так виглядає мій код

@override
Widget build(BuildContext context) {
  return new Scaffold(
    body: new Stack(
      children: <Widget>[
        new Container(
          decoration: new BoxDecoration(
            image: new DecorationImage(image: new AssetImage("images/background.jpg"), fit: BoxFit.cover,),
          ),
        ),
        new Center(
          child: new Text("Hello background"),
        )
      ],
    )
  );
}

яким має бути розмір зображення? ширина висота?
ArgaPK

5
Відкриваючи клавіатуру, розмір зображення змінюється. Що для цього можна зробити?
Майкл

15

Можна використовувати DecoratedBox.

@override
Widget build(BuildContext context) {
  return DecoratedBox(
    decoration: BoxDecoration(
      image: DecorationImage(image: AssetImage("your_asset"), fit: BoxFit.cover),
    ),
    child: Center(child: FlutterLogo(size: 300)),
  );
}

Вихід:

введіть тут опис зображення


11

Ви можете використовувати, Stackщоб зображення розтягувалося на весь екран.

Stack(
        children: <Widget>
        [
          Positioned.fill(  //
            child: Image(
              image: AssetImage('assets/placeholder.png'),
              fit : BoxFit.fill,
           ),
          ), 
          ...... // other children widgets of Stack
          ..........
          .............
         ]
 );

Примітка. Опціонально, якщо ви використовуєте a Scaffold, ви можете поставити Stackвнутрішню частину Scaffoldз або без AppBarвідповідно до ваших потреб.


Точно те, що мені було потрібно, у моєму випадку мій образ знаходиться всередині ShaderMask, тому введення image:імені не вийде .
Незабаром Сантос,

5

Мені вдалося застосувати фон нижче Scaffold(і навіть це AppBar), поставивши Scaffoldпід a Stackі встановивши a Containerв перший "шар" із набором фонового зображення та fit: BoxFit.coverвластивістю.

Як Scaffoldі AppBarповинно мати backgroundColorнабір як Color.transparentі elevationз AppBarмає бути 0 (нуль).

Вуаля! Тепер у вас є гарне тло під цілим ешафотом та AppBar! :)

import 'package:flutter/material.dart';
import 'package:mynamespace/ui/shared/colors.dart';
import 'package:mynamespace/ui/shared/textstyle.dart';
import 'package:mynamespace/ui/shared/ui_helpers.dart';
import 'package:mynamespace/ui/widgets/custom_text_form_field_widget.dart';

class SignUpView extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Stack( // <-- STACK AS THE SCAFFOLD PARENT
      children: [
        Container(
          decoration: BoxDecoration(
            image: DecorationImage(
              image: AssetImage("assets/images/bg.png"), // <-- BACKGROUND IMAGE
              fit: BoxFit.cover,
            ),
          ),
        ),
        Scaffold(
          backgroundColor: Colors.transparent, // <-- SCAFFOLD WITH TRANSPARENT BG
          appBar: AppBar(
            title: Text('NEW USER'),
            backgroundColor: Colors.transparent, // <-- APPBAR WITH TRANSPARENT BG
            elevation: 0, // <-- ELEVATION ZEROED
          ),
          body: Padding(
            padding: EdgeInsets.all(spaceXS),
            child: Column(
              children: [
                CustomTextFormFieldWidget(labelText: 'Email', hintText: 'Type your Email'),
                UIHelper.verticalSpaceSM,
                SizedBox(
                  width: double.maxFinite,
                  child: RaisedButton(
                    color: regularCyan,
                    child: Text('Finish Registration', style: TextStyle(color: white)),
                    onPressed: () => {},
                  ),
                ),
              ],
            ),
          ),
        ),
      ],
    );
  }
}

3

Ми можемо використовувати контейнер і позначити його висоту як нескінченність

body: Container(
      height: double.infinity,
      width: double.infinity,
      child: FittedBox(
        fit: BoxFit.cover,
        child: Image.network(
          'https://cdn.pixabay.com/photo/2016/10/02/22/17/red-t-shirt-1710578_1280.jpg',
        ),
      ),
    ));

Вихід:

введіть тут опис зображення


2
decoration: BoxDecoration(
      image: DecorationImage(
        image: ExactAssetImage("images/background.png"),
        fit: BoxFit.cover
      ),
    ),

це також працює всередині контейнера.


-1

Щоб встановити фонове зображення без зменшення після додавання дитини, використовуйте цей код.

  body: Container(
    constraints: BoxConstraints.expand(),
      decoration: BoxDecoration(
        image: DecorationImage(
            image: AssetImage("assets/aaa.jpg"),
        fit: BoxFit.cover,
        )
      ),

    //You can use any widget
    child: Column(
      children: <Widget>[],
    ),
    ),

-1
body: Container(
    decoration: BoxDecoration(
      image: DecorationImage(
        image: AssetImage('images/background.png'),fit:BoxFit.cover
      )
    ),
);

Надану відповідь було позначено для розгляду як повідомлення низької якості. Ось декілька вказівок щодо того, як написати гарну відповідь? . Ця надана відповідь могла б отримати користь від пояснення. Відповіді лише з коду не вважаються "хорошими" відповідями.
Трентон Маккінні
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.