CN104244100B - 进度条控制方法和装置 - Google Patents

进度条控制方法和装置 Download PDF

Info

Publication number
CN104244100B
CN104244100B CN201310233626.2A CN201310233626A CN104244100B CN 104244100 B CN104244100 B CN 104244100B CN 201310233626 A CN201310233626 A CN 201310233626A CN 104244100 B CN104244100 B CN 104244100B
Authority
CN
China
Prior art keywords
progress
current buffer
progress bar
data
buffering
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.)
Active
Application number
CN201310233626.2A
Other languages
English (en)
Other versions
CN104244100A (zh
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.)
Tencent Technology Shenzhen Co Ltd
Original Assignee
Tencent Technology Shenzhen Co Ltd
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 Tencent Technology Shenzhen Co Ltd filed Critical Tencent Technology Shenzhen Co Ltd
Priority to CN201310233626.2A priority Critical patent/CN104244100B/zh
Priority to PCT/CN2013/090469 priority patent/WO2014198115A1/en
Priority to US14/493,935 priority patent/US20150012828A1/en
Publication of CN104244100A publication Critical patent/CN104244100A/zh
Application granted granted Critical
Publication of CN104244100B publication Critical patent/CN104244100B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • 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/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/44004Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving video buffer management, e.g. video decoder buffer or video display buffer
    • 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/47217End-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 controlling playback functions for recorded or on-demand content, e.g. using progress bars, mode or play-point indicators or bookmarks

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Human Computer Interaction (AREA)
  • Databases & Information Systems (AREA)
  • Computer And Data Communications (AREA)
  • Information Transfer Between Computers (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)

Abstract

本发明提供了一种进度条控制方法和装置。所述方法包括:获取应用中数据流的实际缓冲进度和当前缓冲进度;对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;根据所述进度条变化量刷新所述应用的进度条;显示所述刷新后的进度条。所述装置包括:缓冲进度获取模块,用于获取应用中数据流的实际缓冲进度和当前缓冲进度;处理模块,用于对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;刷新模块,用于根据所述进度条变化量刷新所述应用的进度条;显示模块,用于显示所述刷新后的进度条。采用本发明能有效控制进度条,以使得进度条在反馈进度的同时降低网络状况等因素对进度条显示的影响。

Description

进度条控制方法和装置
技术领域
本发明涉及互联网应用技术,特别是涉及一种进度条控制方法及装置。
背景技术
各种应用中常常通过进度条实现进度反馈,例如,在上传文件的过程中,通过进度条的变化来实时反馈当前的上传进度;在线视频的播放过程中,也常常通过进度条来实时反馈当前的加载进度。
然而,应用中进度条反馈的进度将受到数据流流量的影响,单位时间内数据流的流量越大,则加载进度加载速度则越快,例如,在网络状况好的情况下数据下载速度比较快,进而使得进度条中展现的加载也将不断地出现突变,但是,在网络状况较差的情况之下,数据下载速度将比较慢,进度条中展现的加载进度的变化也较为缓慢,因此,应用中的进度条所反馈的进度大都随着网络状况的好与坏等因素而出现骤变,无法有效控制进度条,以使得进度条在反馈缓冲进度的同时,降低网络状况等因素对进度条显示的影响。
发明内容
基于此,有必要针对应用中的进度条所反馈的进度大都随着网络状况的好与坏等因素而出现骤变,无法有效控制进度条的技术问题,提供一种能有效控制进度条,以使得进度条在反馈进度的同时降低网络状况等因素对进度条显示的影响的进度条控制方法。
此外,还有必要提供一种能有效控制进度条,以使得进度条在反馈进度的同时降低网络状况等因素对进度条显示的影响的进度条控制装置。
一种进度条控制方法,包括如下步骤:
获取应用中数据流的实际缓冲进度和当前缓冲进度;
对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;
根据所述进度条变化量刷新所述应用的进度条;
显示所述刷新后的进度条。
一种进度条控制装置,其特征在于,包括:
缓冲进度获取模块,用于获取应用中数据流的实际缓冲进度和当前缓冲进度;
处理模块,用于对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;
刷新模块,用于根据所述进度条变化量刷新所述应用的进度条;
显示模块,用于显示所述刷新后的进度条。
上述进度条控制方法和装置,在应用进行数据缓冲的过程中,将获取应用中数据的实际缓冲进度和当前缓冲进度,对实际缓冲进度和当前缓冲进度之间的差值进行降价处理得到进度条变化量,根据得到的进度条变化量刷新应用中的进度条,并显示,以反馈应用中的数据缓冲进度,由于进度条变化量是将实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到的,该差值受到外界因素,例如网络状况的影响较大,因此,对该差值进行降阶处理将相应地降低了外界因素的影响,进而使得根据进度变化量刷新后的进度条既反馈了应用中数据缓冲的进度,又降低了网络状况等外界因素的影响,实现了对进度条的有效控制。
附图说明
图1为一个实施例中进度条控制方法的流程图;
图2为图1中根据进度条变化量刷新应用的进度条的方法流程图;
图3为另一个实施例中进度条控制方法的流程图;
图4为一个实施例中进度条控制装置的结构示意图;
图5为图4中刷新模块的结构示意图;
图6为一个实施例中进度条控制装置的结构示意图。
具体实施方式
如图1所示,在一个实施例中,一种进度条控制方法,包括如下步骤:
步骤S110,获取应用中数据流的实际缓冲进度和当前缓冲进度。
本实施例中,该应用可以是需要进行数据缓冲和加载,并设置了进度条的应用,例如,该应用可为在线播放媒体文件的应用;也可以是正在加载页面的应用,该应用的加载页面中设置了用于反馈进度的进度条,在此不一一进行列举。
数据流的实际缓冲进度是将是数据流的下载进度或者数据流由本地缓冲到内存的进度;当前缓冲进度则是应用的进度条所对应的数据流缓冲进度。
从应用所进行的数据流缓冲获取得到实际缓冲进度,并由应用的进度条得到当前缓冲进度。
应用中随着数据流的缓冲,所对应的实际缓冲进度和当前缓冲进度都将是不断变化的,例如,浏览器在加载网页游戏的过程中,实际缓冲进度将随着数据流的下载进度发生变化,而当前缓冲进度则是页面中进度条所对应的进度。
进一步的,随着数据流来源的不同,数据流的实际缓冲进度可以是数据流的下载进度,也可以是数据流由本地缓冲到内存的进度。若数据流来源于网络服务器,则应用是从网络服务器中拉取数据,相应的,实际缓冲进度即为从网络服务器中进行下载的下载进度;若数据流是存储于本地的数据,则不可能一次性缓冲到内存中,也需要一定的时间加载到内存中,相应的,实际缓冲进度为加载到内存的数据量与实际数据量之间的占比。
步骤S130,对实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量。
本实施例中,将实际缓冲进度和当前缓冲进度相减,得到实际缓冲进度和当前缓冲进度之间的差值,并对该差值进行降阶处理得到进度条变化量,其中,降阶处理得到的进度条变化量是不大于该差值的,用于指示进度条的实际变化量。
对实际缓冲进度和当前缓冲进度之间的差值进行降阶处理,将有利于降低外界因素的影响,例如网络状况好坏对进度条的影响。具体的,在网络状况非常好的情况下,实际缓冲进度在网络状况的影响下飞速变化,而当前缓冲进度则是进度条中反馈的,是与变化前的实际缓冲进度相对应的,此时,将造成实际缓冲进度和当前缓冲进度之间的差值较大,也就是说,网络状况越好,则差值越大,直接根据这一差值进行进度条的刷新将会出现进度条中的骤变,因此,对该差值进行降阶处理,以根据降阶处理后得到的进度条变化量进行进度条的刷新,从而使得进度条中的当前缓冲进度是平滑递增的。
进一步的,将预先设定进度条的最佳变化值,进而根据最佳变化值对差值进行降价处理。根据实际需要,用于实现差值的降价处理的算法是可以灵活变换的,例如,可以是将差值除以2的阶乘,也可以是对差值进行取余数操作,还可以是先将差值进行取余数操作,然后再除以2的阶乘,在此不一一进行列举。
步骤S150,根据进度条变化量刷新应用的进度条。
本实施例中,通过进度条变化量即可获知进度条的实际变化量,进而根据这一实际变化量即可刷新应用的进度条。
步骤S170,显示刷新后的进度条。
本实施例中,将刷新后的进度条显示于应用所在的页面中,以向用户反馈进度。
上述进度条控制方法中,对应用中数据流的实际缓冲进度,在进度条中延迟加载,以使得进度条中的当前缓冲进度平滑变化,呈现一个较为平滑的数据流缓冲过程,使得实现上述进度条控制方法的进度条组件不受外部因素的影响,提高了自适应能力。
如图2所示,在一个实施例中,上述步骤S150包括:
步骤S151,根据进度条变化量对当前缓冲进度进行自增运算。
本实施例中,通过降阶处理得到了进度条变化量之后,将进行自增运算,将获取的当前缓冲进度和进度条变化量之和作为新的当前缓冲进度。
步骤S153,按照自增运算得到的当前缓冲进度刷新应用的进度条中反馈的当前缓冲进度。
本实施例中,将进度条中的进度刷新为自增运算之后的当前缓冲进度,以反馈应用中的数据流缓冲过程。
如图3所示,在一个实施例中,上述进度条控制方法还包括:
步骤S210,随着应用对缓冲的数据流进行的使用,获取应用中的数据使用进度。
本实施例中,在将网络服务器中的数据流下载的过程中,或者将存储于本地的数据流加载到内存的过程中,应用将使用已经完成缓冲的数据流。
例如,对于在线播放媒体文件的应用而言,从网络服务器下载得到媒体文件的视频流或音频流的过程中,将在播放界面中播放已经下载的视频流或音频流,此时,将获取播放界面中视频流或音频流的播放进度,该进度即为数据使用进度。
对于游戏应用而言,从网络服务器下载得到游戏的数据流,或者读取本地的数据流,并缓冲到内存的过程中数据流而言,将使用已经下载或者完成缓冲的数据流进行游戏页面的加载,此时,将获取游戏页面的加载进度,该进度即为数据使用进度。
步骤S230,对当前缓冲进度和数据使用进度进行差值计算,得到当前缓冲进度和数据使用进度之间的差值。
本实施例中,由于应用在使用数据的过程中所使用的数据流必定的已经完成缓冲的数据流,因此,数据使用进度必然是小于或者等于当前缓冲进度的,并且数据使用进度和当前缓冲进度之间必将呈现一个追赶的态势。
步骤S250,判断该差值是否小于阈值,若是,则进入步骤S270,若否,则进入步骤S150。
本实施例中,若判断到当前缓冲进度和数据使用进度之间的差值是小于阈值的,则说明已经完成缓冲的数据流即将使用完毕,此时,将暂停使用,以等待数据流的缓冲,直至新的当前缓冲进度与当前未发生变化的数据使用进度之间的差值大于阈值。
例如,对于在线播放媒体文件的应用而言,若判断到当前缓冲进度和数据使用进度之间的差值小于阈值,则说明当前播放的媒体文件所缓冲的数据流即将播放完毕,因此,将暂停播放,以等待媒体文件未缓冲的数据流完成进行缓冲,直至新的当前缓冲进度与当前未发生变化的数据使用进度之间的差值大于阈值。
步骤S270,暂停对缓冲的数据流的使用,使数据使用进度保持不变。
在一个实施例中,上述步骤S150包括:根据数据使用进度刷新应用的进度条中反馈的数据使用进度。
本实施例中,根据不断变化的数据使用进度对应用的进度条进行刷新,以使得进度条反馈当前的数据使用进度。
上述进度条控制方法中,通过进度条反馈应用中的当前缓冲进度和数据使用进度,因此通过一个进度条组件即可同时反馈应用中数据流的当前缓冲进度和数据使用进度,实现了进度条的双缓冲功能,不再需要设置两个进度条组件来分别反馈应用中数据流的当前缓冲进度和数据使用进度。
在另一个实施例中,上述进度条控制方法还包括按照预设的频率触发进行实际缓冲进度、当前缓冲进度和数据使用进度的获取。
本实施例中,预先设定一定的频率,以按照该频率触发获取应用中数据流的实际缓冲进度、当前缓冲进度和数据使用进度,进而使得进度条中当前缓冲进度和数据使用进度的刷新是按照预先设定的频率进行的。
下面结合一个具体的实施例来详细描述上述进度条控制方法。该实施例中,以在线视频播放应用为例,通过在线视频播放应用播放视频文件的过程中,将从网络服务器拉取视频流,此时,视频流的下载进度即为实际缓冲进度。
当前缓冲进度是在线视频播放应用在进度条中对实际缓冲进度进行延迟加载所对应的进度。
在视频流的下载和播放过程中,获取实际缓冲进度和当前缓冲进度,以对实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量,根据进度条变化量刷新应用中的当前缓冲进度。
此外,也将获取进度条中的数据使用进度,由于数据使用进度和当前缓冲进度之间的约束关系是数据使用进度不会超出当前缓冲进度,因此,判断当前缓冲进度和数据使用进度之间的差值是否小于阈值,若否,则以当前视频流的播放进度作为数据使用进度,进而刷新进度条。
通过上述在线视频播放应用中对进度条的控制,使得进度条组件在同是反馈当前缓冲进度和数据使用进度的同时,当前缓冲进度的变化将是平滑过渡的,例如,对用户而言,将查看到进度条中10%至40%是较为均衡地划分为多次发生变化的,然后40%至80%也将是较为均衡地划分为多次来刷新的,而进度条组件所反馈的数据使用进度将追赶着当前缓冲进度,实现了进度条的自适应功能。
如图4所示,在一个实施例中,一种进度条控制装置,包括缓冲进度获取模块110、处理模块130、刷新模块150和显示模块170。
缓冲进度获取模块110,用于获取应用中数据流的实际缓冲进度和当前缓冲进度。
本实施例中,该应用可以是需要进行数据缓冲和加载,并设置了进度条的应用,例如,该应用可为在线播放媒体文件的应用;也可以是正在加载页面的应用,该应用的加载页面中设置了用于反馈进度的进度条,在此不一一进行列举。
数据流的实际缓冲进度是将是数据流的下载进度或者数据流由本地缓冲到内存的进度;当前缓冲进度则是应用的进度条所对应的数据流缓冲进度。
缓冲进度获取模块110从应用所进行的数据流缓冲获取得到实际缓冲进度,并由应用的进度条得到当前缓冲进度。
应用中随着数据流的缓冲,所对应的实际缓冲进度和当前缓冲进度都将是不断变化的,例如,浏览器在加载网页游戏的过程中,实际缓冲进度将随着数据流的下载进度发生变化,而当前缓冲进度则是页面中进度条所对应的进度。
进一步的,随着数据流来源的不同,数据流的实际缓冲进度可以是数据流的下载进度,也可以是数据流由本地缓冲到内存的进度。若数据流来源于网络服务器,则应用是从网络服务器中拉取数据,相应的,实际缓冲进度即为从网络服务器中进行下载的下载进度;若数据流是存储于本地的数据,则不可能一次性缓冲到内存中,也需要一定的时间加载到内存中,相应的,实际缓冲进度为加载到内存的数据量与实际数据量之间的占比。
处理模块130,用于对实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量。
本实施例中,处理模块130将实际缓冲进度和当前缓冲进度相减,得到实际缓冲进度和当前缓冲进度之间的差值,并对该差值进行降阶处理得到进度条变化量,其中,降阶处理得到的进度条变化量是不大于该差值的,用于指示进度条的实际变化量。
处理模块130对实际缓冲进度和当前缓冲进度之间的差值进行降阶处理,将有利于降低外界因素的影响,例如网络状况好坏对进度条的影响。具体的,在网络状况非常好的情况下,实际缓冲进度在网络状况的影响下飞速变化,而当前缓冲进度则是进度条中反馈的,是与变化前的实际缓冲进度相对应的,此时,将造成实际缓冲进度和当前缓冲进度之间的差值较大,也就是说,网络状况越好,则差值越大,直接根据这一差值进行进度条的刷新将会出现进度条中的骤变,因此,处理模块130对该差值进行降阶处理,以根据降阶处理后得到的进度条变化量进行进度条的刷新,从而使得进度条中的当前缓冲进度是平滑递增的。
进一步的,处理模块130将预先设定进度条的最佳变化值,进而根据最佳变化值对差值进行降价处理。根据实际需要,用于实现差值的降价处理的算法是可以灵活变换的,例如,可以是将差值除以2的阶乘,也可以是对差值进行取余数操作,还可以是先将差值进行取余数操作,然后再除以2的阶乘,在此不一一进行列举。
刷新模块150,用于根据进度条变化量刷新应用的进度条。
本实施例中,刷新模块150通过进度条变化量即可获知进度条的实际变化量,进而根据这一实际变化量即可刷新应用的进度条。
显示模块170,用于显示刷新后的进度条。
本实施例中,显示模块170将刷新后的进度条显示于应用所在的页面中,以向用户反馈进度。
上述进度条控制装置中,对应用中数据流的实际缓冲进度,在进度条中延迟加载,以使得进度条中的当前缓冲进度平滑变化,呈现一个较为平滑的数据流缓冲过程,使得实现上述进度条控制方法的进度条组件不受外部因素的影响,提高了自适应能力。
如图5所示,在一个实施例中,上述刷新模块150包括自增运算单元151和缓冲刷新单元153。
自增运算单元151,用于根据进度条变化量对当前缓冲进度进行自增运算。
本实施例中,通过降阶处理得到了进度条变化量之后,自增运算单元151将进行自增运算,将获取的当前缓冲进度和进度条变化量之和作为新的当前缓冲进度。
缓冲刷新单元153,用于按照自增运算得到当前缓冲进度刷新应用的进度条中反馈的当前缓冲进度。
本实施例中,缓冲刷新单元153将进度条中的进度刷新为自增运算之后的当前缓冲进度,以反馈应用中的数据流缓冲过程。
如图6所示,在一个实施例中,上述进度条控制装置还包括使用进度获取模块210、差值计算模块230、判断模块250和暂停模块270。
使用进度获取模块210,用于随着应用对缓冲的数据流进行的使用,获取应用中的数据使用进度;
本实施例中,在将网络服务器中的数据流下载的过程中,或者将存储于本地的数据流加载到内存的过程中,应用将使用已经完成缓冲的数据流。
例如,对于在线播放媒体文件的应用而言,从网络服务器下载得到媒体文件的视频流或音频流的过程中,将在播放界面中播放已经下载的视频流或音频流,此时,使用进度获取模块210将获取播放界面中视频流或音频流的播放进度,该进度即为数据使用进度。
对于游戏应用而言,从网络服务器下载得到游戏的数据流,或者读取本地的数据流,并缓冲到内存的过程中数据流而言,将使用已经下载或者完成缓冲的数据流进行游戏页面的加载,此时,使用进度获取模块210将获取游戏页面的加载进度,该进度即为数据使用进度。
差值计算模块230,用于对当前缓冲进度和数据使用进度进行差值计算,得到当前缓冲进度和数据使用进度之间的差值。
本实施例中,由于应用在使用数据的过程中所使用的数据流必定的已经完成缓冲的数据流,因此,数据使用进度必然是小于或者等于当前缓冲进度的,并且数据使用进度和当前缓冲进度之间必将呈现一个追赶的态势。
判断模块250,用于判断差值是否小于阈值,若是,则通知暂停模块270,若否则通知刷新模块150。
本实施例中,若判断模块250判断到当前缓冲进度和数据使用进度之间的差值是小于阈值的,则说明已经完成缓冲的数据流即将使用完毕,此时,将通知暂停模块270暂停使用,以等待数据流的缓冲,直至新的当前缓冲进度与当前未发生变化的数据使用进度之间的差值大于阈值。
例如,对于在线播放媒体文件的应用而言,若判断模块250到当前缓冲进度和数据使用进度之间的差值小于阈值,则说明当前播放的媒体文件所缓冲的数据流即将播放完毕,因此,将通知暂停模块270暂停播放,以等待媒体文件未缓冲的数据流完成进行缓冲,直至新的当前缓冲进度与当前未发生变化的数据使用进度之间的差值大于阈值。
暂停模块270,用于暂停对缓冲的数据流的使用,使数据使用进度保持不变。
上述刷新模块150还用于根据使用进度刷新应用的进度条中反馈的数据使用进度。
本实施例中,刷新模块150根据不断变化的数据使用进度对应用的进度条进行刷新,以使得进度条反馈当前的数据使用进度。
上述进度条控制装置中,通过进度条反馈应用中的当前缓冲进度和数据使用进度,因此通过一个进度条组件即可同时反馈应用中数据流的当前缓冲进度和数据使用进度,实现了进度条的双缓冲功能,不再需要设置两个进度条组件来分别反馈应用中数据流的当前缓冲进度和数据使用进度。
在一个实施例中,上述进度条控制装置还包括定时器。该定时器用于按照预设的频率触发进行实际缓冲进度、当前缓冲进度和数据使用进度的获取。
本实施例中,预先设定一定的频率,定时器按照该频率触发获取应用中数据流的实际缓冲进度、当前缓冲进度和数据使用进度,进而使得进度条中当前缓冲进度和数据使用进度的刷新是按照预先设定的频率进行的。
上述进度条控制方法和装置,在应用进行数据缓冲的过程中,将获取应用中数据的实际缓冲进度和当前缓冲进度,对实际缓冲进度和当前缓冲进度之间的差值进行降价处理得到进度条变化量,根据得到的进度条变化量刷新应用中的进度条,并显示,以反馈应用中的数据缓冲进度,由于进度条变化量是将实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到的,该差值受到外界因素,例如网络状况的影响较大,因此,对该差值进行降阶处理将相应地降低了外界因素的影响,进而使得根据进度变化量刷新后的进度条既反馈了应用中数据缓冲的进度,又降低了网络状况等外界因素的影响,实现了对进度条的有效控制。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,所述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)或随机存储记忆体(Random AccessMemory,RAM)等。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。

Claims (8)

1.一种进度条控制方法,包括如下步骤:
获取应用中数据流的实际缓冲进度和当前缓冲进度;其中,所述数据流的实际缓冲进度为数据流的下载进度或者数据流由本地缓冲到内存的进度,所述当前缓冲进度为所述应用的进度条所对应的数据流缓冲进度;
对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;其中,降阶处理是指对所述实际缓冲进度和当前缓冲进度之间的差值进行处理,使处理后得到的进度条变化量小于或等于所述差值;
根据所述进度条变化量刷新所述应用的进度条;
显示所述刷新后的进度条。
2.根据权利要求1所述的方法,其特征在于,所述根据所述进度条变化量刷新所述应用的进度条的步骤包括:
根据所述进度条变化量对所述当前缓冲进度进行自增运算;
按照自增运算得到的当前缓冲进度刷新所述应用的进度条中反馈的当前缓冲进度,其中,所述自增运算是指将所述当前缓冲进度和进度条变化量之和作为新的当前缓冲进度的运算。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
随着所述应用对缓冲的数据流进行的使用,获取应用中的数据使用进度;
对所述当前缓冲进度和数据使用进度进行差值计算,得到当前缓冲进度和数据使用进度之间的差值;
判断所述差值是否小于阈值,若是,则暂停对缓冲的数据流的使用,使所述数据使用进度保持不变,若否,则根据所述数据使用进度刷新所述应用的进度条中反馈的数据使用进度。
4.根据权利要求3所述的方法,其特征在于,所述方法还包括:
按照预设的频率触发进行实际缓冲进度、当前缓冲进度和数据使用进度的获取。
5.一种进度条控制装置,其特征在于,包括:
缓冲进度获取模块,用于获取应用中数据流的实际缓冲进度和当前缓冲进度;其中,所述数据流的实际缓冲进度为数据流的下载进度或者数据流由本地缓冲到内存的进度,所述当前缓冲进度为所述应用的进度条所对应的数据流缓冲进度;
处理模块,用于对所述实际缓冲进度和当前缓冲进度之间的差值进行降阶处理得到进度条变化量;其中,降阶处理是指对所述实际缓冲进度和当前缓冲进度之间的差值进行处理,使得处理后得到的进度条变化量小于或等于所述差值;
刷新模块,用于根据所述进度条变化量刷新所述应用的进度条;
显示模块,用于显示所述刷新后的进度条。
6.根据权利要求5所述的装置,其特征在于,所述刷新模块包括:
自增运算单元,用于根据所述进度条变化量对所述当前缓冲进度进行自增运算;
缓冲刷新单元,用于按照自增运算得到的当前缓冲进度刷新所述应用的进度条中反馈的当前缓冲进度,其中,所述自增运算是指将所述当前缓冲进度和进度条变化量之和作为新的当前缓冲进度的运算。
7.根据权利要求5所述的装置,其特征在于,所述装置还包括:
使用进度获取模块,用于随着所述应用对缓冲的数据流进行的使用,获取应用中的数据使用进度;
差值计算模块,用于对所述当前缓冲进度和数据使用进度进行差值计算,得到当前缓冲进度和数据使用进度之间的差值;
判断模块,用于判断所述差值是否小于阈值,若是,则通知暂停模块,若否,则通知所述刷新模块,所述刷新模块还用于根据所述数据使用进度刷新所述应用的进度条中反馈的数据使用进度;
所述暂停模块用于暂停对缓冲的数据流的使用,使所述数据使用进度保持不变。
8.根据权利要求7所述的装置,其特征在于,所述装置还包括:
定时器,用于按照预设的频率触发进行实际缓冲进度、当前缓冲进度和数据使用进度的获取。
CN201310233626.2A 2013-06-13 2013-06-13 进度条控制方法和装置 Active CN104244100B (zh)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN201310233626.2A CN104244100B (zh) 2013-06-13 2013-06-13 进度条控制方法和装置
PCT/CN2013/090469 WO2014198115A1 (en) 2013-06-13 2013-12-25 Method, device and computer-readable storage medium for progress bar control
US14/493,935 US20150012828A1 (en) 2013-06-13 2014-09-23 Method, device and computer-readable storage medium for progress bar control

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201310233626.2A CN104244100B (zh) 2013-06-13 2013-06-13 进度条控制方法和装置

