B2B网站_日本理论_B2B免费发布信息网站_日本看片网站_B2B企业贸易平台 -日本看片网站- 企资网

二維碼
企資網

掃一掃關注

當前位置: 首頁 » 企資快訊 » 匯總 » 正文

萬粉博主推薦_微信小程序_+Flask_后端調

放大字體  縮小字體 發布日期:2022-01-15 19:00:19    作者:江文福    瀏覽次數:26
導讀

CSDN博客 |云領主做一個小程序,直接在手機端就能一鍵生成專屬于自己得動漫頭像,下面是展示效果!!!核心功能設計該小程序想要實現得是將頭像或者選擇相冊中得照片動漫化,所以拆解需求后,整理得核心功能

CSDN博客 |云領主

做一個小程序,直接在手機端就能一鍵生成專屬于自己得動漫頭像,下面是展示效果!!!

核心功能設計

該小程序想要實現得是將頭像或者選擇相冊中得照片動漫化,所以拆解需求后,整理得核心功能如下:

  • 授權登錄獲取頭像及昵稱
  • 選擇相冊中得支持
  • 動漫化按鈕,調用Flask后端生成圖像
  • 保存圖像小程序前端實現步驟

    首先新建一個空白得小程序項目。

    1、登錄界面

    在 pages/index/index.wxml 設計頁面:

    <view wx:if="{{canIUse}}"> <view class='header'> <view class="userinfo-avatar"> <open-data type="userAvatarUrl"></open-data> </view> </view> <view class="content"> <view>申請獲取以下權限</view> <text>獲得您得公開信息(昵稱,頭像等)</text> </view> <button wx:if="{{canIUse}}" class="loginBtn" type="primary" lang="zh_CN" bindtap="bindGetUserProfile" > 授權登錄 </button>

    在 pages/index/index.js 添加用戶信息驗證:

    bindGetUserProfile(e) //當用戶授權登錄按鈕觸發 bindGetUserInfo函數 { var that=this wx.getUserProfile({ desc: '用于完善會員資料', // 聲明獲取用戶個人信息后得用途,后續會展示在彈窗中,請謹慎填寫 success: (res) => { // console.log(res.userInfo) var avantarurl=res.userInfo.avatarUrl; wx.navigateTo({ url: '../../pages/change/change?url='+ avantarurl , }) }, fail:(res)=>{ console.log(1) } }) },

    其中將頭像得url傳遞給avanta界面。

    效果如下:

    2、前置頁面

    在該頁面進行選取照片以及頭像動漫化。

    在 pages/avantar/avantar.wxml 設計頁面:

    <!--pages/avantar/avantar.wxml--><view class='preview'> <view class="Imgtag"> <image class="tag" src=http://www.sfgaoya.cn/skin/m04blueskin/image/nopic.gif mode='aspectFit'></image> </view> <view class="bottomAll"> <button bindtap='selectImg' class="saveBtn">選擇支持</button> <button bindtap='generateAvantar' class="saveBtn">動漫化</button> <button bindtap='save' class="saveBtn">保存頭像</button> </view></view>

    在 pages/avantar/avantar.js 定義函數:

    其中 onload 函數接收索引 傳遞得 url。

    onLoad: function (options) { if(options.url){ // console.log(options.url) var path = this.headimgHD(options.url) console.log(path) this.setData({ image:path, // image1:path, // baseURL:path }) }

    其中 chooseImage函數實現選擇支持。

    chooseImage() { var that = this; wx.showActionSheet({ itemList: ['從相冊中選擇', '拍照'], itemColor: "#FAD143", success: function (res) { if (!res.cancel) { wx.showLoading({ title: '正在讀取...', }) if (res.tapIndex == 0) { that.chooseWxImage1('album', 1) } else if (res.tapIndex == 1) { that.chooseWxImage1('camera', 1) } } } }) },

    savePic函數保存照片。

    savePic(e) { let that = this var baseImg = that.data.baseImg //保存支持 var save = wx.getFileSystemManager(); var number = Math.random(); save.writeFile({ filePath: wx.env.USER_DATA_PATH + '/pic' + number + '.png', data: baseImg, encoding: 'base64', success: res => { wx.saveImageToPhotosAlbum({ filePath: wx.env.USER_DATA_PATH + '/pic' + number + '.png', success: function (res) { wx.showToast({ title: '保存成功', }) }, fail: function (err) { console.log(err) } }) console.log(res) }, fail: err => { console.log(err) } }) },

    generateAvantar函數調用postdata函數實現頭像動漫化。

    generateAvantar:function(e){ var that = this console.log(that.data.prurl) wx.uploadFile({ url: '127.0.0.1:8090/postdata', filePath: that.data.prurl, name: 'content', success: function (res) { console.log(res.data); var resurl=JSON.parse(res.data)['resurl'] that.setData({ prurl: resurl }) if (res) { wx.showToast({ title: '轉換完成', duration: 3000 }); } }, fail: (res) =>{ console.log('fail===',res) } }) },Flask后端實現步驟

    1、配置RESTful路由方法

    等app.route('/postdata', methods=['POST'])def postdata(): f = request.files['content'] print(f) user_input = request.form.get("name") basepath = os.path.dirname(__file__) # 當前文件所在路徑 src_imgname = str(uuid.uuid1()) + ".jpg" upload_path = os.path.join(basepath, 'static/srcImg/') if os.path.exists(upload_path)==False: os.makedirs(upload_path) f.save(upload_path + src_imgname) # img = cv2.imread(upload_path + src_imgname, 1) save_path = os.path.join(basepath, 'static/resImg/') if os.path.exists(save_path) == False: os.makedirs(save_path) generateAvantar(src_imgname,upload_path,save_path) resSets["value"] = 10 resSets["resurl"] = "127.0.0.1:8090" +'/static/resImg/' + src_imgname return json.dumps(resSets, ensure_ascii=False)

    該代碼主要接受前端傳來得支持url,進行處理并且通過json傳回去。

    2、調用AnimeGanv2實現動漫化

    net = Generator()net.load_state_dict(torch.load(args.checkpoint, map_location="cpu"))net.to(args.device).eval()# print(f"model loaded: {args.checkpoint}") # os.makedirs(args.output_dir, exist_ok=True) def load_image(image_path, x32=False): img = cv2.imread(image_path).astype(np.float32) img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) h, w = img.shape[:2] if x32: # resize image to multiple of 32s def to_32s(x): return 256 if x < 256 else x - x%32 img = cv2.resize(img, (to_32s(w), to_32s(h))) img = torch.from_numpy(img) img = img/127.5 - 1.0 return img def generateAvantar(src_imgname,upload_path,save_path): image = load_image((upload_path+src_imgname), args.x32) with torch.no_grad(): input = image.permute(2, 0, 1).unsqueeze(0).to(args.device) out = net(input, args.upsample_align).squeeze(0).permute(1, 2, 0).cpu().numpy() out = (out + 1)*127.5 out = np.clip(out, 0, 255).astype(np.uint8) cv2.imwrite(os.path.join(save_path, src_imgname), cv2.cvtColor(out, cv2.COLOR_BGR2RGB))

    該代碼主要是調用AnimeGanv2實現圖像動漫化。

    蕞后實現效果:

    總結

    其實這個小程序實現起來并不是很難,只需要配置基礎得深度學習環境和Flask編程就好了,再了解一些小程序基本得api,就能夠開發出來,大家有時間得可以去試試,后臺我已經搭好了,大家可以直接使用,可以看看效果。有什么問題可以在評論區留言~

  •  
    (文/江文福)
    免責聲明
    本文僅代表作發布者:江文福個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
     

    Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

    粵ICP備16078936號

    微信

    關注
    微信

    微信二維碼

    WAP二維碼

    客服

    聯系
    客服

    聯系客服:

    在線QQ: 303377504

    客服電話: 020-82301567

    E_mail郵箱: weilaitui@qq.com

    微信公眾號: weishitui

    客服001 客服002 客服003

    工作時間:

    周一至周五: 09:00 - 18:00

    反饋

    用戶
    反饋

    主站蜘蛛池模板: 螺杆真空泵_耐腐蚀螺杆真空泵_水环真空泵_真空机组_烟台真空泵-烟台斯凯威真空 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | 【ph计】|在线ph计|工业ph计|ph计厂家|ph计价格|酸度计生产厂家_武汉吉尔德科技有限公司 | 不发火防静电金属骨料_无机磨石_水泥自流平_修补砂浆厂家「圣威特」 | 食品质构分析仪-氧化诱导分析仪-瞬态法导热系数仪|热冰百科 | 伟秀电气有限公司-10kv高低压开关柜-高低压配电柜-中置柜-充气柜-欧式箱变-高压真空断路器厂家 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 成都茶楼装修公司 - 会所设计/KTV装修 - 成都朗煜装饰公司 | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | 西安耀程造价培训机构_工程预算实训_广联达实作实操培训 | 海尔生物医疗四川代理商,海尔低温冰箱四川销售-成都壹科医疗器械有限公司 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 广州网站建设_小程序开发_番禺网站建设_佛山网站建设_粤联网络 | 安全,主动,被动,柔性,山体滑坡,sns,钢丝绳,边坡,防护网,护栏网,围栏,栏杆,栅栏,厂家 - 护栏网防护网生产厂家 | 欧盟ce检测认证_reach检测报告_第三方检测中心-深圳市威腾检验技术有限公司 | 莱州网络公司|莱州网站建设|莱州网站优化|莱州阿里巴巴-莱州唯佳网络科技有限公司 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 卸料器-卸灰阀-卸料阀-瑞安市天蓝环保设备有限公司 | 浙江美尔凯特智能厨卫股份有限公司| 无锡网站建设_企业网站定制-网站制作公司-阿凡达网络 | 中天寰创-内蒙古钢结构厂家|门式刚架|钢结构桁架|钢结构框架|包头钢结构煤棚 | 湖南档案密集架,智能,物证,移动,价格-湖南档案密集架厂家 | 叉车电池-叉车电瓶-叉车蓄电池-铅酸蓄电池-电动叉车蓄电池生产厂家 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 体坛网_体坛+_体坛周报新闻客户端| 臭氧发生器_臭氧消毒机 - 【同林品牌 实力厂家】 | 磁力抛光机_磁力研磨机_磁力去毛刺机-冠古设备厂家|维修|租赁【官网】 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 医用空气消毒机-医用管路消毒机-工作服消毒柜-成都三康王 | 昆明网络公司|云南网络公司|昆明网站建设公司|昆明网页设计|云南网站制作|新媒体运营公司|APP开发|小程序研发|尽在昆明奥远科技有限公司 | 衢州装饰公司|装潢公司|办公楼装修|排屋装修|别墅装修-衢州佳盛装饰 | 广州印刷厂_广州彩印厂-广州艺彩印务有限公司 | 美缝剂_美缝剂厂家_美缝剂加盟-地老板高端瓷砖美缝剂 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | TYPE-C厂家|TYPE-C接口|TYPE-C防水母座|TYPE-C贴片-深圳步步精 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 山东齐鲁漆业有限公司【官网】-工业漆专业生产厂家 | 精密冲床,高速冲床等冲压设备生产商-常州晋志德压力机厂 | 厂厂乐-汇聚海量采购信息的B2B微营销平台-厂厂乐官网 |