使用Flutter開發的抖音國際版

来源:https://www.cnblogs.com/fengqingyangNo1/archive/2020/05/21/12927538.html
-Advertisement-
Play Games

簡介 最近花了兩天時間研究使用Flutter開發一個抖音國際版. 先上圖,個人感覺使用Flutter開發app快得不要不要的額. 兩天就基本可以開發個大概出來. 最主要是熱更新,太方便實時調整UI佈局了. 相應速度極快. 功能介紹 Flutter開發安卓、IOS app確實方便,還有熱更新可以實時查 ...


簡介

最近花了兩天時間研究使用Flutter開發一個抖音國際版. 個人感覺使用Flutter開發app快得不要不要的額.  兩天就基本可以開發個大概出來.   最主要是熱重載,太方便實時調整UI佈局了.  相應速度極快.  如下圖:

 

主要項目架構

 

 詳細說明一下,開發主要在lib文件夾

  • pubspec.yaml是配置插件的位置,如http: ^0.12.0+4,類似依賴組件.
  • common文件夾存放的是重寫的網路組件,以及圖標組件icons.dart
  • config文件夾存放的api.dart,wei調用的api配置文件
  • models文件存放的實體層
  • screen文件夾存放的頁面view層
  • tabs存放的底部切換文件夾層
  • widgets存放的組件,包含視頻播放組件player.dart以及左右等描述組件

功能介紹

 

主要的依賴組件,請使用國內鏡像下載,切記切記!!!!

  flutter:
    sdk: flutter
  flutter_svg: ^0.17.4

  # The following adds the Cupertino Icons font to your application.
  # Use with the CupertinoIcons class for iOS style icons.
  cupertino_icons: ^0.1.3
  cached_network_image: ^2.2.0
  json_annotation: ^3.0.1
  font_awesome_flutter: ^8.8.1
  http: ^0.12.0+4
  provider: ^4.0.4
  avatar_glow: any
  getflutter: ^1.0.11
  flutter_money_formatter: ^0.8.3
  video_player: ^0.10.8+1
  dio: ^3.0.9
  dio_cookie_manager: ^1.0.0

 

包含字體文件,主要為抖音自帶的字體文件

import 'package:flutter/widgets.dart';

class DouyinIcons {
  DouyinIcons._();

  static const _kFontFam = 'DouyinIcons';
  static const IconData chat_bubble =
      const IconData(0xe808, fontFamily: _kFontFam);
  static const IconData create = const IconData(0xe809, fontFamily: _kFontFam);
  static const IconData heart = const IconData(0xe80a, fontFamily: _kFontFam);
  static const IconData home = const IconData(0xe80b, fontFamily: _kFontFam);
  static const IconData messages =
      const IconData(0xe80c, fontFamily: _kFontFam);
  static const IconData profile = const IconData(0xe80d, fontFamily: _kFontFam);
  static const IconData reply = const IconData(0xe80e, fontFamily: _kFontFam);
  static const IconData search = const IconData(0xe80f, fontFamily: _kFontFam);
}

 

此次採用Flutter開發安卓、IOS等 app確實方便,主要為將tiktok的數據使用http下載下來.

import 'package:http/http.dart' as http;

class RequestController {
  static String host = "https://www.tiktok.com/";
  String url = host +
      "/share/item/list?secUid=&id=&type=5&count=30&minCursor=0&maxCursor=0&shareUid=&lang=en&_signature=pKb.ogAgEB9ImoSQahoqJKSm.rAAPox";

  Future<String> getCookie() async {
    try {
      var response = await http.get(host + "/share/item/");
      return response.headers["set-cookie"];
    } catch (e) {
      return "error";
    }
  }

  

Model層

主要為實體層,解析json後綁定數據以及傳遞數據

class Tiktok {
  int statueCode;
  Body body;
  Object errMsg;

  Tiktok({this.statueCode, this.body, this.errMsg});

  Tiktok.fromJson(Map<String, dynamic> json) {
    statueCode = json['statusCode'];
    body = json['body'] != null ? new Body.fromJson(json['body']) : null;
    errMsg = json['errMsg'];
  }

  Map<String, dynamic> toJson() {
    final Map<String, dynamic> data = new Map<String, dynamic>();
    data['statusCode'] = this.statueCode;
    if (this.body != null) {
      data['body'] = this.body.toJson();
    }
    data['errMsg'] = this.errMsg;
    return data;
  }
}

 

視圖層

另外屏幕層主要包含三個,homescreen,trendingscreen,以及顯示videoscreen

import 'package:flutter/material.dart';
import 'package:flutter_app/Screens/trendingScreen.dart';
import 'package:flutter_app/widgets/bottom_toolbar.dart';

class Home extends StatefulWidget {
  @override
  HomeState createState() => HomeState();
}

class HomeState extends State<Home> {
  int currentIndex = 0;
  PageController pageController;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: PageView(
        controller: pageController,
        children: <Widget>[
          Trending(),
        ],
        onPageChanged: (int index) {
          setState(() {
            currentIndex = index;
          });
        },
      ),
      bottomNavigationBar: bottomItems(currentIndex, pageController),
    );
  }
}

  

Tending層,主要包含讀取抖音的api,將api轉化成實體對象,綁定數據到videoscreen頁面

import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';
import 'package:getflutter/getflutter.dart';
import 'package:flutter_app/config/api.dart';
import 'package:flutter_app/models/Tiktok.dart';
import 'package:http/http.dart' as http;
import 'package:flutter_app/Screens/videoScreen.dart';

