LivePhoto(实况图片)渲染

前言

最近使用 iPhone 拍摄了一些实况照片,发现了一个很有意思的功能,LivePhoto,它可以将照片变成一个小视频,如果把这个特性应用到LifePalette-Web项目中,会不会很有趣呢?

探索 LivePhoto

网上对于 vue 实现LivePhoto的文章很少,搜索相关资料发现苹果官方提供了一个LivePhotojs库,LivePhotoKit,它可以帮助我们实现LivePhoto的渲染,于是我就尝试使用这个库来实现LivePhoto的渲染

html 复制代码
<!DOCTYPE html>

<html>

  <head>

    <meta charset="utf-8" />

    <script src="https://cdn.apple-livephotoskit.com/lpk/1/livephotoskit.js"></script>

  </head>

  <body>

    <div

      data-live-photo

      data-photo-src="http://nest-js.oss-accelerate.aliyuncs.com/nestTest/1/1711965193523.JPEG"

      data-video-src="http://nest-js.oss-accelerate.aliyuncs.com/nestTest/1/1711965199299.MOV"

      style="width: 320px; height: 320px"

    ></div>

  </body>

</html>

由官网 demo 发现实况图片其实是由两部分组成的,一部分是图片,一部分是视频,图片和视频是一一对应的,这里我们可以通过data-photo-srcdata-video-src来指定图片和视频的地址,这样就可以实现实况图片的渲染

在Vue中使用LivePhoto

官方提供了 livephotoskit.js 库,我们可以 npm 安装这个库

bash 复制代码
pnpm install livephotoskit

实现

vue 复制代码
<script setup>

import * as LivePhotosKit from 'livephotoskit'

  


const livePhotoRef = ref()

const fileInfo = {

    src: 'http://nest-js.oss-accelerate.aliyuncs.com/nestTest/1/1711965193523.JPEG',

    videoSrc: 'http://nest-js.oss-accelerate.aliyuncs.com/nestTest/1/1711965199299.MOV',

}

async function initLivePhoto() {

    await nextTick()

    const player = LivePhotosKit.Player(livePhotoRef.value)

    player.photoSrc = fileInfo.src

    player.videoSrc = fileInfo.videoSrc

}

onMounted(() => {

    initLivePhoto()

})

</script>

  


<template>

 <div ref="livePhotoRef" class="w-100 h-100" />

</template>

  


<style lang="less" scoped></style>

  

总结

通过这次探索,我们成功的实现了LivePhoto的渲染,这个功能可以让我们的项目更加有趣,如果你也对这个功能感兴趣,可以尝试一下

项目地址:LifePalette-Web

预览地址:LifePalette-Web

相关推荐
鹏仔工作室1 小时前
elemetui中el-date-picker限制开始结束日期只能选择当月
前端·vue.js·elementui
Lyuing2 小时前
el-input数字类型禁止+-符号输入
vue.js
拉不动的猪2 小时前
Token无感刷新全流程(Vue + Axios + Node.js(Express))
java·javascript·vue.js
再吃一颗苹果要不要2 小时前
Vue.js 源码解读:从 new Vue() 到 DOM 更新的完整追踪
vue.js
竹秋…4 小时前
el-table 滚动条小箭头点不了且部分滚动条无法拖动的问题
javascript·vue.js·elementui
香香爱编程4 小时前
Electron里的electron-window-state 使用
前端·javascript·vue.js·vscode·electron·前端框架
涔溪4 小时前
Vue 中实现 PDF 文件上传
javascript·vue.js·pdf
顾三殇4 小时前
【TRAE】AI 编程:颠覆全栈开发,基于 TRAE AI 编程完成 Vue 3 + Node.js + MySQL 企业级项目实战,从环境搭建到部署上线
vue.js·ai编程·trae·ai 开发工具
脸大是真的好~5 小时前
黑马JAVAWeb -Vue工程化 - Element Plus- 表格-分页条-中文语言包-对话框-Form表单
前端·javascript·vue.js
DevUI团队5 小时前
🚀 MateChat发布V1.10.0版本,支持附件上传及体验问题修复,欢迎体验~
前端·vue.js·人工智能