CN116710881A - 针对多视频片段捕获选择音频 - Google Patents

针对多视频片段捕获选择音频 Download PDF

Info

Publication number
CN116710881A
CN116710881A CN202180088064.XA CN202180088064A CN116710881A CN 116710881 A CN116710881 A CN 116710881A CN 202180088064 A CN202180088064 A CN 202180088064A CN 116710881 A CN116710881 A CN 116710881A
Authority
CN
China
Prior art keywords
audio track
camera mode
audio
user
capture
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202180088064.XA
Other languages
English (en)
Inventor
卡韦赫·安瓦里普尔
克里斯蒂娜·巴龙
韦恩·迈克·卡奥
安德鲁·格罗夫纳·库珀
克里斯蒂·马里·海基宁
拉尼德·兰卡格
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Snap Inc
Original Assignee
Snap Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Snap Inc filed Critical Snap Inc
Priority claimed from PCT/US2021/064704 external-priority patent/WO2022146798A1/en
Publication of CN116710881A publication Critical patent/CN116710881A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/16Sound input; Sound output
    • G06F3/165Management of the audio stream, e.g. setting of volume, audio stream path
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/81Monomedia components thereof
    • H04N21/8106Monomedia components thereof involving special audio data, e.g. different tracks for different languages
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • G06F3/0482Interaction with lists of selectable items, e.g. menus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0484Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
    • G06F3/04845Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range for image manipulation, e.g. dragging, rotation, expansion or change of colour
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • G06F3/04883Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures for inputting data by handwriting, e.g. gesture or text
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/02Editing, e.g. varying the order of information signals recorded on, or reproduced from, record carriers
    • G11B27/031Electronic editing of digitised analogue information signals, e.g. audio or video signals
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/10Indexing; Addressing; Timing or synchronising; Measuring tape travel
    • G11B27/34Indicating arrangements 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/07User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail characterised by the inclusion of specific contents
    • H04L51/10Multimedia information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/439Processing of audio elementary streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/472End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content
    • H04N21/47205End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content for manipulating displayed content, e.g. interacting with MPEG-4 objects, editing locally
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/478Supplemental services, e.g. displaying phone caller identification, shopping application
    • H04N21/4788Supplemental services, e.g. displaying phone caller identification, shopping application communicating with other users, e.g. chatting
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/85Assembly of content; Generation of multimedia applications
    • H04N21/854Content authoring
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/63Control of cameras or camera modules by using electronic viewfinders
    • H04N23/631Graphical user interfaces [GUI] specially adapted for controlling image capture or setting capture parameters
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/667Camera operation mode switching, e.g. between still and video, sport and normal or high- and low-resolution modes

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Databases & Information Systems (AREA)
  • Computer Security & Cryptography (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

本公开内容的各方面涉及系统,该系统包括存储用于提供音频与捕获的视频片段的程序和方法的计算机可读存储介质。该程序和方法使得进行以下操作:由消息收发应用显示用于捕获视频的捕获用户界面;提供摄像装置模式选择元素,该摄像装置模式选择元素可选择以在用于捕获单个视频片段的第一摄像装置模式与用于捕获多个视频片段的第二摄像装置模式之间切换,以生成媒体内容项;提供音频选择元素,该音频选择元素可选择以针对媒体内容项选择音频轨道;经由摄像装置模式选择元素接收对第二摄像装置模式进行选择的第一用户输入;经由音频选择元素接收对音频轨道进行选择的第二用户输入;以及使得捕获与所选择的音频轨道相关联的多个视频片段以生成媒体内容项。

Description

针对多视频片段捕获选择音频
相关申请的交叉引用
本专利申请要求于2021年12月20日提交的美国申请序列号17/556,802的权益,该申请要求于2020年12月30日提交的题为“SELECTING AN AUDIO TRACK IN ASSOCIATIONWITH MULTI-VIDEO CLIP CAPTURE”的美国临时专利申请第63/132,172号的权益,该美国申请通过引用整体并入本文。
技术领域
本公开内容一般涉及消息收发系统,包括在消息收发系统内选择与多片段视频捕获相关联的音频轨道。
背景技术
消息收发系统提供用户之间的消息内容的交换。例如,消息收发系统允许用户与一个或更多个其他用户交换消息内容(例如,文本、图像)。
附图说明
在不必按比例绘制的附图中,相似的附图标记可以在不同的视图中描述类似的部件。为了容易标识对任何特定元素或动作的讨论,附图标记中的一个最高位数字或多个最高位数字指代该元素被首次引入时所在的图号。一些非限制性示例在附图的图中示出,在附图中:
图1是根据一些示例的其中可以部署本公开内容的联网环境的图解表示。
图2是根据一些示例的具有客户端侧功能和服务器侧功能两者的消息收发系统的图解表示。
图3是根据一些示例的如在数据库中维护的数据结构的图解表示。
图4是根据一些示例的消息的图解表示。
图5是示出根据一些示例实施方式的被配置成捕获、组合和预览多个视频片段的用户接口布置的图。
图6A至图6E示出了根据一些示例实施方式的被配置成捕获多个视频片段以包括到媒体内容项中的用户界面。
图7示出了根据一些示例实施方式的用于预览多个视频片段以组合成媒体内容项的用户界面。
图8A至图8E示出了根据一些示例实施方式的被配置成捕获与音频轨道相关联的视频片段以包括到媒体内容项中的用户界面。
图9是示出根据一些示例实施方式的用于选择与多个视频片段捕获相关联的音频轨道的过程的流程图。
图10是根据一些示例的访问限制处理的流程图。
图11是根据一些示例的呈计算机系统形式的机器的图解表示,在该计算机系统内可以执行一组指令以使该机器执行本文中讨论的方法中的任何一种或更多种。
图12是示出其中可以实现示例的软件架构的框图。
具体实施方式
消息收发系统通常允许用户在消息线程中彼此交换内容项(例如,消息、图像和/或视频)。消息收发系统可以实现一个或更多个内容馈送以将媒体内容呈现给最终用户。
所公开的实施方式提供具有用户接口元素的消息收发系统以添加与多视频片段摄像装置模式相关联的音频轨道。摄像装置模式对应于捕获多个视频片段,这些视频片段可组合以生成媒体内容项(例如,用于发送给朋友、广播给其他人等)。时间轴进度条在视频片段被捕获时描绘视频片段(例如,作为分段)。消息收发系统提供用于选择音频轨道的用户接口元素,以及用于在所选择的音频轨道内选择开始回放的点。
预览按钮可选择成指向用于预览和编辑媒体内容项的预览界面。可以通过将多个视频片段中的一个或更多个视频片段(例如,每个片段具有相应的编辑)与所选择的音频轨道一起组合来生成媒体内容项。媒体内容项可以经由预览界面发送、保存或广播。
图1是示出用于通过网络来交换数据(例如,消息和相关联的内容)的示例消息收发系统100的框图。消息收发系统100包括客户端设备102的多个实例,每个客户端设备托管包括消息收发客户端104和其他应用106的若干应用。每个消息收发客户端104经由网络112(例如,因特网)通信地耦接至消息收发客户端104(例如,托管在相应的其他客户端设备102上)的其他实例、消息收发服务器系统108和第三方服务器110。消息收发客户端104还可以使用应用程序接口(API)与本地托管的应用106通信。
消息收发客户端104能够经由网络112与其他消息收发客户端104以及与消息收发服务器系统108通信并交换数据。在消息收发客户端104之间以及在消息收发客户端104与消息收发服务器系统108之间交换的数据包括功能(例如,用于激活功能的命令)以及有效载荷数据(例如,文本、音频、视频或其他多媒体数据)。
消息收发服务器系统108经由网络112向特定消息收发客户端104提供服务器侧功能。虽然消息收发系统100的某些功能在本文中被描述为由消息收发客户端104或由消息收发服务器系统108执行,但是某些功能的定位是在消息收发客户端104内还是在消息收发服务器系统108内可以是设计选择。例如,在技术上优选的可能是:最初将某些技术和功能部署在消息收发服务器系统108内,但是后面将该技术和功能迁移至客户端设备102具有足够处理能力的消息收发客户端104。
消息收发服务器系统108支持向消息收发客户端104提供的各种服务和操作。这样的操作包括向消息收发客户端104发送数据、从消息收发客户端104接收数据以及对由消息收发客户端104生成的数据进行处理。作为示例,该数据可以包括消息内容、客户端设备信息、地理定位信息、媒体增强和叠加、消息内容持续条件、社交网络信息和实况事件信息。通过经由消息收发客户端104的用户界面(UI)可用的功能来激活和控制消息收发系统100内的数据交换。
现在具体地转至消息收发服务器系统108,应用程序接口(API)服务器116耦接至应用服务器114并且向应用服务器114提供编程接口。应用服务器114通信地耦接至数据库服务器120,数据库服务器120便于对数据库126的访问,该数据库126存储与通过应用服务器114处理的消息相关联的数据。类似地,web服务器128耦接至应用服务器114,并且向应用服务器114提供基于web的接口。为此,web服务器128通过超文本传输协议(HTTP)和若干其他相关协议处理传入的网络请求。
应用程序接口(API)服务器116在客户端设备102与应用服务器114之间接收和发送消息数据(例如,命令和消息有效载荷)。具体地,应用程序接口(API)服务器116提供一组接口(例如,例程和协议),该组接口可以由消息收发客户端104调用或查询以激活应用服务器114的功能。应用程序接口(API)服务器116暴露由应用服务器114支持的各种功能,包括:帐户注册;登录功能;经由应用服务器114将消息从特定消息收发客户端104发送至另一消息收发客户端104;将媒体文件(例如,图像或视频)从消息收发客户端104发送至消息收发服务器118并用于另一消息收发客户端104的可能访问;媒体数据集合(例如,故事)的设置;检索客户端设备102的用户的朋友列表;检索这样的集合;检索消息和内容;在实体图(例如,社交图)中添加和删除实体(例如,朋友);在社交图中定位朋友;以及打开应用事件(例如,与消息收发客户端104相关)。
应用服务器114托管若干服务器应用和子系统,包括例如消息收发服务器118、图像处理服务器122和社交网络服务器124。消息收发服务器118实现了若干消息处理技术和功能,特别是与从消息收发客户端104的多个实例接收到的消息中包括的内容(例如,文本和多媒体内容)的聚合和其他处理相关的消息处理技术和功能。如将进一步详细描述的,来自多个来源的文本和媒体内容可以聚合成内容集合(例如,称为故事或图库)。然后,使这些集合可用于消息收发客户端104。鉴于对数据的其他处理器和存储器密集处理的硬件要求,也可以由消息收发服务器118在服务器侧执行这样的处理。
应用服务器114还包括图像处理服务器122,该图像处理服务器专用于执行各种图像处理操作,通常相对于在从消息收发服务器118发送或者在消息收发服务器118处接收的消息的有效载荷内的图像或视频,执行各种图像处理操作。
社交网络服务器124支持各种社交联网功能和服务,并且使这些功能和服务可用于消息收发服务器118。为此,社交网络服务器124维护和访问数据库126内的实体图304(如图3所示)。社交网络服务器124所支持的功能和服务的示例包括标识消息收发系统100中的与特定用户具有关系或该特定用户正在“关注”的其他用户,以及标识特定用户的其他实体和兴趣。
返回到消息收发客户端104,外部资源(例如,应用106或小应用(applet))的特征和功能经由消息收发客户端104的接口对用户可用。在该上下文中,“外部”是指应用106或小应用在消息收发客户端104外部的事实。外部资源通常由第三方提供,但也可以由消息收发客户端104的创建者或提供者提供。消息收发客户端104接收对启动或访问这种外部资源的特征的选项的用户选择。外部资源可以是安装在客户端设备102上的应用106(例如,“本地app”)、或者托管在客户端设备102上或者位于客户端设备102的远端(例如,在第三方服务器110上)的应用的小规模版本(例如,“小应用”)。应用的小规模版本包括应用的特征和功能的子集(例如,应用的全规模、原声版本),并且使用标记语言文档来实现。在一个示例中,应用的小规模版本(例如,“小应用”)是应用的基于web的标记语言版本,并且嵌入在消息收发客户端104中。除了使用标记语言文档(例如,.*ml文件)之外,小应用还可以包括脚本语言(例如,.*js文件或.json文件)和样式表(例如,.*ss文件)。
响应于接收到对启动或访问外部资源的特征的选项的用户选择,消息收发客户端104确定所选择的外部资源是基于web的外部资源还是本地安装的应用106。在一些情况下,本地安装在客户端设备102上的应用106可以例如通过在客户端设备102的主屏幕上选择对应于应用106的图标来独立于消息收发客户端104并且与消息收发客户端104分开启动。可以经由消息收发客户端104启动或访问这种应用的小规模版本,并且在一些示例中,小规模应用的任何部分都不能(或者有限部分才能)在消息收发客户端104之外被访问。可以通过消息收发客户端104例如从第三方服务器110接收与小规模应用相关联的标记语言文档并处理这样的文档来启动小规模应用。
响应于确定外部资源是本地安装的应用106,消息收发客户端104指示客户端设备102通过执行与外部资源相对应的本地存储的代码来启动外部资源。响应于确定外部资源是基于web的资源,消息收发客户端104(例如)与第三方服务器110通信以获得与所选择的外部资源相对应的标记语言文档。消息收发客户端104然后处理所获得的标记语言文档以在消息收发客户端104的用户界面内呈现基于web的外部资源。
消息收发客户端104可以向客户端设备102的用户或与这样的用户相关的其他用户(例如,“朋友”)通知在一个或更多个外部资源中发生的活动。例如,消息收发客户端104可以向消息收发客户端104中的对话(例如,聊天会话)中的参与者提供与一组用户中的一个或更多个成员当前或最近使用外部资源相关的通知。可以邀请一个或更多个用户加入活动的外部资源或启动最近使用但当前未活动的(在该组朋友中的)外部资源。外部资源可以向对话中的各自使用相应的消息收发客户端104的参与者提供与一组用户中的一个或更多个成员将外部资源中的项、状态、状况或定位共享到聊天会话中的能力。共享项可以是交互式聊天卡,聊天的成员可以利用该交互式聊天卡进行交互,例如,以启动相应的外部资源,查看外部资源内的特定信息,或者将聊天的成员带到外部资源内的特定定位或状态。在给定的外部资源内,可以在消息收发客户端104上向用户发送响应消息。外部资源可以基于外部资源的当前上下文在响应中选择性地包括不同的媒体项。
消息收发客户端104可以向用户呈现可用外部资源(例如,应用106或小应用)的列表以启动或访问给定的外部资源。该列表可以呈现在上下文相关菜单中。例如,表示应用106(或小应用)中的不同应用的图标可以基于用户如何启动菜单(例如,从对话界面或从非对话界面)而变化。
图2是示出根据一些示例的关于消息收发系统100的另外的细节的框图。具体地,消息收发系统100被示出为包括消息收发客户端104和应用服务器114。消息收发系统100包含多个子系统,这些子系统在客户端侧由消息收发客户端104支持并且在服务器侧由应用服务器114支持。这些子系统包括例如短暂定时器系统202、集合管理系统204、增强系统208、地图系统210、外部资源系统212和摄像装置模式系统214。
短暂定时器系统202负责施行由消息收发客户端104和消息收发服务器118对内容的临时或限时访问。短暂定时器系统202包含多个定时器,这些定时器基于与消息或消息集合(例如,故事)相关联的持续时间和显示参数,选择性地实现经由消息收发客户端104访问消息和相关联的内容(例如,用于呈现和显示)。下面提供关于短暂定时器系统202的操作的另外的细节。
集合管理系统204负责管理媒体的集或集合(例如,文本、图像视频和音频数据的集合)。可以将内容(例如,消息,包括图像、视频、文本和音频)集合组织成“事件图库”或“事件故事”。可以使这样的集合在指定的时间段(例如,内容所涉及的事件的持续时间)内可用。例如,可以使与音乐会相关的内容在音乐会的持续时间内作为“故事”可用。集合管理系统204还可以负责向消息收发客户端104的用户界面发布提供关于存在特定集合的通知的图标。
此外,集合管理系统204包括策展接口206,该策展接口使得集合管理器能够管理和策展特定的内容集合。例如,策展接口206使得事件组织器能够策展与特定事件相关的内容集合(例如,删除不适当的内容或冗余消息)。另外,集合管理系统204采用机器视觉(或图像识别技术)和内容规则来自动策展内容集合。在某些示例中,可以针对将用户生成的内容包括到集合中而向用户支付补偿。在这样的情况下,集合管理系统204进行操作以自动地向这样的用户进行支付以便使用他们的内容。
增强系统208提供使得用户能够增强(例如,注释或以其他方式修改或编辑)与消息相关联的媒体内容的各种功能。例如,增强系统208提供与生成和发布用于由消息收发系统100处理的消息的媒体叠加(media overlay)相关的功能。增强系统208基于客户端设备102的地理定位可操作地向消息收发客户端104提供媒体叠加或增强(例如,图像过滤器)。在另一示例中,增强系统208基于例如客户端设备102的用户的社交网络信息的其他信息可操作地向消息收发客户端104提供媒体叠加。媒体叠加可以包括音频和视觉内容以及视觉效果。音频和视觉内容的示例包括图片、文本、标识、动画和声音效果。视觉效果的示例包括色彩叠加。可以将音频和视觉内容或视觉效果应用于客户端设备102处的媒体内容项(例如,照片)。例如,媒体叠加可以包括可以叠加在由客户端设备102拍摄的照片之上的文本或图像。在另一示例中,媒体叠加包括定位标识叠加(例如,威尼斯海滩)、实况事件的名称或商家名称叠加(例如,海滩咖啡馆)。在另一示例中,增强系统208使用客户端设备102的地理定位来标识包括在客户端设备102的地理定位处的商家的名称的媒体叠加。媒体叠加可以包括与商家相关联的其他记号。媒体叠加可以存储在数据库126中并且通过数据库服务器120访问。
在一些示例中,增强系统208提供基于用户的发布平台,该发布平台使得用户能够选择地图上的地理定位,并且上传与所选择的地理定位相关联的内容。用户还可以指定特定媒体叠加应当被提供给其他用户的情况。增强系统208生成包括所上传的内容的媒体叠加并且将所上传的内容与所选择的地理定位相关联。
在其他示例中,增强系统208提供基于商家的发布平台,该基于商家的发布平台使得商家能够经由出价过程选择与地理定位相关联的特定媒体叠加。例如,增强系统208将最高出价商家的媒体叠加与对应地理定位相关联达预定义时间量。
在其他示例中,如下面关于图3所讨论的,增强系统208使得与客户端设备102的摄像装置所捕获的图像或视频相关联地呈现增强现实内容。增强系统208可以实现或以其他方式访问增强现实内容项(例如,对应于应用镜头(Lenses)或增强现实体验)来提供可以被添加至图像或视频的实时特殊效果和/或声音。为了有助于增强现实内容的呈现,增强系统208可以实现或以其他方式访问对象识别算法(例如,包括机器学习算法),该对象识别算法被配置成扫描图像或视频并且检测/跟踪图像或视频内的对象的移动。
地图系统210提供各种地理定位功能,并且支持由消息收发客户端104呈现基于地图的媒体内容和消息。例如,地图系统210使得能够在地图上显示(例如,存储在简档数据302中的)用户图标或化身,以在地图的上下文内指示用户的“朋友”的当前或过去定位,以及由这些朋友生成的媒体内容(例如,包括照片和视频的消息的集合)。例如,在消息收发客户端104的地图界面上,可以将用户从特定地理定位发布到消息收发系统100的消息在地图的该特定定位的上下文内显示给特定用户的“朋友”。用户还可以经由消息收发客户端104(例如,使用适当的状态化身)与消息收发系统100的其他用户共享他的或她的定位和状态信息,其中该定位和状态信息在消息收发客户端104的地图界面的上下文内被类似地显示给所选择的用户。
外部资源系统212为消息收发客户端104提供接口以与远程服务器(例如,第三方服务器110)通信以启动或访问外部资源(即,应用或小应用)。每个第三方服务器110托管例如基于标记语言(例如,HTML5)的应用或应用的小规模版本(例如,游戏应用、实用程序应用、支付应用或乘坐共享应用)。消息收发客户端104可以通过从与基于web的资源相关联的第三方服务器110访问HTML5文件来启动基于web的资源(例如,应用)。在某些示例中,利用由消息收发服务器118提供的软件开发工具包(SDK)以JavaScript对由第三方服务器110托管的应用进行编程。SDK包括应用程序接口(API),API具有可以由基于web的应用调用或激活的功能。在某些示例中,消息收发服务器118包括JavasScript库,该库提供对消息收发客户端104的某些用户数据的给定外部资源访问。HTML5被用作用于编程游戏的示例技术,但是可以使用基于其他技术编程的应用和资源。
为了将SDK的功能集成到基于web的资源中,SDK由第三方服务器110从消息收发服务器118下载,或者由第三方服务器110以其他方式接收。一旦被下载或接收,SDK被包括作为基于web的外部资源的应用代码的一部分。基于web的资源的代码然后可以调用或激活SDK的某些功能以将消息收发客户端104的特征集成到基于web的资源中。
存储在消息收发服务器118上的SDK有效地提供外部资源(例如,应用106或小应用)与消息收发客户端104之间的桥接。这为用户提供了在消息收发客户端104上与其他用户通信的无缝体验,同时还保留了消息收发客户端104的外观和感觉。为了桥接外部资源与消息收发客户端104之间的通信,在某些示例中,SDK有助于第三方服务器110与消息收发客户端104之间的通信。在某些示例中,在客户端设备102上运行的WebViewJavaScriptBridge在外部资源与消息收发客户端104之间建立两个单向通信信道。消息经由这些通信信道在外部资源与消息收发客户端104之间异步发送。每个SDK函数调用作为消息和回调发送。通过构造唯一的回调标识符并且发送具有该回调标识符的消息来实现每个SDK函数。
通过使用SDK,并非来自消息收发客户端104的所有信息都与第三方服务器110共享。SDK基于外部资源的需要来限制共享哪些信息。在某些示例中,每个第三方服务器110向消息收发服务器118提供与基于web的外部资源相对应的HTML5文件。消息收发服务器118可以在消息收发客户端104中添加基于web的外部资源的视觉表示(例如,盒设计或其他图形)。一旦用户选择了视觉表示或通过消息收发客户端104的GUI指示消息收发客户端104访问基于web的外部资源的特征,消息收发客户端104获得HTML5文件并且对访问基于web的外部资源的特征所需的资源进行实例化。
消息收发客户端104呈现用于外部资源的图形用户界面(例如,登录页面或标题画面)。在呈现登录页面或标题画面期间、之前或之后,消息收发客户端104确定所启动的外部资源是否先前已被授权访问消息收发客户端104的用户数据。响应于确定所启动的外部资源先前已被授权访问消息收发客户端104的用户数据,消息收发客户端104呈现包括外部资源的功能和特征的外部资源的另一图形用户界面。响应于确定所启动的外部资源先前未被授权访问消息收发客户端104的用户数据,在显示外部资源的登录页面或标题画面的阈值时间段(例如,3秒)之后,消息收发客户端104向上滑动菜单(例如,将菜单动画化为从屏幕底部浮现到屏幕中部或其他部分)以用于授权外部资源访问用户数据。该菜单标识外部资源将被授权使用的用户数据的类型。响应于接收到对接受选项的用户选择,消息收发客户端104将外部资源添加至授权的外部资源的列表,并且允许外部资源访问来自消息收发客户端104的用户数据。在一些示例中,外部资源由消息收发客户端104根据OAuth 2框架授权访问用户数据。
消息收发客户端104基于被授权的外部资源的类型来控制与外部资源共享的用户数据的类型。例如,向包括全规模应用(例如,应用106)的外部资源提供对第一类型的用户数据(例如,具有或不具有不同化身特性的用户的仅二维化身)的访问。作为另一示例,向包括应用的小规模版本(例如,应用的基于web的版本)的外部资源提供对第二类型的用户数据(例如,支付信息、用户的二维化身、用户的三维化身、以及具有各种化身特性的化身)的访问。化身特性包括定制化身的外观和感觉(例如不同姿势、面部特征、服装等)的不同方式。
摄像装置模式系统214实现各种功能以在消息收发系统100的上下文内提供不同的摄像装置模式。例如,摄像装置模式系统214提供第一摄像装置模式和第二摄像装置模式,并且向用户提供在第一摄像装置模式与第二摄像装置模式之间进行选择的选项。第一摄像装置模式对应于捕获单个视频片段以便生成媒体内容项。摄像装置模式系统214提供第二摄像装置模式来捕获多个视频以进行组合来生成媒体内容项。另外,摄像装置模式系统214被配置成基于启用哪个摄像装置模式调整用户界面(例如,用于捕获视频片段的捕获用户界面和/或用于预览所捕获的视频片段的预览用户界面)。
音频轨道系统216实现用于关于生成媒体内容项而将音频轨道添加至所捕获的视频(或所捕获的图像)的各种功能。例如,音频轨道系统216提供访问可用音频轨道的目录、呈现可用音频轨道以供用户选择,以及将所选择的音频轨道与所捕获的视频或图像组合以生成媒体内容项。在一个或更多个实施方式中,可用音频轨道的目录由第三方服务器(例如,对应于第三方服务器110之一)维护。例如,音频轨道系统216被配置成基于消息收发系统100与第三方服务器之间的许可布置来访问(例如,下载和/或流式传输)音频轨道。在一个或更多个实施方式中,音频轨道系统216还被配置成访问给定音频轨道的标识信息,例如,音频轨道的标题(例如,歌曲名称)、艺术家、流派等。
图3是示出根据某些示例的可以存储在消息收发服务器系统108的数据库126中的数据结构300的示意图。虽然数据库126的内容被示出为包括若干表,但是将理解的是,数据可以存储在其他类型的数据结构中(例如,作为面向对象数据库)。
数据库126包括存储在消息表306内的消息数据。对于任何特定的一个消息,该消息数据至少包括消息发送方数据、消息接收方(或接收器)数据和有效载荷。下面参照图4描述了关于可以被包括在消息中并且被包括在存储在消息表306中的消息数据中的信息的另外的细节。
实体表308存储实体数据,并且(例如,以参考的方式)链接至实体图304和简档数据302。在实体表308内保存其记录的实体可以包括个人、公司实体、组织、对象、地点、事件等。与实体类型无关,消息收发服务器系统108存储关于其的数据的任何实体可以是被辨识的实体。每个实体设置有唯一的标识符以及实体类型标识符(未示出)。
实体图304存储关于实体之间的关系和关联的信息。仅作为示例,这样的关系可以是社交的、职业的(例如,在共同的公司或组织工作)、基于兴趣的、或基于活动的。
简档数据302存储关于特定实体的多种类型的简档数据。基于由特定实体指定的隐私设置,简档数据302可以被选择性地使用并且呈现给消息收发系统100的其他用户。在实体是个人的情况下,简档数据302包括例如用户名、电话号码、地址、设置(例如,通知和隐私设置)以及用户选择的化身表示(或这样的化身表示的集合)。然后,特定用户可以将这些化身表示中的一个或更多个化身表示选择性地包括在经由消息收发系统100传达的消息的内容中以及由消息收发客户端104向其他用户显示的地图界面上。化身表示的集合可以包括“状态化身”,所述状态化身呈现用户可以选择在特定时间进行传达的状态或活动的图形表示。
在实体是团体的情况下,除了团体名称、成员以及针对相关团体的各种设置(例如,通知)之外,针对团体的简档数据302还可以类似地包括与团体相关联的一个或更多个化身表示。
数据库126还在增强表310中存储例如叠加或过滤器的增强数据。增强数据与视频(其数据被存储在视频表314中)和图像(其数据被存储在图像表316中)相关联并且应用于视频和图像。
在一个示例中,过滤器是在向接收方用户呈现期间显示为叠加在图像或视频上的叠加。过滤器可以是各种类型的,包括当发送用户正在编写消息时来自由消息收发客户端104呈现给发送用户的一组过滤器的用户选择的过滤器。其他类型的过滤器包括地理定位过滤器(也称为地理过滤器),所述地理定位过滤器可以基于地理定位被呈现给发送用户。例如,可以基于由客户端设备102的全球定位系统(GPS)单元确定的地理定位信息,由消息收发客户端104在用户接口内呈现特定于附近或特殊定位的地理定位过滤器。
另一类型的过滤器是数据过滤器,该数据过滤器可以由消息收发客户端104基于在消息创建过程期间由客户端设备102收集的其他输入或信息选择性地呈现给发送用户。数据过滤器的示例包括特定定位处的当前温度、发送用户行进的当前速度、客户端设备102的电池寿命或当前时间。
可以存储在图像表316内的其他增强数据包括增强现实内容项(例如,与应用镜头或增强现实体验相对应)。增强现实内容项可以提供可以被添加至图像或视频的实时特殊效果和/或声音。
如上所述,增强数据包括增强现实内容项、叠加、图像变换、AR图像,以及涉及可以应用于图像数据(例如,视频或图像)的修改的类似术语。这包括实时修改,其在使用客户端设备102的设备传感器(例如,一个或多个摄像装置)捕获图像时然后在修改的情况下在客户端设备102的屏幕上显示时对图像进行修改。这还包括对所存储的内容的修改,例如可以被修改的图库中的视频片段。例如,在访问多个增强现实内容项的客户端设备102中,用户可以将单个视频片段与多个增强现实内容项一起使用来查看不同的增强现实内容项将如何修改所存储的片段。例如,通过针对同一内容选择不同的增强现实内容项,可以将应用不同伪随机运动模型的多个增强现实内容项应用于该同一内容。类似地,实时视频捕获可以与示出的修改一起使用,以示出当前由客户端设备102的传感器捕获的视频图像将如何修改所捕获的数据。这样的数据可以仅显示在屏幕上而不存储在存储器中,或者由设备传感器捕获的内容可以在进行修改或不进行修改(或两者)的情况下被记录并且存储在存储器中。在一些系统中,预览特征可以显示不同的增强现实内容项在同一时间在显示器的不同窗口中看起来如何。例如,这可以使得具有不同伪随机动画的多个窗口能够同时在显示器上被查看。
因此,使用增强现实内容项的数据和各种系统或使用该数据修改内容的其他这样的变换系统可以涉及视频帧中的对象(例如,脸、手、身体、猫、狗、表面、物体等)的检测,在这些对象离开视场、进入视场以及在视场四处移动时对这些对象的跟踪,以及在跟踪这些对象时对这样的对象的修改或变换。在各种示例中,可以使用用于实现这种变换的不同方法。一些示例可以涉及生成一个或多个对象的三维网格模型,并且使用视频内的模型的变换和动画纹理来实现变换。在其他示例中,可以使用对象上的点的跟踪来将图像或纹理(其可以是二维或三维的)放置在所跟踪的位置处。在又一示例中,视频帧的神经网络分析可以用于将图像、模型或纹理放置在内容(例如,图像或视频的帧)中。因此,增强现实内容项既涉及用于创建内容中的变换的图像、模型和纹理,又涉及利用对象检测、跟踪和放置实现这样的变换所需的附加建模和分析信息。
可以利用保存在任何类型的计算机化系统的存储器中的任何类型的视频数据(例如,视频流、视频文件等)来执行实时视频处理。例如,用户可以加载视频文件并且将其保存在设备的存储器中,或者可以使用设备的传感器生成视频流。另外,可以使用计算机动画模型来处理任何对象,例如人的面部和人身体的各部分、动物或非生物例如椅子、汽车或其他对象。
在一些示例中,当与要变换的内容一起选择特定修改时,由计算设备标识要变换的元素,然后如果所述元素存在于视频帧中,则检测并跟踪它们。根据修改请求来修改对象的元素,从而变换视频流的帧。针对不同类型的变换,可以通过不同的方法执行对视频流的帧的变换。例如,对于主要是指改变对象的元素的形式的帧的变换,计算对象的每个元素的特性点(例如,使用主动形状模型(ASM)或其他已知方法)。然后,针对对象的至少一个元素中的每个元素生成基于特性点的网格。该网格用于在视频流中跟踪对象的元素的后续阶段。在跟踪过程中,将所提及的每个元素的网格与每个元素的位置对准。然后,在网格上生成附加点。基于修改请求针对每个元素生成第一点的第一集合,并且基于第一点的集合和修改请求针对每个元素生成第二点的集合。然后,可以通过基于第一点的集合和第二点的集合以及网格修改对象的元素来对视频流的帧进行变换。在这样的方法中,也可以通过跟踪和修改背景来使所修改的对象的背景改变或扭曲。
在一些示例中,使用对象的元素改变对象的一些区域的变换可以通过计算对象的每个元素的特性点并基于所计算的特性点生成网格来执行。在网格上生成点,然后基于这些点生成各种区域。然后,通过将每个元素的区域与至少一个元素中的每个元素的位置对准来跟踪对象的元素,并且可以基于修改请求来修改区域的性质,从而变换视频流的帧。根据具体的修改请求,可以以不同的方式变换所提及的区域的性质。这样的修改可以涉及:改变区域的颜色;从视频流的帧中去除区域的至少一些部分;将一个或更多个新对象包括在基于修改请求的区域中;以及修改或扭曲区域或对象的元素。在各种示例中,可以使用这样的修改或其他类似修改的任何组合。对于要被动画化的某些模型,可以选择一些特性点作为要用于确定针对模型动画的选项的整个状态空间的控制点。
在使用面部检测来变换图像数据的计算机动画模型的一些示例中,使用特定面部检测算法(例如,Viola-Jones)在图像上检测面部。然后,将主动形状模型(ASM)算法应用于图像的面部区域以检测面部特征参考点。
可以使用适用于面部检测的其他方法和算法。例如,在一些示例中,使用界标来定位特征,该界标表示在所考虑的大多数图像中存在的可区分点。例如,对于面部界标,可以使用左眼瞳孔的定位。在初始界标不可标识的情况下(例如,如果人具有眼罩),则可以使用次级界标。这样的界标标识过程可以用于任何这样的对象。在一些示例中,界标的集合形成形状。可以使用形状中的点的坐标将形状表示为矢量。利用使形状点之间的平均欧几里德距离最小化的相似变换(允许平移、缩放和旋转)将一个形状与另一形状对准。平均形状是经对准的训练形状的均值。
在一些示例中,从与由全局面部检测器确定的面部的位置和大小对准的平均形状开始搜索界标。然后,这样的搜索重复以下步骤直至发生收敛:通过每个点周围的图像纹理的模板匹配来调整形状点的定位而建议暂定形状,然后使暂定形状符合全局形状模型。在一些系统中,单独的模板匹配是不可靠的,并且形状模型将弱模板匹配的结果进行池化,以形成更强的整体分类器。从粗分辨率到细分辨率,在图像金字塔中的每一级处重复整个搜索。
变换系统可以在客户端设备(例如,客户端设备102)上捕获图像或视频流,并且在客户端设备102上本地执行复杂的图像操纵,同时保持适合的用户体验、计算时间和功耗。复杂的图像操纵可以包括大小和形状变化、情绪迁移(例如,将面部从皱眉变为微笑)、状态迁移(例如,使对象变老、减小表观年龄、改变性别)、风格迁移、图形元素应用,以及由已经被配置成在客户端设备102上有效地执行的卷积神经网络实现的任何其他合适的图像或视频操纵。
在一些示例中,用于变换图像数据的计算机动画模型可以由系统使用,在该系统中,用户可以使用具有神经网络的客户端设备102来捕获用户的图像或视频流(例如,自拍),该神经网络作为在客户端设备102上操作的消息收发客户端104的一部分进行操作。在消息收发客户端104内操作的变换系统确定图像或视频流内的面部的存在,并且提供与计算机动画模型相关联的修改图标以变换数据图像,或者计算机动画模型可以与本文中描述的界面相关联地存在。修改图标包括改变,所述改变可以是作为修改操作的一部分的用于修改图像或视频流内的用户的面部的基础。一旦选择了修改图标,则变换系统发起转换用户的图像以反映所选择的修改图标(例如,在用户上生成笑脸)的处理。一旦捕获图像或视频流并且选择指定的修改,则修改的图像或视频流就可以呈现在客户端设备102上显示的图形用户界面中。变换系统可以在图像或视频流的一部分上实施复杂的卷积神经网络,以生成和应用所选择的修改。也就是说,用户可以捕获图像或视频流,并且一旦选择了修改图标,就可以实时或接近实时地呈现修改后的结果。此外,当正在捕获视频流时,修改可以是持久的,并且所选择的修改图标保持被切换。经机器学习的神经网络可以用于实现这样的修改。
呈现由变换系统执行的修改的图形用户界面可以向用户供应附加的交互选项。这样的选项可以基于用于发起内容捕获和对特定计算机动画模型的选择的接口(例如,从内容创建者用户界面发起)。在各种示例中,在对修改图标进行初始选择之后,修改可以是持久的。用户可以通过轻击或以其他方式选择由变换系统修改的面部来打开或关闭修改,并且将其存储以供以后查看或浏览到成像应用的其他区域。在由变换系统修改多个面部的情况下,用户可以通过轻击或选择在图形用户界面内修改和显示的单个面部来全局地打开或关闭修改。在一些示例中,可以单独地修改一组多个面部中的各个面部,或者可以通过轻击或选择图形用户界面内显示的各个面部或一系列各个面部来单独切换这样的修改。
故事表312存储关于消息和相关联的图像、视频或音频数据的集合的数据,所述消息和相关联的图像、视频或音频数据被编译成集合(例如,故事或图库)。特定集合的创建可以由特定用户(例如,在实体表308中为其维护记录的每个用户)发起。用户可以以已经由该用户创建和发送/广播的内容的集合的形式创建“个人故事”。为此,消息收发客户端104的用户界面可以包括用户可选择的图标,以使得发送用户能够将特定内容添加到他或她的个人故事。
集合还可以构成“实况故事”,该“实况故事”是手动地、自动地或者使用手动技术和自动技术的组合创建的来自多个用户的内容的集合。例如,“实况故事”可以构成来自不同定位和事件的用户提交内容的策展流。其客户端设备启用了定位服务并且在特定时间处于共同定位事件处的用户可以例如经由消息收发客户端104的用户界面被呈现有选项,以将内容贡献给特定实况故事。可以由消息收发客户端104基于他或她的定位向用户标识实况故事。最终结果是从社群角度讲述的“实况故事”。
另一类型的内容集合被称为“定位故事”,该“定位故事”使得其客户端设备102位于特定地理定位(例如,在学院或大学校园)内的用户能够对特定集合做出贡献。在一些示例中,对定位故事的贡献可能需要第二程度的认证来验证最终用户属于特定组织或其他实体(例如,是大学校园中的学生)。
如上面提及的,视频表314存储视频数据,在一个示例中,该视频数据与其记录保持在消息表306内的消息相关联。类似地,图像表316存储与其消息数据存储在实体表308中的消息相关联的图像数据。实体表308可以使来自增强表310的各种增强与存储在图像表316和视频表314中的各种图像和视频相关联。
图4是示出根据一些示例的消息400的结构的示意图,消息400由消息收发客户端104生成,以用于传达至另外的消息收发客户端104或消息收发服务器118。特定消息400的内容用于填充存储在数据库126内的消息表306,该消息表306可由消息收发服务器118访问。类似地,消息400的内容被存储在客户端设备102或应用服务器114的存储器中作为“传输中”或“飞行中”数据。消息400被示出为包括以下示例组成部分:
·消息标识符402:标识消息400的唯一标识符。
·消息文本有效载荷404:要由用户经由客户端设备102的用户界面生成并且包括在消息400中的文本。
·消息图像有效载荷406:由客户端设备102的摄像装置部件捕获的或从客户端设备102的存储器部件检索到的、并且包括在消息400中的图像数据。用于发送或接收到的消息400的图像数据可以存储在图像表316中。
·消息视频有效载荷408:由摄像装置部件捕获的或从客户端设备102的存储器部件检索到的、并且包括在消息400中的视频数据。用于发送或接收到的消息400的视频数据可以存储在视频表314中。
·消息音频有效载荷410:由麦克风捕获的或从客户端设备102的存储器部件检索到的、并且包括在消息400中的音频数据。
·消息增强数据412:表示要应用于消息400的消息图像有效载荷406、消息视频有效载荷408或消息音频有效载荷410的增强的增强数据(例如,过滤器、标贴或其他注释或增强)。用于发送或接收到的消息400的增强数据可以存储在增强表310中。
·消息持续时间参数414:以秒为单位指示消息的内容(例如,消息图像有效载荷406、消息视频有效载荷408、消息音频有效载荷410)要经由消息收发客户端104呈现给用户或使其对于用户可访问的时间量的参数值。
·消息地理定位参数416:与消息的内容有效载荷相关联的地理定位数据(例如,纬度和经度坐标)。多个消息地理定位参数416值可以被包括在有效载荷中,这些参数值中的每个参数值与内容中所包括的内容项(例如,消息图像有效载荷406内的特定图像或消息视频有效载荷408中的特定视频)相关联。
·消息故事标识符418:标识与消息400的消息图像有效载荷406中的特定内容项相关联的一个或更多个内容集合(例如,在故事表312中标识的“故事”)的标识符值。例如,可以使用标识符值将消息图像有效载荷406内的多个图像各自与多个内容集合相关联。
·消息标签420:每个消息400可以用多个标签来标记,所述多个标签中的每个标签指示消息有效载荷中所包括的内容的主题。例如,在消息图像有效载荷406中所包括的特定图像描绘动物(例如,狮子)的情况下,标签值可以被包括在指示相关动物的消息标签420内。标签值可以基于用户输入手动地生成,或者可以使用例如图像识别自动地生成。
·消息发送者标识符422:指示在其上生成消息400并且从其发送消息400的客户端设备102的用户的标识符(例如,消息收发系统标识符、电子邮件地址或设备标识符)。
·消息接收者标识符424:指示消息400寻址到的客户端设备102的用户的标识符(例如消息收发系统标识符、电子邮件地址或设备标识符)。
消息400的各种组成部分的内容(例如,值)可以是指向其内存储有内容数据值的表中的位置的指针。例如,消息图像有效载荷406中的图像值可以是指向图像表316内的定位的指针(或图像表316内的定位的地址)。类似地,消息视频有效载荷408内的值可以指向存储在视频表314内的数据,存储在消息增强412内的值可以指向存储在增强表310中的数据,存储在消息故事标识符418内的值可以指向存储在故事表312中的数据,并且存储在消息发送者标识符422和消息接收者标识符424内的值可以指向存储在实体表308内的用户记录。
图5是示出根据一些示例实施方式的被配置成捕获、组合和预览多个视频片段的用户界面布置500的图。出于说明的目的,本文主要参照图1的消息收发客户端104和图2的摄像装置模式系统214来描述用户界面布置500。并非所有所描绘的和所描述的界面/组件均可以用于所有实现方式中,并且一个或更多个实施方式可以包括与关于附图所示出的或所描述的界面/组件相比另外的或不同的界面/组件。在不脱离本文所阐述的权利要求书的精神或范围的情况下,可以对界面/组件的布置和类型做出改变。
用户界面布置500可以至少部分地由摄像装置模式系统214实现。如上所述,摄像装置模式系统214可以对应于消息收发系统100的子系统,并且可以在客户端侧由消息收发客户端104支持和/或在服务器侧由应用服务器114支持。在一个或更多个实施方式中,可以在客户端侧、服务器侧以及/或者以客户端侧和服务器侧的组合来实现如本文所述的对视频片段的捕获、组合和预览。
如图5所示,捕获界面502包括摄像装置选择按钮506,该摄像装置选择按钮506是用户可选择的,以用于在客户端设备102的后置摄像装置与前置摄像装置之间切换。捕获界面502还包括用于相对于所捕获的图像数据512(或者所捕获的图像)激活或去激活闪光灯的闪光灯按钮508。捕获界面502还包括摄像装置模式选择按钮510。另外,捕获界面502包括用于启动如下面关于图6D讨论的轮播界面的轮播启动按钮522。
此外,捕获界面502包括用户可选择以捕获视频(例如,视频片段)和/或图像(例如,图片)的捕获按钮520。如本文所述,“视频片段”对应于运行达不间断时间段的一系列视频帧。例如,视频片段对应于从摄像装置开始录制的时刻直至摄像装置停止录制的时刻所捕获的视频。
在一个或更多个实施方式中,消息收发客户端104与摄像装置模式系统214结合使得用户在第一摄像装置模式与第二摄像装置模式之间进行选择以进行视频捕获。例如,第一摄像装置模式对应于捕获可用于生成媒体内容项的单个视频片段。第二摄像装置模式对应于捕获可以被组合以生成媒体内容项的多个视频片段。
在这方面,摄像装置模式选择按钮510是用户可选择的,以用于在第一摄像装置模式与第二摄像装置模式之间切换。在一个或更多个实施方式中,消息收发客户端104默认为第一摄像装置模式。例如,在消息收发客户端104启动时,消息收发客户端104激活客户端设备102的摄像装置,以实时显示所捕获的图像数据512,并且默认为关于捕获界面502的第一摄像装置模式。
响应于对摄像装置模式选择按钮510的用户选择,消息收发客户端104与摄像装置模式系统214结合使得实现从第一摄像装置模式到第二摄像装置模式的切换。切换到第二摄像装置模式还可以经由预定义触摸手势(例如,在处于第一摄像装置模式下时从捕获按钮520开始的向左拖动手势)来实现。在一个或更多个实施方式中,可以在第一次启动第二摄像装置模式时呈现教程(例如,模态或叠加),以教导用户与第二摄像装置模式相关的特征。
在第一摄像装置模式下,捕获按钮520可选择以经由预定义手势(例如,按下并保持手势,其中在保持持续时间内录制视频)捕获单个视频片段。另外,捕获按钮520可选择以经由另一预定义手势(例如,轻击手势)来捕获图片。
在第二摄像装置模式下,捕获按钮520的行为可以不同于第一摄像装置模式的行为,以有助于捕获多个视频片段。在一个或更多个实施方式中,捕获按钮520响应于用于捕获视频片段的不同类型的触摸输入。在第一示例中,捕获按钮520可选择以经由按下并保持手势捕获视频片段(例如,在保持持续时间内期间录制视频)。在另一示例中,捕获按钮520可选择以经由第一轻击手势和第二轻击手势捕获视频片段,其中对于视频片段,第一轻击手势发起视频捕获并且第二轻击手势结束视频捕获(例如,对应于免提录制)。
在一个或更多个实施方式中,针对第二轻击手势的捕获按钮520的预定义触摸区域可以小于针对第一轻击手势的捕获按钮520的预定义触摸区域(例如,以减少用户无意地停止视频捕获的可能性)。例如,触摸区域可以对应于在所显示的捕获按钮520的中心内的预定义区域。
在第二摄像装置模式下,摄像装置模式系统214使得以顺序方式捕获多个视频片段,使得第一视频片段之后是第二视频片段,第二视频片段之后是第三视频片段,等等。视频片段中的每个视频片段可能已经响应于经由捕获按钮520的相应触摸输入(例如,按下并保持手势、第一/第二轻击或其组合)而被捕获。
在一个或更多个实施方式中,摄像装置模式系统214使得对时间轴进度条514的更新进行实时显示,以在视频片段被捕获时描绘所述视频片段。如图5的示例所示,时间轴进度条514的显示可以伴随有撤销按钮516和预览按钮518的显示。在一个或更多个实施方式中,摄像装置模式系统214使得仅在第二摄像装置模式下显示撤销按钮516、时间轴进度条514和预览按钮518。这样,在第一摄像装置模式活动时,不显示撤销按钮516、时间轴进度条514和预览按钮518。
如图5的示例所示,时间轴进度条514将视频片段描绘成相应的分段,每个分段的长度与相应视频片段的持续时间成比例。可以实时添加和/或更新分段。随着每个相应视频片段被捕获,每个分段的长度可能看起来实时增加。出于说明的目的,扩展视图524(其不必由捕获界面502示出)描绘了示例视频片段1至5。
在一个或更多个实施方式中,时间轴进度条514被配置成基于关于所有当前捕获的视频片段的组合持续时间超过预设时间阈值而实时更新。例如,时间轴进度条514的初始时间轴长度可以预设为第一时间阈值(例如,10秒),使得时间轴进度条514被描绘成在达到第一时间阈值时填满。一旦当前捕获的视频片段的组合持续时间达到第一时间阈值,时间轴长度就被调整成第二时间阈值(例如,30秒),其中当前进度(例如,分段)被描绘成相对于调整后的时间轴长度折叠。一旦当前捕获的视频片段的组合持续时间达到第二时间阈值,时间轴长度就被调整成第三时间阈值(例如,60秒),其中当前进度(例如,分段)被描绘成相对于调整后的时间轴长度折叠。
在一个或更多个实施方式中,摄像装置模式系统214使得对所有当前捕获的视频片段的组合持续时间进行限制或遏制。例如,摄像装置模式系统214可以将最大持续时间设置为60秒(例如,对应于上面提及的第三时间阈值)。如果总录制时间达到最大持续时间,则捕获界面502可以显示通知,以防止录制要包括在媒体内容项中的后续视频片段。
捕获界面502还包括撤销按钮516。如上所述,撤销按钮516可以在第二摄像装置模式活动时(并且不是在第一摄像装置模式活动时)呈现。撤销按钮516可选择以删除最近的视频片段(例如,对应于时间轴进度条514的最后或最右边的分段)。在时间轴进度条514中没有视频片段的情况下,撤销按钮516可以用关闭按钮(描绘为“x”并在下面关于图7进一步讨论)替换,该关闭按钮可选择以退出第二摄像装置模式并且恢复成第一摄像装置模式。
从第二摄像装置模式恢复成第一摄像装置模式还可以通过对摄像装置模式选择按钮510的用户选择来实现。响应于在处于第二摄像装置模式下时对摄像装置模式选择按钮510的用户选择,消息收发客户端104可以提示用户确认将删除任何所捕获的视频片段。
捕获界面502还包括预览按钮518。预览按钮518可选择以从捕获界面502切换到预览用户界面504。另一方面,示例实施方式中的第一摄像装置模式可以不包括预览按钮518,并且代替的是,可以在捕获单个视频片段(或图片)之后自动呈现预览界面。
在第二摄像装置模式下,预览用户界面504使得在捕获时预览所捕获的视频片段(例如,片段1至6)。另外,预览用户界面504提供用户可选择的元素,以用于基于所捕获的视频片段生成媒体内容项。
在一个或更多个实施方式中,预览用户界面504包括用于将视频片段添加到所捕获的视频片段的用户可选择按钮(“+”按钮,该“+”按钮在下面关于图7进一步描绘和讨论)。选择该按钮可以使摄像装置模式系统214从预览用户界面504切换回捕获界面502,其中保留所有的视频片段和编辑。
例如,摄像装置模式系统214可以有助于在与集合管理系统204相关联的本地存储器中保留片段,并且可以有助于在与增强系统208相关联的本地存储器中保留编辑。除了保留关于用户可选择按钮(“+”按钮)的视频片段和/或编辑之外,摄像装置模式系统214可以保留和重新呈现关于用户在其他界面和/或应用之间切换的视频片段和/或编辑。例如,当从以下中的一个或更多个返回到摄像装置选择按钮506或预览用户界面504时,保留视频片段和/或编辑:消息收发客户端104内的另一界面(例如,聊天界面、回复界面);消息收发客户端104以外的应用(例如,其中所选择的摄像装置模式和/或时间轴进度也被保留,如由摄像装置模式系统214所促进的);以及/或者切断消息收发客户端104(例如,其中所选择的摄像装置模式和/或时间轴进度也被保留)。
返回参照图5,预览用户界面504包括用于对所捕获的视频片段进行修改/注释(例如,在其上绘制、向其添加文本、向其添加贴纸、裁剪等)的编辑工具526。虽然在图5中未示出,但是预览用户界面504还可以包括用于以下中的一项或更多项的界面元素(例如,按钮):将(例如,具有修改/注释的)所捕获的视频片段保存为媒体内容项;基于(例如,具有修改/注释的)所捕获的视频片段创建或更新故事;修改与所捕获的视频片段相关联的音频信号;向联系人/朋友发送包括(例如,具有修改/注释的)所捕获的视频片段的媒体内容项;以及/或者广播与馈送界面相关联的媒体内容项(例如,以供不一定是联系人/朋友的其他用户观看)。
如所述的,预览用户界面504使得基于多个视频片段生成媒体内容项。在一个或更多个实施方式中,消息收发客户端104(例如,与消息收发服务器系统108结合)被配置成连同修改或注释对多个视频片段进行组合,以基于所组合的视频片段生成媒体内容项。媒体内容项可以对应于包括所有(具有修改/注释的)片段的单个实体(例如,视频、消息)。在一个或更多个实施方式中,媒体内容项被配置成连续播放(例如,相对于观看用户),以便在播放最后的视频片段之后循环回到第一视频片段。
图6A至图6E示出了根据一些示例实施方式的被配置成捕获多个视频片段以用于包括到媒体内容项中的用户界面(例如,捕获用户界面602)。图6A至图6E描绘了示例场景,在示例场景中,用户选择上面提及的第二摄像装置模式(图6A),捕获第一视频片段(图6B至图6C),启动轮播界面(例如,图6D),以及继续捕获视频片段(图6E)。
与图5的捕获界面502类似,图6A至图6E的捕获用户界面602包括以下中的一项或更多项:摄像装置选择按钮604(例如,用于在后置摄像装置与前置摄像装置之间切换)、闪光灯按钮606(例如,用于激活和去激活闪光灯)、摄像装置模式选择按钮608(例如,用于在第一摄像装置模式与第二摄像装置模式之间切换)、捕获按钮610、轮播启动按钮612(例如,用于启动轮播界面624)、时间轴进度条616(例如,用于显示捕获视频片段的进度)、关闭按钮614(例如,用于从第二摄像装置模式切换回到第一摄像装置模式)、预览按钮618(例如,用于预览、编辑和生成基于所捕获的视频片段的媒体内容项)和/或撤销按钮622(例如,用于删除最近的视频片段)。
在图6A的示例中,用户选择摄像装置模式选择按钮608。在一个或更多个实施方式中,捕获用户界面602可以默认为用于捕获单个视频片段的第一摄像装置模式。响应于对摄像装置模式选择按钮608的选择,消息收发客户端104与摄像装置模式系统214结合使得从第一摄像装置模式切换到第二摄像装置模式。如上所述,这样的切换可以包括:调整捕获按钮520以响应于用于捕获视频的不同类型的触摸输入,以及/或者将撤销按钮516、时间轴进度条514和预览按钮518添加到捕获界面502。
关闭按钮614是用于关闭第二摄像装置模式的用户可选择按钮。响应于对关闭按钮614的用户选择,摄像装置模式系统214使得退出第二摄像装置模式并且恢复到第一摄像装置模式。在一个或更多个实施方式中,关闭按钮614在没有捕获的视频片段时被呈现(例如,没有视频片段被捕获,或者所有捕获的视频片段已经经由撤销按钮516被删除)。
捕获用户界面602还包括预览按钮618,该预览按钮618可选择以预览、编辑和/或生成包括所捕获的视频片段的媒体内容项。在一个或更多个实施方式中,在第一视频片段已经被捕获之后启用预览按钮618。替选地或另外地,摄像装置模式系统214可以实现最小视频持续时间(例如,5秒)以便启用预览按钮618。在图6A的示例中,预览按钮618被禁用,因为还没有捕获视频片段(例如,时间轴进度条616是空的)。在一个或更多个实施方式中,预览按钮618的显示在从禁用(例如,灰色勾选标记)切换到启用(例如,黄色勾选标记)时改变。工具提示(例如,指示“预览您的媒体内容项”的消息)可以将用户注意力引导至启用的预览按钮618。工具提示可以仅显示一次(例如,第一次),以告知用户对预览按钮618的选择指向预览用户界面504。
图6B示出了当用户发起对第一视频片段的捕获时的示例。例如,用户基于经由捕获按钮610的触摸输入620(例如,按下并保持手势或如上所述的第一轻击手势)来发起对第一视频片段的捕获。如图6B的示例所示,实时更新时间轴进度条616以显示与第一视频片段对应的第一分段。随着每个相应视频片段被捕获,第一分段的长度可能看起来实时增加。
图6C示出了用户何时完成对第一视频片段的捕获(例如,释放按下并保持手势,或如上所述的第二轻击手势)。在一个或更多个实施方式中,在捕获第一视频片段完成后,摄像装置模式系统214使得通过将关闭按钮614替换为撤销按钮622(例如,撤销按钮622可选择以从时间轴进度条616删除第一视频片段)和/或通过启用预览按钮618来更新捕获用户界面602。
如上所述,轮播启动按钮612是用户可选择的以启动轮播界面624。响应于对预览按钮618的选择,捕获用户界面602(例如,通过摄像装置模式系统214)被更新以显示如图6D所示的轮播界面624。在一个或更多个实施方式中,轮播界面624使得用户能够循环和/或选择不同的增强现实内容项(例如,镜头)以应用/显示关于当前由设备摄像装置捕获的并在设备屏幕上显示的图像。可用增强现实内容项中的每一个由图标表示,该图标是用户可选择的以用于切换到相应的增强现实内容项。
在一个或更多个实施方式中,与活动的增强现实内容项相对应的图标(例如,活动的AR图标626)相对于其余图标以不同方式(例如,大于其余图标)显示。在第二摄像装置模式下活动的AR图标626的行为类似于捕获按钮610的行为。例如,用户可以选择活动的AR图标626以经由相应的按下并保持手势和/或第一和第二轻击手势来捕获后续视频片段。对应的增强现实内容项(例如,镜头)应用于随后捕获的视频片段。另外,用户可以选择在视频片段被捕获时将不同的增强现实内容项应用到不同的视频片段。在一个或更多个实施方式中,可以向包括增强现实内容的媒体内容项的观看用户呈现用于应用(例如,解锁)对应的增强现实内容项以从它们的末尾修改所捕获的图像/视频的界面。
在图6E的示例中,用户已经捕获了四个视频片段,如由时间轴进度条616中的各个分段所描绘的。如上所述,撤销按钮622可选择以从时间轴进度条616删除视频片段(例如,其中每个轻击手势删除最近的视频片段)。捕获用户界面602还包括预览按钮618,其可选择以经由预览用户界面702预览、编辑和/或生成基于所捕获的视频片段的媒体内容项,如下面关于图7所讨论的。
图7示出了根据一些示例实施方式的用于预览多个视频片段以组合成媒体内容项的预览用户界面702。例如,图7描绘了其中用户选择预览与图6D相关联地捕获的多个视频片段(例如,4个视频片段)的示例场景。
类似于图5的预览用户界面504,图7的预览用户界面702包括编辑工具704。例如,编辑工具704包括用于对所捕获的视频片段进行修改/注释(例如,在其上绘制、向其添加文本、向其添加贴纸、裁剪等)的用户可选择图标(例如,按钮)。用户可选择图标可以包括用于对在循环、弹跳(例如,在正向回放与反向回放之间切换)和/或关于所得的媒体内容项的单次回放之间进行选择的选项。
另外,预览用户界面702包括:保存按钮714,其可选择以将(例如,具有修改/注释的)所捕获的视频片段保存为媒体内容项;故事按钮716,其可选择以基于(例如,具有修改/注释的)所捕获的视频片段创建故事;音频按钮712,其可选择以修改与所捕获的视频片段相关联的音频信号;和/或发送按钮718,其可选择以将对(例如,包括任何修改/注释的)所捕获的视频片段进行组合的媒体内容项发送给接收者(例如,联系人/朋友)以及/或者将媒体内容项广播给消息收发系统100的其他用户。
此外,预览用户界面702(例如,出于预览目的)使得循环回放所捕获的视频片段,如由循环回放722所示。预览用户界面702还包括视频预览708,在视频预览708中,每个视频片段被表示为相应的缩略图,并且在视频预览708中,位置指示器720指示循环回放722的当前回放位置。缩略图被描绘为组合在一起(例如,作为组合的视频片段)。在一个或更多个实施方式中,缩略图可单独选择以进行编辑/删除(例如,与编辑工具704中的一个或更多个编辑工具704相结合)。
另外,预览用户界面702包括用于将视频片段添加到所捕获的视频片段(例如,可经由视频预览708查看)的添加视频按钮710。响应于对添加视频按钮710的用户选择(例如,或者替选地,预定义手势,例如在预览用户界面702的预定义区域内的向下滑动手势),摄像装置模式系统214使得从预览用户界面702切换回到捕获界面502,其中所有视频片段和编辑都被保留。工具提示(例如,指示“返回摄像装置以添加更多”的消息)可以将用户注意力引导至添加视频按钮710。工具提示可以仅显示一次(例如,第一次),以告知用户对添加视频按钮710的选择指向捕获界面502。
关于保留视频片段和编辑,摄像装置模式系统214可以有助于在与集合管理系统204相关联的本地存储器中保留片段,并且可以有助于在与增强系统208相关联的本地存储器中保留(例如,经由编辑工具704)编辑。在一个或更多个实施方式中,预览用户界面702还包括可选择以退出预览用户界面702并返回至捕获界面502而不保留视频片段和/或编辑的关闭按钮706。在一个或更多个实施方式中,对关闭按钮706的用户选择可以提示用户确认删除视频片段和/或编辑。
图8A至图8E示出了根据一些示例实施方式的被配置成捕获与音频轨道相关联的视频片段以包括到媒体内容项目中的用户界面,即捕获用户界面802和音频轨道编辑界面830。图8A至图8E描绘了以下示例场景,在示例场景中,用户选择添加音频轨道以与所捕获的视频相关联(例如,图8A),从可用音频轨道的列表中选择音频轨道(图8B),设置音频轨道内的用于音频回放的起点(例如,图8C),并且捕获与音频轨道相关联的视频片段(图8D)。图8E示出了用于在第一摄像装置模式下选择音频轨道的示例界面。
与图6A至6E的捕获用户界面602类似,图8A至图8E的捕获用户界面802包括以下界面元素的一项或更多项:摄像装置选择按钮804(例如,用于在后置摄像装置与前置摄像装置之间切换)、闪光灯按钮806(例如,用于激活和去激活闪光灯)、摄像装置模式选择按钮808(例如,用于在第一摄像装置模式与第二摄像装置模式之间切换)、捕获按钮812(例如,用于捕获视频片段)、轮播启动按钮814(例如,用于启动轮播界面624)、时间轴进度条818(例如,用于显示捕获视频片段的进度)、关闭按钮816(例如,用于从第二摄像装置模式切换回到第一摄像装置模式)、预览按钮820(例如,用于预览、编辑和生成基于所捕获的视频片段的媒体内容项)和/或撤销按钮842(例如,用于删除最近的视频片段)。图8A至图8E的捕获用户界面802中的这些界面元素被配置成执行与上面关于图6A和至6E的捕获用户界面602所描述的功能类似的功能。
如图8A所示,摄像装置模式选择按钮808被突出显示,从而指示启用第二摄像装置模式以捕获多个视频片段。在图8A的示例中,视频片段尚未被捕获,例如,如时间轴进度条818为空(例如,没有分段)和预览按钮820被禁用(例如,变灰)所描绘的。
在一个或更多个实施方式中,捕获用户界面802还包括用于音频选择的两个元素,即音频选择按钮810和音频选择元素822。(例如,利用指示“添加声音”的文本描绘的)音频选择元素822和音频选择按钮810中的每一个是用户可选择的,以重新指向音频轨道列表824以用于选择音频轨道以伴随关于第二摄像装置模式捕获的视频片段。因此,响应于对音频选择按钮810或音频选择元素822的用户选择,更新捕获用户界面802以显示如图8B所示的音频轨道列表824。此外,音频选择按钮810可以被突出显示(例如,如图8D所示)以指示被启用。
音频轨道列表824显示例如如由音频轨道系统216(例如,与第三方音频服务器结合)所确定的可用音频轨道的列表。如上所述,音频轨道系统216可以与消息收发系统100的子系统相对应,并且可以在客户端侧由消息收发客户端104支持和/或在服务器侧由应用服务器114支持。在一个或更多个实施方式中,可以在客户端侧、服务器侧和/或以客户端侧和服务器侧的组合实现对可用音频轨道和/或可用音频轨道的标识信息(例如,标题、艺术家、流派等)的访问。
消息收发客户端104与音频轨道系统216结合显示每个音频轨道及其相应的标题和作者(例如,歌曲名称和艺术家姓名)。此外,音频轨道列表824内的每个音频轨道都呈现有相应的播放按钮828。播放按钮828是用户可选择的,以播放相应的音频轨道,例如,使得用户可以经由音频轨道列表824对不同的音频轨道进行采样。此外,可以基于流派和/或可由音频轨道系统216访问的其他信息(例如,与第三方音频服务器结合)经由音频轨道选项卡826对音频轨道进行分组。在一个或更多个实施方式中,用户可以经由预定义手势(例如,通过轻击对应的音频轨道条目)来选择音频轨道列表824内的音频轨道。
响应于对音频轨道列表824内的音频轨道的用户选择,消息收发客户端104切换到如图8C所示的音频轨道编辑界面830。音频轨道编辑界面830包括音频波形条832,音频波形条832在视觉上将音频轨道描绘为波形。例如,音频轨道系统216可以实施或以其他方式访问用于从所选择的音频轨道生成波形的算法。此外,音频波形条832包括起始位置选择器834,起始位置选择器834被配置成接收用于设置音频轨道的起始位置的触摸输入。
例如,起始位置选择器834被配置成接收用于在波形中导航的拖动输入(例如,左拖动用于向前方向,右拖动用于向后方向)。拖动手势的释放向音频轨道编辑界面830发出如下信号:停止波形移动,并且设置用于音频轨道回放(例如,在音频轨道编辑界面830内播放音频以用于采样/预览目的)的起始位置。
替选地或另外地,起始位置选择器834被配置成接收用于在波形中导航的滑动手势(例如,左滑动用于向前方向,右滑动用于向后方向)。起始位置选择器834内的后续轻击手势向音频轨道编辑界面830发出如下信号:停止波形移动,设置用于音频轨道回放(例如,在音频轨道编辑界面830内播放音频以用于采样/预览目的)的起始位置。
关闭按钮836是用于关闭音频轨道编辑界面830的用户可选择按钮。响应于对关闭按钮836的用户选择,摄像装置模式系统214和音频轨道系统216使得退出音频轨道编辑界面830并返回到第二摄像装置模式下的捕获用户界面802。在返回到捕获用户界面802时,音频选择按钮810变成禁用(例如,没有选择音频轨道)。用户可以通过选择摄像装置模式选择按钮808或音频选择元素822来返回以(例如,经由音频轨道列表824)选择音频轨道。
虽然在图8C中未示出,但是音频轨道编辑界面830还可以显示“改变声音”元素(例如,作为起始位置选择器834上方的文本),该“改变声音”元素是用户可选择的,以直接显示到如图8B中的音频轨道列表824。在这种情况下,可以在音频轨道列表824内预先选择先前选择的音频轨道,以由用户确认或改变。
音频轨道编辑界面830还包括确认按钮838,该确认按钮838是可选择的,以(例如,基于在起始位置选择器834内的波形的位置)确认所选择的音频轨道的起始位置。响应于对确认按钮838的用户选择,摄像装置模式系统214和音频轨道系统216使得退出音频轨道编辑界面830并返回到根据图8D的第二摄像装置模式下的捕获用户界面802。
在返回到捕获用户界面802时,音频选择按钮810保持启用并且音频轨道标题840显示在时间轴进度条818附近(例如,时间轴进度条818上方)。音频轨道标题840是用户可选择的,以返回到音频轨道编辑界面830(例如,用于经由确认按钮838设置音频轨道的起始位置,或者用于经由关闭按钮836删除音频轨道)。用户可以替选地通过经由触摸输入(例如,轻击手势)来删除音频轨道以禁用音频选择按钮810,并且被提示以确认对关于时间轴进度条818中表示的所捕获的视频的音频轨道的删除。
图8D的示例还示出了作为时间轴进度条818中的分段的第一视频片段。在(例如,经由捕获按钮812的按下并保持手势和/或第一和第二轻击手势)对视频片段的捕获期间,可以从音频轨道的当前位置播放所选择的音频轨道以用于采样/预览目的。
如上所述,轮播启动按钮814使得启动轮播界面(例如,如下面关于图6D所讨论的)。在轮播界面内,在所选择的增强现实内容项包括音频的情况下,这样的音频可以被静音并替换为所选择的音频轨道。
与如以上所讨论的图6A至图6E类似,撤销按钮842可选择以从时间轴进度条818删除视频片段。如果没有捕获到视频片段(例如,没有分段),则撤销按钮842可以用关闭按钮(未示出)替换,该关闭按钮可选择以返回到基于先前选择的音频轨道的音频轨道编辑界面830。可替选地,对关闭按钮的选择可以使捕获用户界面802禁用第二摄像装置模式和音频轨道选择二者(例如,摄像装置模式选择按钮808和音频选择按钮810二者都未被突出显示)。
预览按钮820可选择以(例如,经由预览用户界面)基于所捕获的视频片段和所选择的音频轨道来预览、编辑和/或生成媒体内容项。预览界面类似于上面关于图7讨论的预览用户界面702。然而,由对预览按钮820的用户选择而产生的预览界面还可以使得所选择的音频轨道进行循环回放(例如,与所组合的视频片段的循环回放相关联)。另外,预览界面可以显示所选择的音频轨道的标识信息。例如,轨道标题和/或艺术家姓名可以显示为在视频预览上方的叠加。
因此,如图8A至图8D所示,摄像装置模式系统214与音频轨道系统216结合提供用于添加与多片段视频捕获相关联的音频轨道的用户界面(例如,捕获用户界面802、音频轨道列表824和音频轨道编辑界面830)。图8A至图8D示出了以下示例场景,在该示例场景中,用户最初经由摄像装置模式选择按钮808选择第二摄像装置模式,并且随后(例如,经由音频选择按钮810)选择添加音频轨道。然而,捕获用户界面802提供替选场景。
例如,在捕获用户界面802处于第一摄像装置模式的情况下(例如,其中摄像装置模式选择按钮808未被突出显示),捕获用户界面802不显示关闭按钮816、时间轴进度条818和预览按钮820。如果用户在处于第一摄像装置模式下时最初选择(例如,经由音频选择按钮810)添加音频轨道,则消息收发客户端104使得对音频轨道列表824进行显示。经由音频轨道列表824对音频轨道的用户选择使消息收发客户端104显示如图8E所示的捕获用户界面802。
在用户希望保持在第一摄像装置模式下的情况下,用户可以经由如上所讨论的音频波形条832和起始位置选择器834针对所选择的音频轨道选择起始位置,或者可以经由关闭按钮836删除音频轨道。另外,对播放按钮844的用户选择使得对所选择的音频轨道进行采样/预览。如上文关于第一摄像装置模式所述的,捕获按钮812可选择以(例如,经由按下并保持手势,在该手势期间可以从起始位置播放所选择的音频轨道以用于采样/预览目的)捕获单个视频片段或者(例如,经由轻击手势)捕获图片。在这样的捕获之后,消息收发客户端104可以自动切换到预览用户界面,以用于基于所捕获的单个视频片段或图片以及所选择的音频轨道来预览、编辑和/或生成媒体内容项。
在用户希望切换到第二摄像装置模式的情况下,用户可以选择图8E中的摄像装置模式选择按钮808。作为响应,捕获用户界面802可以根据第二摄像装置模式以及根据启用的音频选择按钮810和先前选择的音频轨道(例如,类似于图8D)进行更新。
在一个或更多个实施方式中,摄像装置模式系统214与音频轨道系统216结合可以有助于将视频片段与音频轨道的组合存储在本地存储器中。这样,在用户界面之间的切换、其他应用之间的切换等方面,可以保留音频轨道与视频片段的组合。
图9是示出根据一些示例实施方式的用于选择与多视频片段捕获相关联的音频轨道的过程900的流程图。为了说明的目的,本文中主要参照图1的消息收发客户端104来描述过程900。然而,过程900的一个或更多个块(或操作)可以由一个或更多个其他部件和/或其他合适的设备来执行。进一步出于说明的目的,过程900的块(或操作)在本文中被描述为串行或线性地发生。然而,过程900的多个块(或操作)可以并行或同时发生。另外,过程900的块(或操作)不需要以所示的顺序执行,和/或过程900的一个或更多个块(或操作)不需要执行和/或可以由其他操作替换。当过程900的操作完成时,过程900可以终止。另外,过程900可以对应于方法、程序、算法等。
消息收发客户端104显示用于捕获视频的捕获用户界面(块902)。消息收发客户端104在捕获用户界面内提供摄像装置模式选择元素,摄像装置模式选择元素可选择以在第一摄像装置模式与第二摄像装置模式之间切换,第一摄像装置模式用于捕获单个视频片段以生成媒体内容项,并且第二摄像装置模式用于捕获多个视频片段以进行组合来生成媒体内容项(块904)。消息收发客户端104在捕获用户界面内提供音频选择元素,音频选择元素可选择以针对媒体内容项选择音频轨道(块906)。
消息收发客户端104经由摄像装置模式选择元素接收对第二摄像装置模式进行选择的第一用户输入(块908)。消息收发客户端104通过消息收发应用并经由音频选择元素接收对音频轨道进行选择的第二用户输入(块910)。
消息收发客户端104可以响应于接收到第一用户输入和第二用户输入,根据第二摄像装置模式和所选择的音频轨道对用于视频捕获的捕获用户界面进行更新。经更新的捕获用户界面可以包括被配置成基于捕获的视频片段的数目和每个捕获的视频片段的长度实时更新的时间轴进度条。时间轴进度条可以被配置成基于所有捕获的视频片段的总长度超过预设阈值而实时更新。更新的捕获用户界面可以显示与时间轴进度条相邻的音频轨道的标题(例如,一旦被选择)。
接收第二用户输入可以包括接收对音频选择元素的用户选择,响应于接收到该用户选择,在音频轨道列表界面内显示多个可用音频轨道,以及接收对来自音频轨道列表界面内的多个可用音频轨道中的音频轨道的用户选择。消息收发客户端104可以响应于接收到对音频轨道的用户选择,提供用于在音频轨道内选择开始音频回放的点的音频轨道编辑界面。
消息收发客户端104基于第一和第二用户输入使得捕获与所选择的音频轨道相关联的多个视频片段以生成媒体内容项(块912)。消息收发客户端104可以基于多个视频片段并且基于所选择的音频轨道生成媒体内容项。
图10是示出访问限制过程1000的示意图,根据该访问限制过程,对内容(例如,短暂消息1002和相关联的数据的多媒体有效载荷)或内容集合(例如,短暂消息组1004)的访问可以是时间受限的(例如,使得是短暂的)。
短暂消息1002被示为与消息持续时间参数1006相关联,消息持续时间参数的值确定消息收发客户端104将向短暂消息1002的接收用户显示短暂消息1002的时间量。在一个示例中,取决于发送用户使用消息持续时间参数1006指定的时间量,接收用户可以查看短暂消息1002达到最多10秒。
消息持续时间参数1006和消息接收者标识符424被示出为消息定时器1010的输入,消息定时器1010负责确定向由消息接收者标识符424标识的特定接收用户示出短暂消息1002的时间量。特别地,仅在由消息持续时间参数1006的值确定的时间段内向相关接收用户示出短暂消息1002。消息定时器1010被示出为向更一般化的短暂定时器系统202提供输出,该短暂定时器系统202负责向接收用户显示内容(例如,短暂消息1002)的总体定时。
在图10中短暂消息1002被示出为包括在短暂消息组1004(例如,个人故事或事件故事中的消息的集合)内。短暂消息组1004具有相关联的组持续时间参数1008,组持续时间参数1008的值确定短暂消息组1004被呈现并可由消息收发系统100的用户访问的持续时间。例如,组持续时间参数1008可以是音乐会的持续时间,其中,短暂消息组1004是涉及该音乐会的内容的集合。替选地,当执行短暂消息组1004的设置和创建时,用户(拥有用户或策展者用户)可以指定组持续时间参数1008的值。
另外,短暂消息组1004内的每个短暂消息1002具有相关联的组参与参数1012,组参与参数1002的值确定在短暂消息组1004的上下文内将可访问短暂消息1002的持续时间。因此,在短暂消息组1004本身根据组持续时间参数1008到期之前,特定的短暂消息组1004可以“到期”并且在短暂消息组1004的上下文中变得不可访问。组持续时间参数1008、组参与参数1012和消息接收者标识符424各自向组定时器1014提供输入,组定时器1014可操作地首先确定短暂消息组1004的特定短暂消息1002是否将被显示给特定接收用户,并且如果是,则确定显示多长时间。注意,由于消息接收者标识符424,短暂消息组1004也知道特定接收用户的身份。
因此,组定时器1014可操作地控制相关联的短暂消息组1004以及包括在短暂消息组1004中的单独的短暂消息1002的总使用期限。在一个示例中,短暂消息组1004内的每个短暂消息1002在由组持续时间参数1008指定的时间段内保持可查看和可访问。在另一示例中,在短暂消息组1004的上下文内,某个短暂消息1002可以基于组参与参数1012而到期。注意,即使在短暂消息组1004的上下文内,消息持续时间参数1006也仍然可以确定向接收用户显示特定短暂消息1002的持续时间。因此,消息持续时间参数1006确定向接收用户显示特定短暂消息1002的持续时间,而不管接收用户是在短暂消息组1004的上下文之内还是之外查看该短暂消息1002。
短暂定时器系统202还可以基于确定特定的短暂消息1002已经超过相关联的组参与参数1012而从短暂消息组1004中可操作地删除该特定的短暂消息1002。例如,在发送用户已经建立了从发布起24小时的组参与参数1012的情况下,短暂定时器系统202将在指定的24小时之后从短暂消息组1004中删除相关的短暂消息1002。短暂定时器系统202还进行操作以当针对短暂消息组1004内的每个短暂消息1002的组参与参数1012已到期时,或者当短暂消息组1004本身根据组持续时间参数1008已到期时,删除短暂消息组1004。
在某些使用情况下,特定短暂消息组1004的创建者可以指定无期限的组持续时间参数1008。在这种情况下,针对短暂消息组1004内最后剩余的短暂消息1002的组参与参数1012的到期将确定短暂消息组1004本身何时到期。在这种情况下,添加至短暂消息组1004的具有新的组参与参数1012的新的短暂消息1002有效地将短暂消息组1004的寿命延长到等于组参与参数1012的值。
响应于短暂定时器系统202确定短暂消息组1004已经到期(例如,不再是可访问的),短暂定时器系统202与消息收发系统100(并且例如特别是消息收发客户端104)通信,以使得与相关短暂消息组1004相关联的标记(例如,图标)不再显示在消息收发客户端104的用户接口内。类似地,当短暂定时器系统202确定针对特定短暂消息1002的消息持续时间参数1006已到期时,短暂定时器系统202使消息收发客户端104不再显示与短暂消息1002相关联的标记(例如,图标或文本标识)。
图11是机器1100的图解表示,在该机器1100中可以执行用于使机器1100执行本文中所讨论的方法中的任何一种或更多种的指令1110(例如,软件、程序、应用、小程序、app或其他可执行代码)。例如,指令1110可以使机器1100执行本文中所描述的方法中的任何一种或更多种方法。指令1110将通用的未编程的机器1100转换成被编程为以所描述的方式执行所描述和所示出的功能的特定机器1100。机器1100可以作为独立设备操作,或者可以耦接(例如,联网)至其他机器。在联网部署中,机器1100可以在服务器-客户端网络环境中以服务器机器或客户端机器的性能来操作,或者在对等(或分布式)网络环境中作为对等机器来操作。机器1100可以包括但不限于:服务器计算机、客户端计算机、个人计算机(PC)、平板计算机、膝上型计算机、上网本、机顶盒(STB)、个人数字助理(PDA)、娱乐媒体系统、蜂窝电话、智能电话、移动设备、可穿戴设备(例如,智能手表)、智能家居设备(例如,智能电器)、其他智能设备、网络设备、网络路由器、网络交换机、网络桥接器或能够顺序地或以其他方式执行指定要由机器1100采取的动作的指令1110的任何机器。此外,虽然仅示出了单个机器1100,但是术语“机器”还应被认为包括单独地或联合地执行指令1110以执行本文中所讨论的方法中的任何一种或更多种方法的机器的集合。例如,机器1100可以包括客户端设备102或者形成消息收发服务器系统108的一部分的若干个服务器设备中的任何一个。在一些示例中,机器1100还可以包括客户端和服务器系统两者,其中特定方法或算法的一些操作在服务器侧上执行,并且其中特定方法或算法的一些操作在客户端侧上执行。
机器1100可以包括处理器1104、存储器1106和输入/输出I/O部件1102,这些部件可以被配置成经由总线1140彼此通信。在示例中,处理器1104(例如,中央处理单元(CPU)、精简指令集计算(RISC)处理器、复杂指令集计算(CISC)处理器、图形处理单元(GPU)、数字信号处理器(DSP)、专用集成电路(ASIC)、射频集成电路(RFIC)、另外的处理器或其任何合适的组合)可以包括例如执行指令1110的处理器1108和处理器1112。术语“处理器”旨在包括多核处理器,所述多核处理器可以包括可以同时执行指令的两个或更多个独立处理器(有时被称为“核”)。尽管图11示出了多个处理器1104,但是机器1100可以包括具有单个核的单个处理器、具有多个核的单个处理器(例如,多核处理器)、具有单个核的多个处理器、具有多个核的多个处理器、或者其任意组合。
存储器1106包括主存储器1114、静态存储器1116以及存储单元1118,其均经由总线1140而可由处理器1104访问。主存储器1106、静态存储器1116和存储单元1118存储实现本文中描述的方法或功能中的任何一种或更多种的指令1110。指令1110还可以在其由机器1100执行期间完全地或部分地驻留在主存储器1114内、在静态存储器1116内、在存储单元1118内的机器可读介质1120内、在处理器1104中的至少一个处理器内(例如,在处理器的高速缓冲存储器内)、或者其任何合适的组合内。
I/O部件1102可以包括用于接收输入、提供输出、产生输出、发送信息、交换信息、捕获测量结果等的各种部件。在特定机器中包括的特定I/O部件1102将取决于机器的类型。例如,诸如移动电话的便携式机器可以包括触摸输入设备或其他这样的输入机构,而无头服务器机器将可能不包括这样的触摸输入设备。要理解的是,I/O部件1102可以包括图11中未示出的许多其他部件。在各种示例中,I/O部件1102可以包括用户输出部件1126和用户输入部件1128。用户输出部件1126可以包括视觉部件(例如,诸如等离子显示面板(PDP)、发光二极管(LED)显示器、液晶显示器(LCD)、投影仪或阴极射线管(CRT)的显示器)、声学部件(例如,扬声器)、触觉部件(例如,振动马达、阻力机构)、其他信号生成器等。用户输入部件1128可以包括字母数字输入部件(例如,键盘、被配置成接收字母数字输入的触摸屏、光学键盘或其他字母数字输入部件)、基于指向的输入部件(例如,鼠标、触摸板、轨迹球、操纵杆、运动传感器或另一指向仪器)、触觉输入部件(例如,物理按钮、提供触摸或触摸手势的定位和力的触摸屏或其他触觉输入部件)、音频输入部件(例如,麦克风)等。
在另一示例中,I/O部件1102可以包括:生物识别部件1130、运动部件1132、环境部件1134、或位置部件1136、以及各种各样的其他部件。例如,生物识别部件1130包括用于检测表达(例如,手表达、面部表达、声音表达、身体姿势或眼睛跟踪)、测量生物信号(例如,血压、心率、体温、出汗或脑波)、识别人(例如,声音识别、视网膜识别、面部识别、指纹识别或基于脑电图的识别)等的部件。运动部件1132包括加速度传感器部件(例如,加速计)、重力传感器部件、旋转传感器部件(例如,陀螺仪)。
环境部件1134包括例如:一个或更多个摄像装置(具有静止图像/照片和视频能力)、照明传感器部件(例如,光度计)、温度传感器部件(例如,检测环境温度的一个或更多个温度计)、湿度传感器部件、压力传感器部件(例如,气压计)、声学传感器部件(例如,检测背景噪声的一个或更多个麦克风)、接近传感器部件(例如,检测附近对象的红外传感器)、气体传感器(例如,为了安全而检测危险气体的浓度或者测量大气中的污染物的气体检测传感器)、或者可以提供与周围物理环境相对应的指示、测量或信号的其他部件。
关于摄像装置,客户端设备102可以具有摄像装置系统,该摄像装置系统包括例如客户端设备102的前表面上的前置摄像装置和客户端设备102的后表面上的后置摄像装置。前置摄像装置可以例如用于捕获客户端设备102的用户的静止图像和视频(例如,“自拍”),然后可以用上述增强数据(例如,过滤器)对该静止图像和视频进行增强。后置摄像装置可以例如用于以更传统的摄像装置模式捕获静止图像和视频,其中这些图像类似地用增强数据进行增强。除了前置摄像装置和后置摄像装置之外,客户端设备102还可以包括用于捕获360°照片和视频的360°摄像装置。
此外,客户端设备102的摄像装置系统可以在客户端设备102的前侧和后侧上包括双后置摄像装置(例如,主摄像装置以及深度感测摄像装置),或者甚至三重、四重或五重后置摄像装置配置。例如,这些多个摄像装置系统可以包括广角摄像装置、超广角摄像装置、长焦摄像装置、微距摄像装置和深度传感器。
位置部件1136包括:定位传感器部件(例如,GPS接收器部件)、海拔传感器部件(例如,检测可以从其得到海拔的气压的高度计或气压计)、取向传感器部件(例如,磁力计)等。
可以使用各种技术来实现通信。I/O部件1102还包括通信部件1138,通信部件1138可操作以经由相应的耦接或连接将机器1100耦接至网络1122或设备1124。例如,通信部件1138可以包括用于与网络1122对接的网络接口部件或另一合适的设备。在另外的示例中,通信部件1138可以包括有线通信部件、无线通信部件、蜂窝通信部件、近场通信(NFC)部件、部件(例如,/>低能耗)、/>部件、以及经由其他模态提供通信的其他通信部件。设备1124可以是另一机器或各种外围设备中的任何外围设备(例如,经由USB耦接的外围设备)。
此外,通信部件1138可以检测标识符或包括可操作以检测标识符的部件。例如,通信部件1138可以包括射频识别(RFID)标签读取器部件、NFC智能标签检测部件、光学读取器部件(例如,用于检测诸如通用产品代码(UPC)条形码的一维条形码、诸如快速反应(QR)码、Aztec码、数据矩阵、数据符号(Dataglyph)、最大码(MaxiCode)、PDF417、超码(UltraCode)、UCC RSS-2D条形码的多维条形码和其他光学码的光学传感器)或声学检测部件(例如,用于识别标记的音频信号的麦克风)。另外,可以经由通信部件1138得到各种信息,例如经由因特网协议(IP)地理定位得出的定位、经由信号三角测量得出的定位、经由检测可以指示特定定位的NFC信标信号得出的定位等。
各种存储器(例如,主存储器1114、静态存储器1116以及处理器1104的存储器)以及存储单元1118可以存储由本文中描述的方法或功能中的任何一个或更多个体现或使用的一组或更多组指令和数据结构(例如,软件)。这些指令(例如,指令1110)在由处理器1104执行的情况下使各种操作实现所公开的示例。
可以经由网络接口设备(例如,通信部件1138中包括的网络接口部件)使用传输介质并且使用若干公知的传输协议中的任意一种传输协议(例如,超文本传输协议(HTTP))通过网络1122来发送或接收指令1110。类似地,可以使用传输介质经由到设备1124的耦接(例如,对等耦接)来发送或接收指令1110。
图12是示出可以安装在本文中描述的设备中的任何一个或更多个上的软件架构1204的框图1200。软件架构1204由诸如包括处理器1220、存储器1226和I/O部件1238的机器1202的硬件来支持。在该示例中,软件架构1204可以被概念化为层的堆栈,其中每个层提供特定功能。软件架构1204包括层,例如操作系统1212、库1210、框架1208和应用1206。在操作上,应用1206通过软件堆栈来激活API调用1250并且响应于API调用1250接收消息1252。
操作系统1212管理硬件资源并且提供公共服务。操作系统1212包括例如:内核1214、服务1216和驱动器1222。内核1214用作硬件层与其他软件层之间的抽象层。例如,内核1214提供存储器管理、处理器管理(例如,调度)、部件管理、联网和安全设置等功能。服务1216可以为其他软件层提供其他公共服务。驱动器1222负责控制底层硬件或与底层硬件对接。例如,驱动器1222可以包括显示驱动器、摄像装置驱动器、低能量驱动器、闪存驱动器、串行通信驱动器(例如,USB驱动器)、驱动器、音频驱动器、电力管理驱动器等。
库1210提供由应用1206使用的公共低级基础设施。库1210可以包括系统库1218(例如,C标准库),系统库1218提供诸如存储器分配功能、字符串操纵功能、数学功能等的功能。另外,库1210可以包括API库1224,例如媒体库(例如,用于支持各种媒体格式的呈现和操纵的库,所述媒体格式例如运动图像专家组4(MPEG4)、高级视频编码(H.264或AVC)、运动图像专家组层3(MP3)、高级音频编码(AAC)、自适应多速率(AMR)音频编解码器、联合图像专家组(JPEG或JPG)或便携式网络图形(PNG))、图形库(例如,用于在显示器上的图形内容中以二维(2D)和三维(3D)呈现的OpenGL框架)、数据库库(例如,提供各种关系数据库功能的SQLite)、Web库(例如,提供网页浏览功能的WebKit)等。库1210还可以包括各种其他库1228,以向应用1206提供许多其他API。
框架1208提供由应用1206使用的公共高级基础设施。例如,框架1208提供各种图形用户界面(GUI)功能、高级资源管理以及高级定位服务。框架1208可以提供可以由应用1206使用的广范的其他API,其中的一些API可以特定于特定的操作系统或平台。
在示例中,应用1206可以包括家庭应用1236、联系人应用1230、浏览器应用1232、书籍阅读器应用1234、定位应用1242、媒体应用1244、消息收发应用1246、游戏应用1248和诸如第三方应用1240的各种各样的其他应用。应用1206是执行程序中限定的功能的程序。可以采用各种编程语言来创建以各种方式构造的应用1206中的一个或更多个,编程语言例如是面向对象的编程语言(例如,Objective-C、Java或C++)或过程编程语言(例如,C语言或汇编语言)。在具体示例中,第三方应用1240(例如,由除了特定平台的供应商以外的实体使用ANDROIDTM或IOSTM软件开发工具包(SDK)开发的应用)可以是在诸如IOSTM、ANDROIDTMPhone的移动操作系统或其他移动操作系统上运行的移动软件。在该示例中,第三方应用1240可以激活由操作系统1212提供的API调用1250以便于本文中描述的功能。
术语表
“载波信号”是指能够存储、编码或携载由机器执行的指令的任何无形介质并且包括数字或模拟通信信号或其他无形介质以便于这样的指令的通信。可以经由网络接口设备使用传输介质在网络上发送或接收指令。
“客户端设备”是指与通信网络对接以从一个或更多个服务器系统或其他客户端设备获得资源的任何机器。客户端设备可以是但不限于移动电话、台式计算机、膝上型计算机、便携式数字助理(PDA)、智能电话、平板计算机、超级本、上网本、膝上型计算机、多处理器系统、基于微处理器或可编程消费电子产品、游戏控制台、机顶盒或用户可以用于接入网络的任何其他通信设备。
“通信网络”是指网络的一个或更多个部分,该网络可以是自组织网络、内联网、外联网、虚拟专用网络(VPN)、局域网(LAN)、无线LAN(WLAN)、广域网(WAN)、无线WAN(WWAN)、城域网(MAN)、因特网、因特网的一部分、公共交换电话网(PSTN)的一部分、普通老式电话服务(POTS)网络、蜂窝电话网络、无线网络、网络、另外类型的网络或者两个或更多个这样的网络的组合。例如,网络或网络的一部分可以包括无线网络或蜂窝网络,并且耦接可以是码分多址(CDMA)连接、全局移动通信系统(GSM)连接或其他类型的蜂窝或无线耦接。在该示例中,耦接可以实现各种类型的数据传输技术中的任何数据传输技术,例如单载波无线电传输技术(1xRTT)、演进数据优化(EVDO)技术、通用分组无线电服务(GPRS)技术、增强型数据速率GSM演进(EDGE)技术、包括3G的第三代合作伙伴计划(3GPP)、第四代无线(4G)网络、通用移动通讯系统(UMTS)、高速分组接入(HSPA)、全球微波接入互操作性(WiMAX)、长期演进(LTE)标准、由各种标准设置组织定义的其他数据传输技术、其他长距离协议或其他数据传输技术。/>
“部件”是指具有以下边界的设备、物理实体或逻辑:所述边界由功能或子例程调用、分支点、API或提供用于对特定处理或控制功能进行划分或模块化的其他技术来定义。部件可以经由其接口与其他部件组合以执行机器处理。部件可以是被设计用于与其他部件一起使用的经封装的功能硬件单元,以及通常执行相关功能中的特定功能的程序的一部分。部件可以构成软件组件(例如,体现在机器可读介质上的代码)或硬件部件。“硬件部件”是能够执行某些操作的有形单元,并且可以以某种物理方式来配置或布置。在各种示例中,可以通过软件(例如,应用或应用部分)将一个或更多个计算机系统(例如,独立计算机系统、客户端计算机系统或服务器计算机系统)或者计算机系统的一个或更多个硬件部件(例如,处理器或处理器组)配置为进行操作以执行如本文描述的某些操作的硬件部件。也可以机械地、电子地或以其任何合适的组合来实现硬件部件。例如,硬件部件可以包括被永久地配置成执行某些操作的专用电路系统或逻辑。硬件部件可以是专用处理器,诸如现场可编程门阵列(FPGA)或专用集成电路(ASIC)。硬件部件还可以包括通过软件临时配置成执行某些操作的可编程逻辑或电路系统。例如,硬件部件可以包括由通用处理器或其他可编程处理器执行的软件。一旦通过这样的软件而配置,硬件部件就成为被唯一地定制成执行所配置功能的特定机器(或机器的特定部件),而不再是通用处理器。将理解的是,可以出于成本和时间考虑来驱动在专用且永久配置的电路系统中或在临时配置(例如,通过软件配置)的电路系统中机械地实现硬件部件的决策。相应地,短语“硬件部件”(或者“硬件实现的部件”)应当被理解成包含有形实体,即为被物理构造、永久配置(例如,硬连线)或临时配置(例如,编程)成以某种方式操作或者执行本文中描述的某些操作的实体。考虑硬件部件被临时配置(例如,被编程)的示例,无需在任一时刻对硬件部件中的每个硬件部件进行配置或实例化。例如,在硬件部件包括通过软件配置成专用处理器的通用处理器的情况下,该通用处理器可以在不同时间处分别被配置为不同的专用处理器(例如,包括不同的硬件部件)。软件相应地配置一个或多个特定处理器以例如在一个时刻处构成特定硬件部件,并且在不同的时刻处构成不同的硬件部件。硬件部件可以向其他硬件部件提供信息以及从其他硬件部件接收信息。因此,所描述的硬件部件可以被认为通信地耦接。在同时存在多个硬件部件的情况下,可以通过在硬件部件中的两个或更多个之间或之中的信号传输(例如,通过适当的电路和总线)来实现通信。在其中多个硬件部件在不同时间处被配置或实例化的示例中,可以例如通过将信息存储在多个硬件部件可以访问的存储器结构中并且在该存储器结构中检索信息来实现这样的硬件部件之间的通信。例如,一个硬件部件可以执行操作,并且将该操作的输出存储在其通信地耦接到的存储器设备中。然后,另外的硬件部件可以在随后的时间访问存储器设备以检索和处理所存储的输出。硬件部件还可以发起与输入设备或输出设备的通信,并且可以对资源进行操作(例如,信息的收集)。本文中描述的示例方法的各种操作可以至少部分地由被临时地配置(例如,由软件)或永久地配置以执行相关操作的一个或更多个处理器来执行。无论是被临时地配置还是永久地配置,这样的处理器可以构成进行操作以执行本文中描述的一个或更多个操作或功能的处理器实现的部件。如本文中使用的,“处理器实现的部件”是指使用一个或更多个处理器实现的硬件部件。类似地,本文中描述的方法可以至少部分地由处理器实现,其中,特定的一个或多个处理器是硬件的示例。例如,方法的操作中的至少一些操作可以由一个或更多个处理器1004或者处理器实现的部件来执行。此外,一个或更多个处理器还可以进行操作以支持“云计算”环境中的相关操作的执行或作为“软件即服务”(SaaS)进行操作。例如,操作中的至少一些操作可以由一组计算机(作为包括处理器的机器的示例)执行,其中,这些操作能够经由网络(例如,因特网)并且经由一个或更多个适当的接口(例如,API)进行访问。操作中的某些操作的执行可以分布在处理器之间,不仅驻留在单个机器内,而且跨多个机器部署。在一些示例中,处理器或处理器实现的部件可以位于单个地理定位中(例如,在家庭环境、办公室环境或服务器群内)。在其他示例中,处理器或处理器实现的部件可以跨若干地理定位而分布。
“计算机可读存储介质”是指机器存储介质和传输介质两者。因此,这些术语包括存储设备/介质和载波/调制数据信号。术语“机器可读介质”、“计算机可读介质”和“装置可读介质”意指相同的事物,并且可以在本公开内容中可互换地使用。
“短暂消息”是指可以在时间有限的持续时间内访问的消息。短暂消息可以是文本、图像、视频等。短暂消息的访问时间可以由消息发送方设置。替选地,访问时间可以是默认设置或者由接收方指定的设置。无论设置技术如何,消息都是暂时的。
“机器存储介质”是指存储可执行指令、例程和数据的单个或多个存储设备和介质(例如,集中式或分布式数据库,以及相关联的高速缓存和服务器)。因此,该术语应被视为包括但不限于固态存储器以及光学和磁性介质,包括处理器内部或外部的存储器。机器存储介质、计算机存储介质和设备存储介质的具体示例包括:非易失性存储器,包括例如半导体存储器设备,例如可擦除可编程只读存储器(EPROM)、电可擦除可编程只读存储器(EEPROM)、FPGA和闪存设备;磁盘,例如内部硬盘和可移动盘;磁光盘;以及CD-ROM和DVD-ROM盘。术语“机器存储介质”、“设备存储介质”、“计算机存储介质”意指相同的事物,并且在本公开内容中可以互换地使用。术语“机器存储介质”、“计算机存储介质”和“设备存储介质”明确地排除了载波、调制数据信号和其他这样的介质,载波、调制数据信号和其他这样的介质中的至少一些被涵盖在术语“信号介质”中。
“非暂态计算机可读存储介质”是指能够存储、编码或携载由机器执行的指令的有形介质。
“信号介质”是指能够存储、编码或携载由机器执行的指令的任何无形介质,并且“信号介质”包括数字或模拟通信信号或其他无形介质以便于软件或数据的通信。术语“信号介质”应当被视为包括任何形式的调制数据信号、载波等。术语“调制数据信号”意指使其特性中的一个或更多个特性以对信号中的信息进行编码的方式来设置或改变的信号。术语“传输介质”和“信号介质”意指相同的事物并且可以在本公开内容中互换使用。

Claims (20)

1.一种方法,包括:
由在设备上运行的消息收发应用显示用于捕获视频的捕获用户界面;
由所述消息收发应用在所述捕获用户界面内提供摄像装置模式选择元素,所述摄像装置模式选择元素能够选择以在第一摄像装置模式与第二摄像装置模式之间切换,所述第一摄像装置模式用于捕获单个视频片段以生成媒体内容项,并且所述第二摄像装置模式用于捕获多个视频片段以进行组合来生成所述媒体内容项;
由所述消息收发应用在所述捕获用户界面内提供音频选择元素,所述音频选择元素能够选择以针对所述媒体内容项选择音频轨道;
由所述消息收发应用经由所述摄像装置模式选择元素接收对所述第二摄像装置模式进行选择的第一用户输入;
由所述消息收发应用经由所述音频选择元素接收对所述音频轨道进行选择的第二用户输入;以及
由所述消息收发应用基于所述第一用户输入和所述第二用户输入使得捕获与所选择的音频轨道相关联的多个视频片段以生成所述媒体内容项。
2.根据权利要求1所述的方法,还包括:
由所述消息收发应用响应于接收到所述第一用户输入和所述第二用户输入,根据所述第二摄像装置模式和所选择的音频轨道对用于视频捕获的所述捕获用户界面进行更新。
3.根据权利要求2所述的方法,其中,经更新的捕获用户界面包括时间轴进度条,所述时间轴进度条被配置成基于捕获的视频片段的数目和每个捕获的视频片段的长度实时更新。
4.根据权利要求3所述的方法,其中,所述时间轴进度条被配置成基于所有捕获的视频片段的总长度超过预设阈值而实时更新。
5.根据权利要求3所述的方法,其中,经更新的捕获用户界面显示与所述时间轴进度条相邻的所述音频轨道的标题。
6.根据权利要求1所述的方法,还包括:
基于所述多个视频片段并且基于所选择的音频轨道生成所述媒体内容项。
7.根据权利要求1所述的方法,其中,接收所述第二用户输入包括:
接收对所述音频选择元素的用户选择;
响应于接收到所述用户选择,在音频轨道列表界面内显示多个可用音频轨道;以及
接收对来自所述音频轨道列表界面内的所述多个可用音频轨道中的所述音频轨道的用户选择。
8.根据权利要求7所述的方法,还包括:
响应于接收到对所述音频轨道的用户选择,提供用于在所述音频轨道内选择开始音频回放的点的音频轨道编辑界面。
9.一种系统,包括:
处理器;以及
存储指令的存储器,所述指令在由所述处理器执行时配置所述处理器以执行包括以下的操作:
由运行的消息收发应用显示用于捕获视频的捕获用户界面;
由所述消息收发应用在所述捕获用户界面内提供摄像装置模式选择元素,所述摄像装置模式选择元素能够选择以在第一摄像装置模式与第二摄像装置模式之间切换,所述第一摄像装置模式用于捕获单个视频片段以生成媒体内容项,并且所述第二摄像装置模式用于捕获多个视频片段以进行组合来生成所述媒体内容项;
由所述消息收发应用在所述捕获用户界面内提供音频选择元素,所述音频选择元素能够选择以针对所述媒体内容项选择音频轨道;
由所述消息收发应用经由所述摄像装置模式选择元素接收对所述第二摄像装置模式进行选择的第一用户输入;
由所述消息收发应用经由所述音频选择元素接收对所述音频轨道进行选择的第二用户输入;以及
由所述消息收发应用基于所述第一用户输入和所述第二用户输入使得捕获与所选择的音频轨道相关联的多个视频片段以生成所述媒体内容项。
10.根据权利要求9所述的系统,所述操作还包括:
由所述消息收发应用响应于接收到所述第一用户输入和所述第二用户输入,根据所述第二摄像装置模式和所选择的音频轨道对用于视频捕获的所述捕获用户界面进行更新。
11.根据权利要求10所述的系统,其中,经更新的捕获用户界面包括时间轴进度条,所述时间轴进度条被配置成基于捕获的视频片段的数目和每个捕获的视频片段的长度实时更新。
12.根据权利要求11所述的系统,其中,所述时间轴进度条被配置成基于所有捕获的视频片段的总长度超过预设阈值而实时更新。
13.根据权利要求11所述的系统,其中,经更新的捕获用户界面显示与所述时间轴进度条相邻的所述音频轨道的标题。
14.根据权利要求9所述的系统,所述操作还包括:
基于所述多个视频片段并且基于所选择的音频轨道生成所述媒体内容项。
15.根据权利要求9所述的系统,其中,接收所述第二用户输入包括:
接收对所述音频选择元素的用户选择;
响应于接收到所述用户选择,在音频轨道列表界面内显示多个可用音频轨道;以及
接收对来自所述音频轨道列表界面内的所述多个可用音频轨道中的所述音频轨道的用户选择。
16.根据权利要求15所述的系统,所述操作还包括:
响应于接收到对所述音频轨道的用户选择,提供用于在所述音频轨道内选择开始音频回放的点的音频轨道编辑界面。
17.一种非暂态计算机可读存储介质,所述计算机可读存储介质包括指令,所述指令在由计算机执行时使所述计算机执行包括以下的操作:
由在设备上运行的消息收发应用显示用于捕获视频的捕获用户界面;
由所述消息收发应用在所述捕获用户界面内提供摄像装置模式选择元素,所述摄像装置模式选择元素能够选择以在第一摄像装置模式与第二摄像装置模式之间切换,所述第一摄像装置模式用于捕获单个视频片段以生成媒体内容项,并且所述第二摄像装置模式用于捕获多个视频片段以进行组合来生成所述媒体内容项;
由所述消息收发应用在所述捕获用户界面内提供音频选择元素,所述音频选择元素能够选择以针对所述媒体内容项选择音频轨道;
由所述消息收发应用经由所述摄像装置模式选择元素接收对所述第二摄像装置模式进行选择的第一用户输入;
由所述消息收发应用经由所述音频选择元素接收对所述音频轨道进行选择的第二用户输入;以及
由所述消息收发应用基于所述第一用户输入和所述第二用户输入使得捕获与所选择的音频轨道相关联的多个视频片段以生成所述媒体内容项。
18.根据权利要求17所述的计算机可读介质,其中,所述操作还包括:
由所述消息收发应用响应于接收到所述第一用户输入和所述第二用户输入,根据所述第二摄像装置模式和所选择的音频轨道对用于视频捕获的所述捕获用户界面进行更新。
19.根据权利要求18所述的计算机可读介质,其中,经更新的捕获用户界面包括时间轴进度条,所述时间轴进度条被配置成基于捕获的视频片段的数目和每个捕获的视频片段的长度实时更新。
20.根据权利要求19所述的计算机可读介质,其中,所述时间轴进度条被配置成基于所有捕获的视频片段的总长度超过预设阈值而实时更新。
CN202180088064.XA 2020-12-30 2021-12-21 针对多视频片段捕获选择音频 Pending CN116710881A (zh)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US202063132172P 2020-12-30 2020-12-30
US63/132,172 2020-12-30
US17/556,802 US20220206738A1 (en) 2020-12-30 2021-12-20 Selecting an audio track in association with multi-video clip capture
US17/556,802 2021-12-20
PCT/US2021/064704 WO2022146798A1 (en) 2020-12-30 2021-12-21 Selecting audio for multi-video clip capture

Publications (1)

Publication Number Publication Date
CN116710881A true CN116710881A (zh) 2023-09-05

Family

ID=82119071

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202180088064.XA Pending CN116710881A (zh) 2020-12-30 2021-12-21 针对多视频片段捕获选择音频

Country Status (4)

Country Link
US (1) US20220206738A1 (zh)
EP (1) EP4272208A1 (zh)
KR (1) KR20230124714A (zh)
CN (1) CN116710881A (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11861800B2 (en) 2020-12-30 2024-01-02 Snap Inc. Presenting available augmented reality content items in association with multi-video clip capture
US11924540B2 (en) 2020-12-30 2024-03-05 Snap Inc. Trimming video in association with multi-video clip capture
US12002135B2 (en) 2021-12-20 2024-06-04 Snap Inc. Adding time-based captions to captured video within a messaging system

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11741995B1 (en) * 2021-09-29 2023-08-29 Gopro, Inc. Systems and methods for switching between video views
CN115022545B (zh) * 2022-06-02 2024-04-02 北京字跳网络技术有限公司 用于内容拍摄的方法、装置、设备和存储介质

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11861800B2 (en) 2020-12-30 2024-01-02 Snap Inc. Presenting available augmented reality content items in association with multi-video clip capture
US11924540B2 (en) 2020-12-30 2024-03-05 Snap Inc. Trimming video in association with multi-video clip capture
US12002135B2 (en) 2021-12-20 2024-06-04 Snap Inc. Adding time-based captions to captured video within a messaging system

Also Published As

Publication number Publication date
US20220206738A1 (en) 2022-06-30
EP4272208A1 (en) 2023-11-08
KR20230124714A (ko) 2023-08-25

Similar Documents

Publication Publication Date Title
CN115443641A (zh) 将第一用户界面内容组合到第二用户界面中
US11924540B2 (en) Trimming video in association with multi-video clip capture
CN116671121A (zh) 用于多视频片段捕获的ar内容
KR102577630B1 (ko) 메시징 애플리케이션에서의 증강 현실 콘텐츠의 디스플레이
US20220210328A1 (en) Camera mode for capturing multiple video clips within a messaging system
US20220206738A1 (en) Selecting an audio track in association with multi-video clip capture
CN116783575A (zh) 媒体内容检测和管理
CN116685995A (zh) 向捕获的视频添加基于时间的字幕
CN116438788A (zh) 媒体内容回放和评论管理
CN115606190A (zh) 显示增强现实内容与教程内容
US20240171849A1 (en) Trimming video in association with multi-video clip capture
CN117337430A (zh) 消息系统内根据扫描操作的快捷方式
CN116349215A (zh) 利用微声音剪辑来聊天
CN116057917A (zh) 记录的声音的缩略图
CN117501675A (zh) 呈现由消息应用从第三方资源接收的内容
CN116648895A (zh) 用于捕获多个视频片段的摄像装置模式
KR20230128068A (ko) 캡처된 비디오에 시간-기반 캡션들을 추가
KR20230121918A (ko) 다수의 비디오 클립을 캡처하기 위한 카메라 모드
WO2022146798A1 (en) Selecting audio for multi-video clip capture
US20240040236A1 (en) Trimming video within a messaging system
US20220094653A1 (en) Augmenting image content with sound
CN117396849A (zh) 在消息系统内将功能组合成快捷方式
CN117121461A (zh) 用户存在指示数据管理
CN116235500A (zh) 生成用于分享到外部应用的媒体内容项
CN116210226A (zh) 基于轮次的协作播放列表

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination