. Ниже я представлю вам несколько подходов и примеры кода:
Метод 1. Использование Контейнерапроизвольного размера
Вы можете обернуть IconButtonвнутри Containerи явно указать его размер. Таким образом, вы можете контролировать размер без каких-либо минимальных ограничений.
Container(
width: 24, // Set the desired width
height: 24, // Set the desired height
child: IconButton(
icon: Icon(Icons.remove),
onPressed: () {
// Handle button press
},
),
)
Метод 2: использование SizedBoxс нестандартным размером
Подобно предыдущему методу, вы можете использовать SizedBox, чтобы указать желаемый размер IconButton.
SizedBox(
width: 24, // Set the desired width
height: 24, // Set the desired height
child: IconButton(
icon: Icon(Icons.remove),
onPressed: () {
// Handle button press
},
),
)
Метод 3. Создание пользовательского виджета кнопки
Вы можете создать собственный виджет кнопки, расширив класс IconButtonи переопределив его ограничения макета. Это позволяет вам полностью контролировать размер.
class CustomIconButton extends IconButton {
CustomIconButton({
required IconData icon,
required VoidCallback onPressed,
}) : super(
icon: Icon(icon),
onPressed: onPressed,
);
@override
Widget build(BuildContext context) {
return ConstrainedBox(
constraints: BoxConstraints(
minWidth: 0, // Set minimum width to 0
minHeight: 0, // Set minimum height to 0
),
child: super.build(context),
);
}
}
Использование:
CustomIconButton(
icon: Icons.remove,
onPressed: () {
// Handle button press
},
)