Publications (2)

Publication Number Publication Date
CN104244100A CN104244100A (zh) 2014-12-24
CN104244100B true CN104244100B (zh) 2018-09-11

Family

ID=52021609

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201310233626.2A Active CN104244100B (zh) 2013-06-13 2013-06-13 进度条控制方法和装置

Country Status (3)

Country Link
US (1) US20150012828A1 (zh)
CN (1) CN104244100B (zh)
WO (1) WO2014198115A1 (zh)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104821963B (zh) * 2015-04-30 2019-02-19 华为技术有限公司 推荐信息展示方法及装置
CN104991750A (zh) * 2015-06-30 2015-10-21 天脉聚源(北京)科技有限公司 一种动态显示数据变化的方法及装置
CN105979344A (zh) * 2015-11-27 2016-09-28 乐视致新电子科技(天津)有限公司 一种多媒体播放方法及播放器
CN107193541A (zh) * 2016-03-15 2017-09-22 广州市动景计算机科技有限公司 任务执行进度的显示方法及装置
CN109743611A (zh) * 2018-11-30 2019-05-10 新视家科技(北京)有限公司 播放进度展现方法及其装置、电子设备、计算机可读介质
CN110022493B (zh) * 2019-05-21 2020-10-09 北京字节跳动网络技术有限公司 播放进度显示方法、装置、电子设备和存储介质
CN113672249A (zh) * 2020-05-15 2021-11-19 青岛海信移动通信技术股份有限公司 移动终端及其下载界面更新方法
CN112435308B (zh) * 2020-11-30 2023-11-14 成都新潮传媒集团有限公司 环形进度条的绘制方法、装置及存储介质

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1960471A (zh) * 2005-11-01 2007-05-09 三星电子株式会社 在便携式终端中搜索运动画面的方法和设备
CN102207863A (zh) * 2011-04-01 2011-10-05 奇智软件(北京)有限公司 一种进度条前进的控制方法及装置
CN103136089A (zh) * 2011-11-25 2013-06-05 腾讯科技(深圳)有限公司 一种进度条显示方法和装置

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6275987B1 (en) * 1998-11-05 2001-08-14 International Business Machines Corporation Adaptive, predictive progress indicator
US6927770B2 (en) * 2000-01-05 2005-08-09 Apple Computer Inc. Interface providing continuous feedback on task progress in a computer operating system
US6865717B2 (en) * 2001-05-30 2005-03-08 International Business Machines Corporation Method, system, and program for generating a progress indicator
US7475358B2 (en) * 2006-02-14 2009-01-06 International Business Machines Corporation Alternate progress indicator displays
EP2525281B1 (en) * 2011-05-20 2019-01-02 EchoStar Technologies L.L.C. Improved progress bar
US20130235044A1 (en) * 2012-03-09 2013-09-12 Apple Inc. Multi-purpose progress bar
CN102802075B (zh) * 2012-08-24 2015-05-20 乐视致新电子科技(天津)有限公司 一种在线播放缓冲系统和方法
US10552774B2 (en) * 2013-02-11 2020-02-04 Amazon Technologies, Inc. Cost-minimizing task scheduler

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1960471A (zh) * 2005-11-01 2007-05-09 三星电子株式会社 在便携式终端中搜索运动画面的方法和设备
CN102207863A (zh) * 2011-04-01 2011-10-05 奇智软件(北京)有限公司 一种进度条前进的控制方法及装置
CN103136089A (zh) * 2011-11-25 2013-06-05 腾讯科技(深圳)有限公司 一种进度条显示方法和装置