class Trending extends StatefulWidget {
  _TrendingState createState() => _TrendingState();
}

class _TrendingState extends State<Trending> {
  PageController pageController;
  BuildContext context;
  RequestController api = RequestController();
  List<Widget> videos = [];

  getTrending() async {
    var cookies = await api.getCookie();
    api.setCookie(cookies);
    try {
      var response = await http.get(
        api.url,
        headers: api.headers,
      );
      Tiktok tiktok = Tiktok.fromJson(jsonDecode(response.body));
      tiktok.body.itemListData.forEach(
        (item) {
          setState(() {
            videos.add(VideoItem(data: item));
          });
        },
      );
    } catch (ex) {
      SimpleDialog(
        title: Text('Hot videos list is empty'),
      );
      print(ex);
    }
  }

  @override
  void initState() {
    super.initState();
    getTrending();
  }

  @override
  Widget build(BuildContext context) {
    context = context;
    return PageView(
      scrollDirection: Axis.vertical,
      controller: pageController,
      children: videos.length == 0
          ? <Widget>[
              Container(
                color: Colors.black,
                child: Center(
                  child: GFLoader(
                    type: GFLoaderType.circle,
                    loaderColorOne: Colors.blueAccent,
                    loaderColorTwo: Colors.white,
                    loaderColorThree: Colors.pink,
                  ),
                ),
              )
            ]
          : videos,
    );
  }
}

  

VideoScreen主要為綁定數據. 展示抖音的視頻

import 'package:flutter/material.dart';
import 'package:flutter_app/models/Tiktok.dart';
import 'package:flutter_app/widgets/video_description.dart';
import 'package:flutter_app/widgets/actions_toolbar.dart';
import 'package:flutter_app/widgets/player.dart';

class VideoItem extends StatelessWidget {
  final ItemListData data;
  const VideoItem({@required this.data});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Stack(
        children: <Widget>[
          DouyinVideoPlayer(
            url: data.itemInfos.video.urls[0],
          ),
          title(),
          VideoDescription(
            description: data.itemInfos.text,
            musicName: data.musicInfos.musicName,
            authorName: data.musicInfos.authorName,
            userName: data.authorInfos.uniqueId,
          ),
          ActionsToolbar(
            comments: data.itemInfos.commentCount.toString(),
            userImg: data.authorInfos.covers[0],
            favorite: data.itemInfos.diggCount,
            coverImg: data.musicInfos.covers[0],
          ),
        ],
      ),
    );
  }

  Widget title() => Align(
        alignment: Alignment.topCenter,
        child: Padding(
          padding: EdgeInsets.symmetric(vertical: 28.0),
          child: Text(
            "Trending | For You",
            style: TextStyle(color: Colors.white, fontSize: 19.0),
          ),
        ),
      );
}

  

此次開發主要時間用在搭建Flutter環境上,切記使用國內鏡像,另外調式需要配合代理即可。

其他待完成的包含底部的導航頁面,打算花兩天時間把剩餘的完成.

 

 

 

各位感興趣的可以到我的github上點一下star.  留言可以教你們開發以及搭建dart環境.  地址:https://github.com/WangCharlie/douyin

 

感興趣的各位留言哈. 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用編輯器:Typora 下載官網:https://www.typora.io/ 學習教程:https://www.markdown.xyz/ 1、代碼塊 (1)源代碼模式 (2)菜單欄設置 菜單欄——【段落】—— 【代碼塊】 可自行選擇代碼語言 (3)快捷方式 英文輸入法狀態下,點擊三次 鍵盤數字 ...
  • 單頁面應用 概念 什麼是單頁應用呢?單頁應用的全稱是 single-page application,簡稱 SPA,它是一種網站應用的模型,它可以動態重寫當前的頁面來與用戶交互,而不需要重新載入整個頁面。單頁應用的流暢性讓 Web 應用更像桌面端或 Native 應用了。相對於傳統的 Web 應用, ...
  • 解決方法: $('#sub').unbind('click').click(function () { ... }); 每次綁定前先取消上次的綁定。 ...
  • 作者: MarkLin 學習目標: 1. 原生 node 封裝 2. 中間件 3. 路由 Koa 原理 一個 nodejs 的入門級 http 服務代碼如下, koa 的目標是更簡單化、流程化、模塊化的方式實現回調,我們希望可以參照 koa 用如下方式來實現代碼: 所以我們需要創建一個 文件,該文件 ...
  • 仿阿裡雲的錯誤提示 dialog - 您當前的會話已超時,請重新登錄。 ...
  • 輸出Map 申請單號<span>[[${listMain.REQ_CODE}]]</span> 輸出List<Map> <tr th:each="listD, listDStat : ${listDetail}"> <td th:text="${listDStat.count}"></td> <td ...
  • 使用 akka 實現,服務註冊、發現、心跳 消息類: package org.examplecase class RegisterWorkerInfo(id: String, cpu: Int, ram: Int);case class WorkerInfo(val id: String, val ...
  • 3.字元型 字元型常見的方法如下所示: capitalize():字元串第一個英文單詞首字母大寫 title():如字元串有多個英文單詞,則每個單詞首字母大寫 split():對字元串指定的分隔符進行拆分,預設為空格符 find():返回匹配到的字元第一次出現的位置索引,找不到返回 1 replac ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...