美文网首页
8.分类 广告和推荐商品

8.分类 广告和推荐商品

作者: 冰点雨 | 来源:发表于2019-12-23 20:05 被阅读0次
274087e15ddbe7a6e0a42086a47bbad.png
import 'dart:js';

import 'package:flutter/material.dart';
import '../service/service_method.dart';
import 'package:flutter_swiper/flutter_swiper.dart';
import 'dart:convert';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:url_launcher/url_launcher.dart';


class HomePage extends StatefulWidget {
  _HomePageState createState() => _HomePageState();

}

class _HomePageState extends State<HomePage> {
  
  @override
  Widget build(BuildContext context) {

    //初始化设置尺寸
    ScreenUtil.instance = ScreenUtil(width: 750,height: 1334)..init(context);

    return Scaffold(
        appBar: AppBar(
          title: Text('百姓生活+'),
        ),
        body: FutureBuilder(
          future: getHomePageContent(),
          builder: (context,snapshot){

            if(snapshot.hasData){
              
              var data=json.decode(snapshot.data.toString());
              List<Map> swiperDataList = (data['data']['slides'] as List).cast();
              // 顶部轮播组件数
              List<Map> navigatorList =(data['data']['category'] as List).cast(); //类别列表
              String advertesPicture = data['data']['advertesPicture']['PICTURE_ADDRESS']; //广告图片
              String  leaderImage= data['data']['shopInfo']['leaderImage'];  //店长图片
              String  leaderPhone = data['data']['shopInfo']['leaderPhone']; //店长电话
              List<Map> recommendList = (data['data']['recommend'] as List).cast(); // 商品推荐

              return  SingleChildScrollView(

                child: Column(
                  children: <Widget>[
                    SwiperDiy(swiperDataList:swiperDataList),   //页面顶部轮播组件
                    TopNavigator(navgatorList:navigatorList),  //导航组件
                    AdBanner(advertesPicture:advertesPicture),   //广告组件
                    LeaderPhone(leaderImage:leaderImage,leaderPhone: leaderPhone),  //广告组件
                    Recommend(recommendList: recommendList),

                  ],
                ),

              );

            }else{
              return Center(
                child: Text('加载中'),

              );
            }

          },
        )
    );
  }
}


// 首页轮播组件编写
class SwiperDiy extends StatelessWidget {

  final List swiperDataList;
  SwiperDiy({Key key,this.swiperDataList}):super(key:key);

  @override
  Widget build(BuildContext context){
    ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);
    return Container(
      height: ScreenUtil().setHeight(333),
      width: ScreenUtil().setWidth(750),
      child: Swiper(
        itemCount: 3,
        itemBuilder: (BuildContext context,int index){
          return Image.network("http://via.placeholder.com/350x150",fit: BoxFit.fill);
        },
        pagination: SwiperPagination(),//轮播图小点
        autoplay: true,//自动播放
      ),
    );
  }
}


//首页导航区域编写
class TopNavigator extends StatelessWidget
{
  final List navgatorList;
  TopNavigator({Key key, this.navgatorList}) : super(key: key);

  Widget _gridItemUI(BuildContext context,item){
    return InkWell(
      onTap: (){
        print('点击了导航');
      },
      child: Column(
        children: <Widget>[

          Image.network(item['image'],width:ScreenUtil().setWidth(95)),
          Text(item['mallCategoryName'])


        ],
      ),

    );
  }


  @override
  Widget build(BuildContext context){
    return Container(
      height: ScreenUtil().setHeight(320),
      padding: EdgeInsets.all(3.0),
      child: GridView.count(
        crossAxisCount: 5,
        padding: EdgeInsets.all(4.0),
        children:
        navgatorList.map((item){
          return _gridItemUI(context,item);
        }).toList()
      ),

    );
  }

}


//广告图片
class AdBanner extends StatelessWidget
{
  final String advertesPicture;
  AdBanner({Key key, this.advertesPicture}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Container(
      child: Image.network(advertesPicture),
    );
  }
  }


//打电话
class LeaderPhone extends StatelessWidget {
  final String leaderImage; //店长图片
  final String leaderPhone; //店长电话

  LeaderPhone({Key key, this.leaderImage,this.leaderPhone}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Container(
      child: InkWell(
        onTap:_launchURL,
        child: Image.network(leaderImage),
      ),
    );
  }

  void _launchURL() async {
    String url = 'tel:'+leaderPhone;
    if (await canLaunch(url)) {
      await launch(url);
    } else {
      throw 'Could not launch $url';
    }
  }
}


//商品推荐区域
class Recommend extends StatelessWidget{
  final List recommendList;
  Recommend({Key key,this.recommendList}):super(key:key);

  @override
  Widget build(BuildContext context){
    return Container(
      height: ScreenUtil().setHeight(380),
      margin: EdgeInsets.only(top: 10.0),
      child: Column(
        children: <Widget>[


        ],
      ),
    );
  }


  //推荐商品标题
   Widget _titleWidget(){
      return Container(
         alignment: Alignment.centerLeft,
         padding: EdgeInsets.fromLTRB(10.0, 2.0, 0, 5.0),
         decoration: BoxDecoration(
             color: Colors.white,
             border: Border(
                 bottom: BorderSide(width: 0.5,color: Colors.black12)
              )
          ),
           child: Text(
                     '商品推荐',
                      style: TextStyle(color: Colors.pink),
                ),

       );
    }



    //商品列表
   Widget _reccomendList(){
    return Container(
      height: ScreenUtil().setHeight(330),
      child: ListView.builder(
        scrollDirection: Axis.horizontal,
        itemCount: recommendList.length,
        itemBuilder: (context,index){
          return _item(index);
        },
      ),
    );
   }



   //推荐item
   Widget _item(index){
    return InkWell(
      onTap: (){
        print('点击推荐商品');
      },
      child: Container(
        height: ScreenUtil().setHeight(330),
        width: ScreenUtil().setWidth(250),
        padding: EdgeInsets.all(8.0),
        decoration: BoxDecoration(
            color:Colors.white,
            border:Border(
                left: BorderSide(width:0.5,color:Colors.black12)
            )
        ),
        child: Column(
          children: <Widget>[
            Image.network(recommendList[index]['image']),
            Text('¥${recommendList[index]['mallPrice']}'),
            Text(
              '¥${recommendList[index]['price']}',
              style: TextStyle(
                decoration: TextDecoration.lineThrough,
                color: Colors.grey
              ),
            ),
          ],
        ),

      ),
    );
   }




}

相关文章

  • 8.分类 广告和推荐商品

  • 商城功能

    前端功能 首页banner广告-最热商品-限时抢购-推荐商品-精品商品-分类-二级商品分类-搜索-宝贝搜索-店铺列...

  • Day003 商品应用需求分析 及 Django 开发介绍

    管理员需要做什么? 管理商品分类:新建分类、编辑分类和删除分类。 管理商品:新建商品、编辑商品。 管理商品规格:新...

  • 搜索推荐技术在电商导购领域的应用(三):自动分类

    搜索推荐技术在电商导购领域的应用(三):自动分类 有一个问题需要解决:自动分类。做好个性化商品推荐,商品整理是第一...

  • 商品的基本概念

    商品模块 1.1 商品分类 商品分类就是把商品分别放到 不同的类目下面。 1.2 品牌 品牌需要可以在平台后台和商...

  • 协同过滤-ALS算法

    ALS算法应用场景 ALS属于数据挖掘,可以做推荐系统,比如电影推荐,商品推荐,广告推荐等. 原理就是给各个指标,...

  • PHP简单电商平台

    搭建框架,添加常用辅助函数 设计数据库 实现后台功能 商品分类 功能 添加商品分类,显示商品分类,编辑商品分类,删...

  • 商城迁移

    08 管理平台开发09 管理平台:分类管理开发10 管理平台 商品管理11 管理平台 商品图片管理12 分类和商品...

  • 床垫系列:选购资料库

    『选购资料库』系列旨在收集『对商品选购有帮助的』各式资料。 列举标题和来源,按类型分类,点评内容和质量。 推荐程度...

  • 电热水器:选购资料库

    『选购资料库』系列旨在收集『对商品选购有帮助的』各式资料。列举标题和来源,按类型分类,点评内容和质量。推荐程度从高...

网友评论

      本文标题:8.分类 广告和推荐商品

      本文链接:https://www.haomeiwen.com/subject/egjtoctx.html