Also Published As

Publication number Publication date
US20150012828A1 (en) 2015-01-08
WO2014198115A1 (en) 2014-12-18
CN104244100A (zh) 2014-12-24

Similar Documents

Publication Publication Date Title
CN104244100B (zh) 进度条控制方法和装置
CN106131657A (zh) 视频播放控制方法及装置
US10325573B2 (en) Managing transitions of adaptive display rates for different video playback scenarios
CN103957431B (zh) 一种流媒体传输控制方法及流媒体服务器
CN104471955B (zh) 将视频内容提供到多个媒体装置的方法以及服务器
US11882056B2 (en) Token-based billing model for server-side rendering service
US8610724B2 (en) Systems and methods for webpage adaptive rendering
US8888590B2 (en) Graphics render matching for displays
US10321179B2 (en) System and monitoring of video quality adaptation
WO2021057448A1 (zh) 信息显示方法和装置
CN103051955A (zh) 流媒体播放方法及装置
CN111292001B (zh) 基于强化学习的联合决策方法及装置
CN1996996A (zh) 用于移动流媒体代理服务器的流媒体文件的缓存方法
CN107205160A (zh) 一种针对服务器下发的视频的播放方法及装置
US10706087B1 (en) Delegated decision tree evaluation
US11321816B2 (en) Systems and methods for frame time smoothing based on modified animation advancement and use of post render queues
JP2011501504A (ja) ストリーミングメディアコンテンツに対応する広告コンテンツを管理するためのシステム及び方法
US20140113705A1 (en) Quick-resume gaming
CN109067916A (zh) 一种在线多媒体文件下载方法及装置、电子设备
CN110516108A (zh) 浏览器播放音频的方法及系统
US8648870B1 (en) Method and apparatus for performing frame buffer rendering of rich internet content on display devices
US9727873B1 (en) Digital returns
CN110072125A (zh) 视频播放方法及装置
CN107301014A (zh) 一种对手势命令的处理方法和装置
WO2023030325A1 (zh) 缓冲处理方法及装置

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
EXSB Decision made by sipo to initiate substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant