曲阜房产网

当前位置: 首页 >市场

女儿问爸我长得好看不这个父亲的回答亮了

来源: 作者: 2019-11-10 02:02:46

掘金首页动态话题小册活动搜索掘金搜索写文章登录注册_Hahn_2019年01月08日浏览 566《蜘蛛侠:平行宇宙》的视觉解析与滤镜实现早在4年前,索尼想要制作全新风格的“蜘蛛侠”电影这1消息被泄漏时,一个显眼的辞汇便被反复提及——“rejuvenate”,译为“使其恢复年轻”。当时,除去《蜘蛛侠:返校日》之外,由索尼出品的《蜘蛛侠》真人电影已有五部之多(托比·马圭尔主演《蜘蛛侠》三部曲,以及安德鲁·加菲尔德主演的两部《超凡蜘蛛侠》)。索尼高层希望以一部动画电影来让这个系列重新恢复活力。而为了拍摄这部动画电影,索尼找到了当时因《天降美食》系列和《乐高大电影》等作品在业界小有名气的导演搭档——菲尔·罗德和克里斯托弗·米勒。有着天马行空的创意和各种鬼才想法的这两位导演提出的要求则是:希望这部动画让观众感到“就像走进了漫画里一般”。他们同时也为能够在这部电影中使用到真人电影没法达成的叙事手段而感到兴奋。第一次看到《蜘蛛侠:平行宇宙》这部电影时,就被其中的十足创新的视觉动态效果所冷艳,跟以往 3D 动画寻求自然流畅截然相反,《蜘蛛侠:平行宇宙》反而在往漫画观感体验靠拢,让 3D 动画 2D 化,而且不是单纯的 2D 化。正如在一篇文章里看到的评论:混搭上各类平行宇宙间不同的漫画风格,保留下了对话框、漫画分格、字幕殊效,还特别加强了手绘涂鸦的部分,并刻意打造出这部份的「稚拙感」。当这些再加上奇异到炸裂的分镜,足以让人看得目不暇接。接下来我们简单的解析下这电影的亮点:一、视觉表达的创新点1.一拍二摹拟 2D 动画在进入正题故事没多久,相信看惯了 3D 动画的大家都会有种稍稍不适应的感觉...「这电影是不是是有些卡?」没错,它确切就是卡。这是电影第一个让人感觉有些「异常」的地方,却也是电影最特别的地方。仔细看你可以发现只有人物角色是有着卡顿感的,而它们的周围环境却很流畅,形成了一种奥妙的对比。关于这一点,在知乎中有网友给我们作出了解答:电影一般采取的是 24 帧每秒的制式,也就是说如果是手绘 2D 动画片,需要每秒连续画 24 张画以使画面中动画流畅,这也就是动画中俗称的1拍1。但是有人发现我一样的动作只画第 1,3,5,7....合计总共只画 12 帧,然后把每帧停留 2 倍时间,观众并不会明显发觉,而动画师却形来表现运动模糊的方式,但却不是那样做的。最后,采取了一些解决方案。Imageworks 的线条工具允许艺术家绘制一样连接形状的运动线,也有从相机快门启发的技术。例如,迪米安说,快速相机平底镜上的背景,无论是合成还是借助殊效,都会被涂上很大的污点和划线,但却会以一种非常块状的插图方式出现。我们基本上尽可能避免任何看起来像是平滑的渐变或因为运动模糊而变得模糊的东西。相反,这是一种非常图形化的处理。后面我们可以看到,电影里通过叠影(相机快门启发的方式)、场景的错位、速度线等方式来补充画面的动感,并保证了电影本身的风格语言。4.色散/高光溢色实际上我们可以从电影画面里看到一般产生于比较老化或者早期的镜头拍摄的照片质感(高光溢色),还有一些镜头色散的效果,这其实也是电影工作室有意为之。导演 peter Ramsey 在接受采访时是这么对电影画面解释的:某种意义上说,你根本不用花费精力去注意什么,因为我们做的就是还原漫画,而我们在看漫画的时候会发现,有时候漫画里都有毛病,有时候印刷不好,色彩都涂到了线条之外,所以看起来就觉得模糊不清。而且这和真人电影是相通的,比如有时镜头中一些东西是没有对上焦有些模糊,这样观众才会集中注意力在重要而清晰的画面上。色散/高光溢色的效果在这里就是起到虚化和模糊的作用。如导演提到的印刷不好的情况,在 20 世纪初中期的印刷行业经常出现,当时的 CMYK 4色印刷会由于有对版的误差出现导致喷色错版,这样的错版在后面发展中也成为了一种风格化的处理,导演注意到这点,并应用到了电影中,这既把漫画的质感还原得更到位,让观者产生共鸣同时也利用这样的错位生成一种视觉景深感,使得电影的层次更强,解决了向 2D 靠近后在电影显得平的问题。这部电影在视觉表达上有很多的突破,创作团队很大胆得把多种风格不一的人物混合在一起,使得平行宇宙的概念合理化,并通过平面漫画的方式把视觉语言和全部电影的题的结合到达了高度的统一。全部电影泄漏出一种处处不稳定的矛盾感,创作团队没有把这类矛盾消弱,而是把他们都展现了出来,这样的碰撞感受让人不能不佩服他们对整体的把控和自信。2、视觉效果与滤镜实现电影从片头就迫不及待的展现出了它在表现形式上的创新,但仔细视察你会发现里面用到的效果并不是从0到1的创新,只不过索尼的动画团队把这些视觉元素运用的淋漓尽致。由于工作中触及了短视频滤镜和转场的 OpenGL Shader 代码编写,所以在2刷电影的时候特别留意了电影里的特效,并思考有哪些是可以通过 Shader 来实现的。当然了,电影里的效果是动画设计师反复调整和多重加工出来的,绝非一段代码就能完美模拟。这里仅仅是从技术角度去探讨电影里一些效果在 Shader 代码层面的可行性。1. HalfTone 半调滤镜电影高度还原了漫画应有的观赏体验,在画面的渲染上使用了 Ben-Day dot (本戴点)让我们感受到了阅读纸质漫画书的质感。Ben-Day dot 与 HalfTone 的不同之处在于 Ben-Day dot 在特定区域中的大小和散布总是相同,而 HalfTone 能根据图象的颜色细节呈现大小和渐变不一定点。我们可以用 HalfTone 半调滤镜去生成差不多的质感。下面截取几张截图可见一斑:科普下 Ben-Day dot (本戴点),全名是「本戴点状制版法」,以插图画家和印刷商 Benjamin Henry Day Jr.(19 世纪出版商 Benjamin Henry Day 的儿子)命名,在 1879 年被发明的印刷制版技术。它根据色彩和视错觉原理,通过小彩色点的间隔疏密、大小或重叠来生成所需要的效果。例如,洋红色圆点间隔比较宽就会形成粉红色。 20 世纪 50 年代和 60 年代的彩色漫画书很受欢迎,但是全彩漫画的本钱很高的故障效果。索尼工作室在制作故障效果的时候使用了手绘图案+多层效果融合的方式来出现,当然了,代码想要摹拟这样的效果其实不容易,如果可以找到一张适合的遮罩图也许可以大致模拟出来。不过这里只单纯展现常规的基于图像本身的故障效果(代码通过基于时间来做像素和色彩通道偏移来模拟故障效果):precision highp float; uniform sampler2D inputImageTexture;uniform sampler2D inputImageTexture2;varying vec2 textureCoordinate;uniform float time;float amount gl_FragColor = vec4(finalColor 1.0);}复制代码同样的,通过 Demo 右上角的滤镜开关可以看到前后效果: Demo23. RGB Shift/Split RGB 分离仔细可以发现,上面第二个 Glitch 效果一样用到了 RGB 色彩分离,在电影中出现了大量的这样的效果,把色彩变化应用到极致,有些魔性有些虚幻。Shader 实现起来会相比上面两个滤镜更简单一下,通过对图象的 RGB 三个色采做拆分和坐标偏移就可以实现:precision highp float;uniform sampler2D inputImageTexture;varying vec2 textureCoordinate;uniform float time;float amount = 0.01;float angle = 0.;void main() { vec2 offset = amount * vec2(cos(time*.001) sin(time*.001)); vec4 cr = texture2D(inputImageTexture textureCoordinate + offset); vec4 cga = texture2D(inputImageTexture textureCoordinate); vec4 cb = texture2D(inputImageTexture textureCoordinate - offset); gl_FragColor = vec4(cr.r cga.g cb.b cga.a);}复制代码下面两张图片比较前后效果:一样的,通过 Demo 右上角的滤镜开关可以看到前后效果:Demo3最后,这部电影可以说的太多太多,有太多让人觉得惊艳的点,没办法一一都提到,我们只能从视觉方面和实现的可能性简单得聊聊,欢迎补充。在快写完文章的时候,想起开头 Sony 说到的「rejuvenate(使其恢复年轻)」。我们可以感觉到这个电影从故事和风格无不充斥着现在年轻人会喜欢的元素,可以说这是一部很酷的作品,但是在看到了很多资料后我们不由有一些感慨,这些很酷炫的效果和元素风格其实在上个世纪就已存在且有着很深的历史痕迹,从某种意义上,与其说是更年轻的体现,感觉倒不如说是这是一种复古了。由此我们也延伸出了一些问题:有人说风格是个轮回,这么一看,所谓的「更年轻的风格」或「过气的风格」都像是个伪命题。也就是说,是否是其实不存在什么年轻或过时的风格,只有时间时间久了,看腻了的风格?又或说,是不是由于技术的创新才让产品(电影或其它)变得年轻了,和风格,实际没太大关系?感觉挺有意思,可以想一想。相关链接:www.gcores.com/articles/10…deadline.com/2018/12/son…www.zhihu.com/question/29…www.douban.com/review/9831…en.wikipedia.org/wiki/Ben-Da…www.bilibili.com/video/av768…wapbaike.baidu.com/tashuo/brow…www.docin.com/p-92574055.…关注下面的标签,发现更多类似文章OpenGL安装掘金浏览器插件打开新标签页发现好内容,掘金、GitHub、Dribbble、productHunt 等站点内容轻松获得。快来安装掘金浏览器插件获得高质量内容吧!评论Lanslord膜拜大佬2小时前F1ashGp6663小时前相关推荐专栏_Hahn_17小时前OpenGL《蜘蛛侠:平行宇宙》的视觉解析与滤镜实现182专栏Cang_Wang10天前C++OpenGL[OpenGL]未来视觉-MagicCamera3实用开源库164专栏熊皮皮1月前iOSJavaRust 移动端跨平台复杂图形渲染项目开发系列总结(目录) 2018.12.9227专栏KoonChaoSo1月前iOS程序员iOS推流器模块知识点浅谈总结244热专栏已禁用3月前前端Life of a pixel:前端代码如何通过浏览器演变为屏幕显示的像素1158专栏熊皮皮1月前iOSRustgfx-rs/hal跨平台图形抽象库使用介绍410专栏熊皮皮28天前OpenGL以OpenGL/ES视角介绍gfx-hal(Vulkan) Shader/program接口使用2热专栏闲鱼技术4月前iOS万万没想到——flutter这样外接纹理12312热专栏SimonLeeeeeeeee8月前AndroidAndroid新兴扫码框架:XCodeScanner(最近更新2018-08-17)44740专栏熊皮皮1月前iOSC++Rust图形库gfx-hal 逐帧渲染流程介绍62关于作者_Hahn_UI 工程师取得赞数240取得浏览数6398掘金小册基于 python 实现微信公众号爬虫新人价 ¥9.95¥19.9Git 原理详解及实用指南新人价 ¥14.95¥29.9新人专享好礼送你45元买小册立即领取相关文章写 Shader 转场的几点思考3611Shader 动画331WebGL Shader 环境搭建384Shader 高斯模糊(Gaussion Blur)220Shader 运动模糊(Motion Blur)223目录1、视觉表达的创新点1.一拍二摹拟 2D 动画2. 漫画手法还原3. 不用运动模糊4.色散/高光溢色二、视觉效果与滤镜实现1. HalfTone 半调滤镜2. Glitch 故障效果3. RGB Shift/Split RGB 分离掘金浏览器插件 - 下载插件,送你45元买小册掘金首页动态话题小册活动搜索掘金搜索写文章登录注册chokcoco2019年01月09日阅读 1733不可思议的纯 CSS 转动进度条效果问题先行,如何使用 CSS 实现下述滚动条效果?scrollbar就是顶部黄色的转动进度条,随着页面的转动进度而变化长短。在继续阅读下文之前,你可以先缓一缓。尝试思考一下上面的效果或动手尝试一下,不借助 JS ,能否巧妙的实现上述效果。OK,继续。这个效果是我在业务开发的进程中遇到的一个类似的小问题。其实即使让我借助 Javascript ,我的第一反应也是,感觉很麻烦啊。所以我一直在想,有没有可能只使用 CSS 完成这个效果呢?image分析需求第一眼看到这个效果,感觉这个跟随转动动画,仅靠 CSS 是不可能完成的,由于这里触及了页面滚动距离的计算。如果想只用 CSS 实现,只能另辟蹊径,使用一些讨巧的方法。好,下面就借助一些奇技淫巧,使用 CSS 一步一步完成这个效果。分析一下难点:如何得知用户当前转动页面的距离并且通知顶部进度条?正常分析应该是这样的,但是这就堕入了传统的思维。进度条就只是进度条,接收页面转动距离,改变宽度。如果页面转动和进度条是一个整体呢?实现需求不卖关子了,下面我们运用线性渐变来实现这个功能。假定我们的页面被包裹在 中,可以滚动的是全部 body,给它添加这样一个从左下到到右上角的线性渐变:body { background-image: linear-gradient(to right top #ffcc00 50% #eee 50%); background-repeat: no-repeat;}复制代码那么,我们可以得到一个这样的效果:scrollbar2Wow,黄色块的色采变化其实已经很能表达整体的进度了。其实到这里,聪明的同学应当已知道下面该怎样做了。我们运用一个伪元素,把多出来的部份遮住:body::after { content: \\; position: fixed; top: 5px; left: 0; bottom: 0; right: 0; background: #fff; z-index: -1;}复制代码为了方便演示,我把上面白色底改成了黑色透明底,:scrollbar3实际效果达成了这样:scrollbar4眼尖的同学可能会发现,这样以后,滑到底的时候,进度条并没有到底:image究其缘由,是由于 body 的线性渐变高度设置了全部 body 的大小,我们调整一下渐变的高度:body { background-image: linear-gradient(to right top #ffcc00 50% #eee 50%); background-size: 100% calc(100% - 100vh + 5px); background-repeat: no-repeat;}复制代码这里使用了 calc 进行了运算,减去了 100vh,也就是减去一个屏幕的高度,这样渐变刚好在滑动到底部的时候与右上角贴合。而 + 5px 则是转动进度条的高度,预留出 5px 的高度。再看看效果,完善:scrollbar至此,这个需求就完善实现拉,算是一个不错的小技能,完整的 Demo:Codepen Demo -- 使用线性渐变实现转动进度条image最后其实这只是非常牛逼的渐变非常小的一个技能。更多你想都想不到的有趣的 CSS 你可以来这里瞧瞧:CSS-Inspiration -- CSS灵感更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,延续更新,欢迎点个 star 定阅收藏。好了,本文到此结束,希望对你有帮助 :)如果还有甚么疑问或建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。关注下面的标签,发现更多类似文章CSS前端安装掘金浏览器插件打开新标签页发现好内容,掘金、GitHub、Dribbble、productHunt 等站点内容轻松获得。快来安装掘金浏览器插件获得高质量内容吧!评论godbmw前端 @ 腾讯已Star1分钟前 前端工程师秀18分钟前chenry优秀22分钟前阿卡林你们都没见过这个? http://youmightnotneedjs.com/网页链接30分钟前晟功在望本尊奇思妙想,秀儿31分钟前T_one进度条是个锯齿形的怎样破?36分钟前相干推荐热专栏chokcoco2小时前CSS不可思议的纯 CSS 滚动进度条效果10743热专栏亚古5小时前面试【面经】寒冬中的一年半前端跳槽20379专栏CRpER2小时前前端Visual Studio CodeVS Code 折腾记 - (15) 再来推荐一波大前端适用系列的插件(改善编码体验)454专栏Seymoe3小时前前端程序员24K 纯非科班前端的总结与展望 | 掘金年度征文1220专栏腾讯IVWEB团队6小时前前端安全使用 SRI 解决 CDN 劫持4415热慕晨同学21小时前前端大前端架构思考与选择18013专栏sunshine小小倩16小时前前端拥抱变化,无穷可能(D2 开场总结)461专栏邓李儿22小时前前端true || false && false2941热专栏木易杨说2天前JavaScript【进阶4-2期】Object.assign 原理及其实现30836ShanaMaid42分钟前TypeScript前端Archer-svgs: 动态加载svg并缓存的方案1关于作者chokcoco切图仔 @ Tencent联合编辑取得赞数6494取得阅读数100844掘金小册基于 python 实现微信公众号爬虫新人价 ¥9.95¥19.9Vue.js 组件精讲新人价 ¥14.95¥29.9新人专享好礼送你45元买小册立即领取相干文章不可思议的纯CSS导航栏下划线跟随效果114893滚动视差?CSS 不在话下104240奇异的选择器 :focus-within45841你所不知道的 CSS 阴影技能与细节43030妙用 scale 与 transfrom-origin,精准控制动画方向26218目录分析需求实现需求最后掘金浏览器插件 - 下载插件,送你45元买小册掘金首页动态话题小册活动搜索掘金搜索写文章登录注册roberthuang2019年01月08日浏览 3663mpvue+小程序云开发,纯前端实现婚礼邀请函目录前言准备工作项目结构介绍页面介绍云开发介绍总结前言感谢OnceLove提供的思路,借助他的小程序的界面UI风格,自己重新用mpvue实现了属于自己的婚礼邀请函,前前后后花了3天时间。在这之前本人是没想过要自己实现这样一个项目,缘由是后台那块是个麻烦事,所以当媳妇让我自己实现这个邀请函的时候,起初我是谢绝的。后面由于快要过年了,公司项目没有重大更新,趁着这段空闲时间,自己研究了下小程序自带的云开发,无需后台支持,前后端都可以自己来实现,下面我将逐一介绍本项目的实现过程!本小程序为婚礼正式使用的小程序(由于某些小伙伴的不文明行动,所以只能换一个小程序让大家体验),婚期将至,感兴趣的可以扫码体验本项目,沾沾喜气,欢迎大家体验,有甚么问题可以在本文给我留言源码地址:https://gitee.com/roberthuang123/wedding点击并拖拽以移动准备工作mpvue框架 mpvue官方文档小程序·云开发 小程序·云开发文档注意:使用mpvue前,首先你得先熟习vue框架的基本使用项目结构介绍点击并拖拽以移动common目录: 放一些公共资源,如jscssjsoncomponents目录:组件相干的.vue文件都放在这里pages目录:所有页面都放在这个目录utils目录:使用mpvue时自动生成,可疏忽app.json文件:{ \pages\: [ \pages/index/main\ \pages/photo/main\ \pages/map/main\ \pages/greet/main\ \pages/message/main\ ] \window\: { \backgroundTextStyle\: \light\ \navigationBarBackgroundColor\: \#fff\ \ \pagepath\: \pages/greet/main\ \iconpath\: \static/images/4-1.png\ \selectedIconpath\: \static/images/4-2.png\ \text\: \好友祝贺\ } { \pagepath\: \pages/message/main\ \iconpath\: \static/images/5-1.png\ \selectedIconpath\: \static/images/5-2.png\ \text\: \留言评论\ } ] } \requiredBackgroundModes\: [\audio\]}复制代码点击并拖拽以移动App.vue文件:本人主要是为了增加项目更新后的提示,所以在这个文件加了些相关内容,内容以下,复制代码点击并拖拽以移动main.js文件:import Vue from 'vue'import App from './App'Vue.config.productionTip = falseApp.mpType = 'app'wx.cloud.init({ env: '云开发环境ID'})const app = new Vue(App)app.$mount()复制代码点击并拖拽以移动functions目录:主要放一些云函数,这里不清楚云函数的文章后面会提及images目录:主要放一些静态资源图片页面介绍首页——邀请函首页侧重和大家讲解下背景音乐的实现方法const audioCtx = wx.createInnerAudioContext()首先,wx.createInnerAudioContext 接口获取实例接着,通过实例的相干方法来实现音乐的播放与暂停功能关于小程序音频相关文档具体代码如下:复制代码点击并拖拽以移动以上代码中使用到了云开发相干功能,文章后面会介绍,请大家稍安勿躁相册页——就一个轮播图,这里就不过量介绍地图页——这里侧重讲一下地图标签mapmap标签 关于map组件的使用文档这里讲一下标记点markersdata () { return { // qqSdk: '' markers: [{ iconpath: '../../static/images/nav.png' id: 0 latitude: 30.08059 longitude: 115.93027 width: 50 height: 50 }] } }复制代码点击并拖拽以移动复制代码点击并拖拽以移动祝愿页——也是云开发相关内容,后面会介绍留言页——也是云开发相关内容,后面会介绍云开发介绍小程序云开发文档project.config.json文件:\cloudfunctionRoot\: \static/functions/\复制代码点击并拖拽以移动进行云开发首先我们需要找到上面这个文件,在上面这个json文件中加上上面这句cloudfunctionRoot 用于指定存放云函数的目录app.json文件:\window\: { \backgroundTextStyle\: \light\ \navigationBarBackgroundColor\: \#移动接下来是操作数据库的相干示例:例:首页获得背景音乐资源getMusicUrl () { const that = this const db = wx.cloud.database() const music = db.collection('music') music.get().then(res => { let musicUrl = res.data[0].musicUrl audioCtx.src = musicUrl audioCtx.loop = true audioCtx.play() that.getList() })}复制代码点击并拖拽以移动例:首页获得轮播图数组getList () { const that = this const db = wx.cloud.database() const banner = db.collection('banner') banner.get().then(res => { that.list = res.data[0].bannerList })}复制代码点击并拖拽以移动例:祝愿页,用户送上祝愿存储用户复制代码点击并拖拽以移动进入祝愿页,首先我们需要取得送祝福的好友列表getUserList () { const that = this wx.cloud.callFunction({ name: 'use点击并拖拽以移动这是留言的评论,如图:总结在这里给大家讲授几点细节:云开发是免费的;数据库集合名首先必须要建立;云函数新建后一定要创建并安装依赖;如果担心有些评论不太友好希望有删除功能,可以给自己开放权限,在每条评论加一个删除按钮,仅自己使用的时候通过唯一的openid控制删除按钮为可见,其他人不可见,从而来管理留言列表;数据库建立集合后记得将权限放开,如下图:最后总结:除一些静态资源放在项目中,其他资源建议一律存储在云开发-存储管理中,这样的话,方便更换资源而不用再次提交等待小程序审核,更换后的资源可以立即生效;我知道大家都喜欢拿来就能直接看到一样效果的东西,本项目由于涉及到后台数据,不可能完全把本人的环境放出来给大家使用,建议真的要实现相干功能或类似项目的小火伴对比我的思路重新做一个属于自己的作品才最有意义。大概的功能就是这么多,希望可以帮助到大家,觉得写得不错的记得给作者点个赞,你们的支持是我不断更新的最大动力!关注下面的标签,发现更多类似文章小程序·云开发安装掘金浏览器插件打开新标签页发现好内容,掘金、GitHub、Dribbble、productHunt 等站点内容轻松获得。快来安装掘金浏览器插件取得高质量内容吧!评论上官羽心很棒的小程序2小时前fernandoxu代码会写,就差个未婚妻了。5小时前roberthuang(作者)前端开发关于字段相干的内容已补充,不清楚的结合源码查看8小时前FlyingAir前端回复 roberthuang(作者): 感谢!祝贺!7小时前_lemon小前端很棒棒8小时前重名了前端祝福祝贺8小时前程序圜_前端工程师 @ 中公教育留言区左上角有个小bug哦~点击那个显示一个小角的字体就可以输入文字进行留言17小时前相干推荐热专栏roberthuang1天前小程序·云开发mpvue+小程序云开发,纯前端实现婚礼邀请函12249专栏蚂蚁金服科技23小时前小程序·云开发支付宝工程师创造出了一个可以“拷贝”支付宝的神器1专栏李CHENGXI28天前微信小程序小程序·云开发1个开发如何撑起一个过亿用户的小程序405热专栏腾讯云加社区4月前小程序·云开发小程序·云开发 项目开发经验分享571专栏stupidWall1月前Node.js前端小程序云开发初体验233专栏netwjx曹宇2月前微信微信小程序小程序·云开发低级FAQ323专栏薄荷前端2月前前端微信小程序云开发初探202关于作者roberthuang前端开发取得赞数130获得浏览数3975掘金小册Vue.js 组件精讲新人价 ¥14.95¥29.9React 实战:设计模式和最好实践新人价 ¥14.95¥29.9新人专享好礼送你45元买小册立即领取相干文章支付宝工程师创造出了一个可以“拷贝”支付宝的神器101个开发如何撑起一个过亿用户的小程序405小程序·云开发 项目开发经验分享571小程序云开发初体验233目录前言准备工作项目结构介绍页面介绍云开发介绍总结掘金浏览器插件 - 下载插件,送你45元买小册掘金首页动态话题小册活动搜索掘金搜索写文章登录注册roberthuang2019年01月08日阅读 3663mpvue+小程序云开发,纯前端实现婚礼邀请函目录前言准备工作项目结构介绍页面介绍云开发介绍总结前言感谢OnceLove提供的思路,借助他的小程序的界面UI风格,自己重新用mpvue实现了属于自己的婚礼邀请函,前前后后花了3天时间。在这之前本人是没想过要自己实现这样一个项目,缘由是后台那块是个麻烦事,所以当媳妇让我自己实现这个邀请函的时候,起初我是谢绝的。后面由于快要过年了,公司项目没有重大更新,趁着这段空闲时间,自己研究了下小程序自带的云开发,无需后台支持,前后端都可以自己来实现,下面我将逐一介绍本项目的实现过程!本小程序为婚礼正式使用的小程序(由于某些小火伴的不文明行动,所以只能换一个小程序让大家体验),婚期将至,感兴趣的可以扫码体验本项目,沾沾喜气,欢迎大家体验,有什么问题可以在本文给我留言源码地址:https://gitee.com/roberthuang123/wedding点击并拖拽以移动准备工作mpvue框架 mpvue官方文档小程序·云开发 小程序·云开发文档注意:使用mpvue前,首先你得先熟悉vue框架的基本使用项目结构介绍点击并拖拽以移动common目录: 放一些公共资源,如jscssjsoncomponents目录:组件相干的.vue文件都放在这里pages目录:所有页面都放在这个目录utils目录:使用mpvue时自动生成,可忽视app.json文件:{ \pages\: [ \pages/index/main\ \pages/photo/main\ \pages/map/main\ \pages/greet/main\ \pages/message/main\ ] \window\: { \backgroundTextStyle\: \light\ \navigationBarBackgroundColor\: \#fff\ \ \pagepath\: \pages/greet/main\ \iconpath\: \static/images/4-1.png\ \selectedIconpath\: \static/images/4-2.png\ \text\: \好友祝愿\ } { \pagepath\: \pages/message/main\ \iconpath\: \static/images/5-1.png\ \selectedIconpath\: \static/images/5-2.png\ \text\: \留言评论\ } ] } \requiredBackgroundModes\: [\audio\]}复制代码点击并拖拽以移动App.vue文件:本人主要是为了增加项目更新后的提示,所以在这个文件加了些相关内容,内容如下,复制代码点击并拖拽以移动main.js文件:import Vue from 'vue'import App from './App'Vue.config.productionTip = falseApp.mpType = 'app'wx.cloud.init({ env: '云开发环境ID'})const app = new Vue(App)app.$mount()复制代码点击并拖拽以移动functions目录:主要放一些云函数,这里不清楚云函数的文章后面会提及images目录:主要放一些静态资源图片页面介绍首页——邀请函首页侧重和大家讲解下背景音乐的实现方法const audioCtx = wx.createInnerAudioContext()首先,wx.createInnerAudioContext 接口取得实例接着,通过实例的相干方法来实现音乐的播放与暂停功能关于小程序音频相干文档具体代码以下:复制代码点击并拖拽以移动以上代码中使用到了云开发相干功能,文章后面会介绍,请大家稍安勿躁相册页——就一个轮播图,这里就不过量介绍地图页——这里侧重讲一下地图标签mapmap标签 关于map组件的使用文档这里讲一下标记点markersdata () { return { // qqSdk: '' markers: [{ iconpath: '../../static/images/nav.png' id: 0 latitude: 30.08059 longitude: 115.93027 width: 50 height: 50 }] } }复制代码点击并拖拽以移动复制代码点击并拖拽以移动祝愿页——也是云开发相关内容,后面会介绍留言页——也是云开发相关内容,后面会介绍云开发介绍小程序云开发文档project.config.json文件:\cloudfunctionRoot\: \static/functions/\复制代码点击并拖拽以移动进行云开发首先我们需要找到上面这个文件,在上面这个json文件中加上上面这句cloudfunctionRoot 用于指定寄存云函数的目录app.json文件:\window\: { \backgroundTextStyle\: \light\ \navigationBarBackgroundColor\: \#移动接下来是操作数据库的相关示例:例:首页获得背景音乐资源getMusicUrl () { const that = this const db = wx.cloud.database() const music = db.collection('music') music.get().then(res => { let musicUrl = res.data[0].musicUrl audioCtx.src = musicUrl audioCtx.loop = true audioCtx.play() that.getList() })}复制代码点击并拖拽以移动例:首页获得轮播图数组getList () { const that = this const db = wx.cloud.database() const banner = db.collection('banner') banner.get().then(res => { that.list = res.data[0].bannerList })}复制代码点击并拖拽以移动例:祝贺页,用户送上祝愿存储用户复制代码点击并拖拽以移动进入祝愿页,首先我们需要获取送祝愿的好友列表getUserList () { const that = this wx.cloud.callFunction({ name: 'use点击并拖拽以移动这是留言的评论,如图:总结在这里给大家讲授几点细节:云开发是免费的;数据库集合名首先必须要建立;云函数新建后一定要创建并安装依赖;如果担心有些评论不太友好希望有删除功能,可以给自己开放权限,在每条评论加一个删除按钮,仅自己使用的时候通过唯一的openid控制删除按钮为可见,其他人不可见,从而来管理留言列表;数据库建立集合后记得将权限放开,如下图:最后总结:除一些静态资源放在项目中,其他资源建议一概存储在云开发-存储管理中,这样的话,方便更换资源而不用再次提交等待小程序审核,更换后的资源可以立即生效;我知道大家都喜欢拿来就能直接看到一样效果的东西,本项目因为涉及到后台数据,不可能完全把本人的环境放出来给大家使用,建议真的要实现相干功能或类似项目的小伙伴对比我的思路重新做一个属于自己的作品才最有意义。大概的功能就是这么多,希望可以帮助到大家,觉得写得不错的记得给作者点个赞,你们的支持是我不断更新的最大动力!关注下面的标签,发现更多类似文章小程序·云开发安装掘金浏览器插件打开新标签页发现好内容,掘金、GitHub、Dribbble、productHunt 等站点内容轻松获取。快来安装掘金浏览器插件获得高质量内容吧!评论上官羽心很棒的小程序2小时前fernandoxu代码会写,就差个未婚妻了。5小时前roberthuang(作者)前端开发关于字段相干的内容已经补充,不清楚的结合源码查看8小时前FlyingAir前端回复 roberthuang(作者): 感谢!祝贺!7小时前_lemon小前端很棒棒8小时前重名了前端祝贺祝愿8小时前程序圜_前端工程师 @ 中公教育留言区左上角有个小bug哦~点击那个显示一个小角的字体就可以输入文字进行留言17小时前相关推荐热专栏roberthuang1天前小程序·云开发mpvue+小程序云开发,纯前端实现婚礼邀请函12249专栏蚂蚁金服科技23小时前小程序·云开发支付宝工程师创造出了一个可以“拷贝”支付宝的神器1专栏李CHENGXI28天前微信小程序小程序·云开发1个开发如何撑起一个过亿用户的小程序405热专栏腾讯云加社区4月前小程序·云开发小程序·云开发 项目开发经验分享571专栏stupidWall1月前Node.js前端小程序云开发初体验233专栏netwjx曹宇2月前微信微信小程序小程序·云开发低级FAQ323专栏薄荷前端2月前前端微信小程序云开发初探202关于作者roberthuang前端开发取得赞数130取得阅读数3975掘金小册Vue.js 组件精讲新人价 ¥14.95¥29.9React 实战:设计模式和最好实践新人价 ¥14.95¥29.9新人专享好礼送你45元买小册立即领取相干文章支付宝工程师创造出了一个可以“拷贝”支付宝的神器101个开发如何撑起一个过亿用户的小程序405小程序·云开发 项目开发经验分享571小程序云开发初体验233目录前言准备工作项目结构介绍页面介绍云开发介绍总结掘金浏览器插件 - 下载插件,送你45元买小册

呼叫新郎

呼叫新娘

呼唤新郎

呼唤新娘

关注小淘妈

每天读点有用、有趣、有态度的育儿干货

女儿问爸我长得好看不这个父亲的回答亮了

如果在该努力的年龄去寻求美貌,生活总会让你付出惨痛的代价!

——淘妈

父亲有个同事叫李叔叔,他女儿的年纪和我差不多。

李叔叔的爱人长得非常漂亮,是一个天生的美人胚子,她的女儿尽得她遗传,长得非常像她,从小就天生丽质,混在孩子中间,非常耀眼。

不知是什么原因,李叔叔历来不要别人来夸她的女儿长得漂亮,要是他人不经意夸他女儿漂亮,他其实不高兴,亦不认同。

所以,亲戚朋友也就不去夸耀,知道他有这个忌讳。

不仅如此,李叔叔从小到大给女儿的打扮都非常普通,历来不会给她买非常漂亮的裙子或鞋子,乃至故意让她穿一些比较土气的衣服,这样即使她长得很漂亮,但是融入到学生群体中也就没有甚么特别了。

李叔叔从小会给女儿灌输这样一种思想:女儿,你长得非常一般,如果将来你想要出人头地的话,唯一的出路就是读书。

那个时候,他女儿深信父亲的话,她觉得自己长得不漂亮,不漂亮的话就只能读书。

这样的她居然从来没有由于长相普通而难过,反而因为父亲的话,好像顿悟了人生的真理:拼脸拼不过人家,那就拼才华。

李叔叔是一个国学爱好者,他的女儿在他的引导下,像一块海绵一样在知识的海洋中拼命汲取营养,她在小学的时候就看完了《山海经》、《吕氏年龄》、《文心雕龙》等各种古典名著,唐诗宋词更是信手拈来。

记得集会的时候,大人们都会要她背诵古诗或讲一个成语故事,每次她表演完以后,在坐的大人们都会给她雷鸣般的掌声,这时候李叔叔豪情万丈的站出来,用非常自豪的语气来总结:我家闺女虽然长相不出众,但是她不靠脸吃饭,我们靠才华!

此时的她非常满足,恍如遭到了极大的鼓舞。

由于经常被人说成不漂亮,她也没有花多少心思在穿衣打扮上面,常常穿的是学校的校服,扎着一个马尾辫,一双简单的帆布鞋,虽然打扮不是很时髦,但是非常干净质朴。

我和她从小在一个学校读书,她的成绩常常让我望尘莫及,每次考试差不多都是年级第一名,尤其是语文成绩,作文常常是满分,遣词造句都极为讲求,引经据典更是不在话下,打开文章一看,浓浓的文学气息就扑面而来。

那时候的她,有点像最近在诗词大赛中大红大紫的高中生武亦姝,连博士生的诗词储备量都没有她那末高。

这样的她读完我们当地最好的初中,最好的高中,单招进了国内顶尖的大学,然后毕业后公费去了美国的1所著名学府继续进修,后来留在了美国工作,在那里结婚生子。

女儿问爸我长得好看不这个父亲的回答亮了

去年过年的时候,她回国了,当我再次见到她的时候,简直亮瞎了我的双眼。

她妆容精致,谈吐优雅,衣着干净利落,踩着一双高跟鞋,一股国际化的气味扑面而来,举手投足之间充满了自信,她的身上产生了天翻地覆的变化.......

从前的那个丑小鸭不见了,转身1变成了白天鹅,浑身上下都充满着美好。

我冲她打招呼,她回头朝我微微一笑,笑起来的样子还是很像小时候的她,眼睛很好看,像月牙。

我朝她开玩笑,“明明你从小到大都很好看,可是李叔却总是说你长相不好,这肯定是亲爹么?”

她哈哈大笑,对我说:“其实,我读大学的时候就早发现了,那个时候有很多男孩子追我,还把我评为系里面的系花。然后我打电话给我爸,我对我爸说,爸,其实,我长得还是蛮好看的,对吧?我爸沉默了好久,然后说了一段我至今难忘的话。

他说:丫头,外貌是你的资本,而不是你这个年龄阶段应当追求的目标。不要在该努力的时候,放弃努力,去寻求所谓的美貌,被所谓的美貌扰乱你的心志,这是百分之九十的女孩都会犯的毛病,我是你的父亲,我有义务让你少走弯路。相信爸爸,爸爸这么多年的努力,真的只是为你好。

我挂了电话后,想了很久,从小被我爸建立的“你不漂亮”的观念被完全打破,我反复揣摩我爸的话,开始反思总结自己短短二十几年的经历,最后我总结出:我能够有我现在的光辉和成绩,不就是因为心无旁骛的在学习么?因此,我选择了相信我爸的话,更加明确了自己想要的是什么。”

她的一番话,让我感慨万千,我深深佩服她爸的智慧和良苦用心,如果没有她爸的引导和教育,恐怕她这一生很难到达现在的这个高度。

女儿问爸我长得好看不这个父亲的回答亮了

读高中的时候,我的前桌是一个美丽聪明的女孩。她是我们班上所有男生心目中的女神,乃至可以说是全校最漂亮的一个。

刚刚进高中的时候,她的成绩还不错,常常是前三名,可是到后面愈来愈差。

那个时候很多男生追她,她开始每天穿很漂亮的衣服,画眉毛,涂口红,烫头发,经常上着上着课就拿着镜子出来照照,心思完全没在学习上面。

她后来总是迟到,成绩徘徊在班上倒数五名之间,教导处批评的名单里面,经常出现她的名字。

后来她因为一些原因被学校给退学了,她退学后,我再也没有看见过她。

直到有一次我和同学去我们老家县城里面办事的时候,经过菜市场,我看到了她。

她胖了很多,穿着一套脏兮兮的睡衣在菜市场买菜,牵着一个孩子,头发像稻草,皮肤粗糙,满脸倦容,她正和小贩在那里因为几毛钱讨价还价。

210几岁的她俨然已变成了一个中年妇女,再也没法从她身上看到一个美字,我少年时期对于她美好的印象,瞬间倒塌........

她的人生轨迹,让我心痛不已。

自从参加教育工作以后,她这样的女孩我见了太多太多了。

她们在最应当学习的年龄,没有好好学习,而是把自己最大的精力都用来打扮自己,用来如何跟男生谈恋爱,然后完全没有心思沉下心来学习。

这样的青春美吗?美,但是非常短暂。

一旦她们成绩下滑,很难考上好的大学,或不得不在高中就终止学业。

这样的她们一无所长,又没有什么文化内涵,很快就会看到生活残暴的一面,最后她们不能不由于年龄和生存的压力,早早的嫁人生子。

这样的她们,并没有多少资本,能嫁的男人条件也好不到哪里去,结婚后,由于要照顾孩子,操持家务,常常会疏于打扮自己,乃至可以说没有钱去打扮自己,买一套化妆品贵了,还要遭受丈夫或婆婆的白眼。

很快,她们靠年轻所支撑起来的美丽,在短短的几年后会消失得很快,最后变成一个中年妇女的形象。

很多人说年龄是女人面貌的天敌,不好意思,没钱打扮自己才是女人面貌真正的天敌。

一套好一点牌子的化妆品,一身好看一点的衣服,一个好看一点的包包,这样来维护自己美丽的本钱,一个月没有几千是完全拿不下的。

对经济并不好的她们,不是想不想去打扮自己的问题,而是能不能打扮自己的问题。

反而那些很用功读书的女人,她们长大后有好的工作,有好的经济实力,她们有能力让自己变得更漂亮,远远比之前的姑娘要荣幸得多。

就像龙应台对自己的儿子所说的那样:

孩子,我要求你读书用功,是由于,我希望你将来会具有选择的权利,选择有意义、有时间的工作,而不是被迫谋生。

所以,姑娘,我希望你在年少的时候让自己“丑”点,这样你才有心思专注你的学业,你才能够不会被自己的美貌所干扰。

你应当在什么年纪就做符合你年纪的事情,要知道很多事情过了这村就没有这店了。

如果在该努力的年龄去追求美貌,生活总会让你付出惨痛的代价!

威尔刚官方网站

印度神油可以用于保健

神油保质期

印度神油印

相关推荐