You are on page 1of 2

import 'package:flutter/material.

dart';
import 'package:responsive_builder/responsive_builder.dart';

void main() {
runApp(const MyApp());
}

class MyApp extends StatelessWidget {


const MyApp({super.key});

@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
useMaterial3: true,
),
home: HomePage(),
);
}
}

class HomePage extends StatelessWidget {


const HomePage({super.key});

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Responsive Builder'),
),
body: OrientationLayoutBuilder(
portrait: (context) => protiteModeWidget(),
landscape: (context) => LendscapeModeWidget(),
),
);
}
}

Widget protiteModeWidget() {
return Column(
children: [
Expanded(
child: DecoratedBox(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(50),
),
child: ClipOval(
child: Image.network(
'https://picsum.photos/200',
fit: BoxFit.cover,
),
),
),
),
Expanded(
child: Container(
padding: const EdgeInsets.all(10),
child: GridView.builder(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3,
crossAxisSpacing: 10,
mainAxisSpacing: 10,
childAspectRatio: 1,
),
itemCount: 10,
itemBuilder: (context, index) {
return Image.network('https://picsum.photos/200');
},
),
),
),
],
);
}

Widget LendscapeModeWidget() {
return Row(
children: [
Expanded(
child: DecoratedBox(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(50),
),
child: ClipOval(
child: Image.network(
'https://picsum.photos/200',
fit: BoxFit.cover,
),
),
),
),
Expanded(
child: Container(
padding: const EdgeInsets.all(10),
child: GridView.builder(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3,
crossAxisSpacing: 10,
mainAxisSpacing: 10,
childAspectRatio: 1,
),
itemCount: 10,
itemBuilder: (context, index) {
return Image.network('https://picsum.photos/200');
},
),
),
),
],
);
}

You might also like