Зображення закруглених кутів у мерехтінні


122

Я використовую Flutter, щоб скласти список інформації про фільми. Тепер я хочу, щоб зображення на обкладинці зліва було закругленим кутом. Я зробив наступне, але це не вийшло. Дякую!

    getItem(var subject) {
    var row = Container(
      margin: EdgeInsets.all(8.0),
      child: Row(
        children: <Widget>[
          Container(
            width: 100.0,
            height: 150.0,
            decoration: BoxDecoration(
              borderRadius: BorderRadius.all(Radius.circular(8.0)),
              color: Colors.redAccent,
            ),
            child: Image.network(
              subject['images']['large'],
              height: 150.0,
              width: 100.0,
            ),
          ),
        ],
      ),
    );
    return Card(
      color: Colors.blueGrey,
      child: row,
    );
  }

наступним чином

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


Ви зрозуміли, чому цей метод не працює?
Мартін

Відповіді:


356

Використовувати ClipRRectйого буде прекрасно

ClipRRect(
    borderRadius: BorderRadius.circular(8.0),
    child: Image.network(
        subject['images']['large'],
        height: 150.0,
        width: 100.0,
    ),
)

9
Дякую ! Я зробив це, як ви сказали, а потім додав fit: BoxFit.fill, це виглядає досить добре.
Лю Сілонг

2
Дякую - чи маєте ви ідею, як створити барвисту рамку для зображення clipRRect'ed?
iKK

3
@iKK - Загорніть його в контейнер з коробкою. Декорація з відповідним кордоном / кордономRadius реквізити так: Container( decoration: BoxDecoration( borderRadius: BorderRadius.circular(3.0), border: Border.all(color: Colors.grey[300])), child: ClipRRect( borderRadius: BorderRadius.circular(3.0), child: Image.network( uri, fit: BoxFit.fill, width: imageDimension, height: imageDimension, ), ), )
Daniel Allen

1
дякую, підказка: працює лише з однаковою шириною та висотою
Álvaro Agüero

50

Ви також можете використовувати CircleAvatar, що поставляється з трепетом

CircleAvatar(
  radius: 20,
  backgroundImage: NetworkImage('https://via.placeholder.com/140x100')
)

2
Це найкраща відповідь. Я зробив додатковоbackgroundImage: member[index].picture == null ? Image(image: AssetImage('assests/no-image.png')) : NetworkImage( member[index].picture,
saviour123

@ saviour123 не кожне зображення із закругленими кутами є "аватаром". Прийнятим є загальна відповідь.
nipunasudha

Неможливо встановити висоту чи ширину за допомогою цього віджета, що є проблематичним.
папільйон

38

Використовувати ClipRRectпотрібно жорсткий код BorderRadius, тому якщо вам потрібні повні кругові речі, використовуйте ClipOvalзамість цього.

ClipOval(
  child: Image.network(
    "image_url",
    height: 100,
    width: 100,
    fit: BoxFit.cover,
  ),
),

2
Найпростіша відповідь!
Елвін Конда

1
якщо зображення дитини не є квадратним, відсікання буде еліптичним у цьому рішенні.
Білал Şimşek

29

Спробуйте це замість цього, працював для мене:

Container(
  width: 100.0,
  height: 150.0,
  decoration: BoxDecoration(
    image: DecorationImage(
        fit: BoxFit.cover, image: NetworkImage('Path to your image')),
    borderRadius: BorderRadius.all(Radius.circular(8.0)),
    color: Colors.redAccent,
  ),
),

Ваш відповідач, безумовно, корисний, дякую! Але що робити, якщо вміст контейнера - це не просто зображення, а віджет? Будь-яка ідея?
Олександр

13
   Container(
      width: 48.0,
      height: 48.0,
      decoration: new BoxDecoration(
        shape: BoxShape.circle,
        image: new DecorationImage(
            fit: BoxFit.fill,
            image: NetworkImage("path to your image")
        )
    )),

5

Для зображення використовуйте це

ClipOval(
    child: Image.network(
        'https://url to your image',
        fit: BoxFit.fill,
    ),
);

Хоча для Asset Image використовуйте це

ClipOval(
    child: Image.asset(
        'Path to your image',
        fit: BoxFit.cover,
    ),
)

1
Я вже використовував це як відповідь, ви нічого корисного не надали. -1 від мене.
CopsOnRoad

4

З новою версією флетера та матеріальної теми вам потрібно використовувати віджет "Padding", щоб мати зображення, яке не заповнює контейнер.

Наприклад, якщо ви хочете вставити округлене зображення в AppBar, ви повинні використовувати набивання, або ваше зображення завжди буде таким же високим, як AppBar.

Сподіваюся, що це комусь допоможе

InkWell(
        onTap: () {
            print ('Click Profile Pic');
        },
        child: Padding(
            padding: const EdgeInsets.all(8.0),
            child: ClipOval(
                child: Image.asset(
                    'assets/images/profile1.jpg',
                ),
            ),
        ),
    ),

3

ви можете використовувати ClipRRect так:

  Padding(
                  padding: const EdgeInsets.all(8.0),
                  child: ClipRRect(
                    borderRadius: BorderRadius.circular(25),
                    child: Image.asset(
                      'assets/images/pic13.jpeg',
                      fit: BoxFit.cover,
                    ),
                  ),
                )

ви можете встановити радіус чи користувача лише для верхнього лівого або нижнього зліва, як:

Padding(
              padding: const EdgeInsets.all(8.0),
              child: ClipRRect(
                borderRadius: BorderRadius.only(
                    topLeft: Radius.circular(25)
                ,bottomLeft: Radius.circular(25)),
                child: Image.asset(
                  'assets/images/pic13.jpeg',
                  fit: BoxFit.cover,
                ),
              ),
            )

2

Використовуйте ClipRRect із встановленим властивістю зображення fit: BoxFit.fill

ClipRRect(
          borderRadius: new BorderRadius.circular(10.0),
          child: Image(
            fit: BoxFit.fill,
            image: AssetImage('images/image.png'),
            width: 100.0,
            height: 100.0,
          ),
        ),

1

Використовуйте ClipRRect, це вирішить вашу проблему.

      ClipRRect(
              borderRadius: BorderRadius.all(Radius.circular(10.0)),
              child: Image.network(
                Constant.SERVER_LINK + model.userProfilePic,
                fit: BoxFit.cover,
              ),
            ),

0

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

new ClipRRect(
     borderRadius: new BorderRadius.circular(30.0),
     child: FadeInImage.assetNetwork(
          placeholder:'asset/loader.gif',
          image: 'Your Image Path',
      ),
    )

0

Спробуйте це добре працює.

Container(
  height: 220.0,
  width: double.infinity,
  decoration: BoxDecoration(
    borderRadius: new BorderRadius.only(
      topLeft: Radius.circular(10),
       topRight: Radius.circular(10),
    ),
    image: DecorationImage(
      fit: BoxFit.fill,
      image: NetworkImage(
        photoUrl,
      ),
     ),
   ),
);

-1

зображення прикраси користувача для контейнера.

  @override
  Widget build(BuildContext context) {
    final alucard = Container(
        decoration: new BoxDecoration(
        borderRadius: BorderRadius.circular(10),
          image: new DecorationImage(
              image: new AssetImage("images/logo.png"),
              fit: BoxFit.fill,
          )
        )
    );
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.