🎮 Google เตรียมพัฒนามาตรฐานเว็บใหม่ เพื่อให้สามารถใช้การ์ดจอเครื่องเล่นเกมบน Chrome ได้ดีขึ้น
.
ยุคของเกมบน Broswer กำลังจะกลับมารุ่งเรืองอีกครั้ง เมื่อ Google ประกาศว่ากำลังนำมาตรฐานเว็บแบบใหม่ ที่จะทำให้ประสบการณ์การเล่นเกมบนเว็บเบราว์เซอร์ดียิ่งขึ้น โดยจะใช้เทคโนโลยีที่เรียกว่า WebCodecs และ WebGPU ซึ่งจะมารองรับการสตรีมและเรนเดอร์ภาพสามมิติแบบใหม่ให้กับ Google Chrome โดยเริ่มทดสอบแล้วกับ Google Chrome Beta ตั้งแต่เวอร์ชั่น 94 เป็นต้นไป (ซึ่งจะเห็นได้ว่าหลังๆ มี CS 1.6 และ Red Alert 2 ให้เล่นบน Browser กันแล้ว)
.
🪄 โดย WebCodecs คือ API ที่ถูกพัฒนาขึ้นโดย W3C เพื่อซัพพอร์ตการสตรีมมิ่งเกมบนคลาวน์ผ่านเบราว์เซอร์ ที่จะช่วยให้การสตรีมเกมไหลลื่นใกล้เคียงกับการสตรีมวิดีโอมากขึ้น มีค่า latency ต่ำลงมาก ในขณะที่ WebGPU (พัฒนาขึ้นมาจาก WebGL เดิมก่อนหน้า) คือ API ที่จะช่วยให้นักพัฒนาออกแบบเกมที่สามารถดึงประสิทธิภาพของ GPU บนเครื่องคอมพิวเตอร์ของผู้เล่นมาใช้กับเกมบนคลาวน์ของตัวเองได้
.
ตัว WebGPU จะค่อนข้างคล้ายกับ Apple Metal, Microsoft DirectX 12, หรือ Vulkan ที่เคยมีมาแล้วก่อนหน้า แต่ครั้งนี้จะเป็นมาตรฐานที่ใหญ่และมีประสิทธิภาพกว่าในการดึงกราฟิก โดย Google จะนำมาใช้ก่อนกับ Chrome และเบราว์เซอร์ตระกูล Chromium ที่เป็น open-source ในขณะที่ Firefox หรือ Safari ก็เริ่มมีการทดสอบบ้างแล้วเช่นกัน
.
🧑💻 สำหรับตัว WebGPU บน Chrome ยังอยู่ในช่วงเริ่มต้นการทดลอง ซึ่งคาดว่าจะแล้วเสร็จในช่วงต้นปี 2022 ในขณะที่ตัว WebCodecs จะเริ่มเปิดให้ใช้งานได้ตั้งแต่ Chrome Beta 94 นี้เลย คาดว่าเพื่อเร่งนำมาใช้กับ Stadia ที่เป็นแพลตฟอร์มสตรีมมิ่งเกมบนคลาวน์ของ Google เอง ฉะนั้นแล้วหลังจากต้นปีหน้าเมื่อตัว WebGPU เสร็จสิ้น เราอาจจะได้เห็นเกมบน Browser ใหม่ๆ กราฟิกแรงๆ กันเพิ่มมากขึ้นครับ
.
ที่มา : https://www.theverge.com/2021/8/30/22649214/chrome-94-beta-browser-gaming-apis-metal-directx-vulkan-streaming-graphics-codecs
https://www.chromestatus.com/feature/6213121689518080
.
ป.ล. จริงๆ ก็ถือเป็นเรื่องดีนะ ต่อไปเราจะได้เล่นเกมเก่าๆ ลงบน Browser ได้เลยโดยไม่จำเป็นต้องติดตั้ง หรือสตรีมเกมกราฟิกหนักๆ มาเล่นเกมบนคอมสเปคธรรมดาได้สบายๆ เพียงแค่ขอมีเน็ตแรงๆ ก็พอ
.
ป.ล.2 แต่เอาจริงๆ ขอพัฒนาให้กิน RAM เครื่องน้อยลงด้วย ดูน่าจะตอบโจทย์คนส่วนใหญ่มากกว่านะ
----------------------------------------------
ฝากกดติดตามด้วยนะครับ
YouTube : https://www.youtube.com/c/comcraftds
กรุ๊ป FB : https://www.facebook.com/groups/2594751244112180
同時也有1部Youtube影片,追蹤數超過136萬的網紅JJ Lin林俊傑,也在其Youtube影片中提到,Simultaneous live performance and recording, in a multiple-room environment. 多重空間進行現場演出同步錄影 Binaural "dummy head" recording: An unparalleled live s...
「streaming api」的推薦目錄:
- 關於streaming api 在 คอมคร้าบ Facebook 的最佳貼文
- 關於streaming api 在 軟體開發學習資訊分享 Facebook 的最讚貼文
- 關於streaming api 在 GamingDose Facebook 的精選貼文
- 關於streaming api 在 JJ Lin林俊傑 Youtube 的精選貼文
- 關於streaming api 在 YouTube Live Streaming API Overview | Google Developers 的評價
- 關於streaming api 在 what are the Streaming APIs - Stack Overflow 的評價
- 關於streaming api 在 Live Video API - Documentation - Facebook for Developers 的評價
- 關於streaming api 在 mambu-gmbh/Streaming-API-Java-Sample-Client - GitHub 的評價
- 關於streaming api 在 Streaming to YouTube Live? Put an API on it! 的評價
- 關於streaming api 在 TWS API v9.72+: Streaming Market Data 的評價
- 關於streaming api 在 The Top 80 Streaming Api Open Source Projects on Github 的評價
- 關於streaming api 在 What is the difference between the Streaming API PushTopic ... 的評價
- 關於streaming api 在 Schedule Live Streams and Go Live Automatically using ... 的評價
streaming api 在 軟體開發學習資訊分享 Facebook 的最讚貼文
用於 SQLite 的串流式S3複製。
Litestream是一個獨立的 SQLite 串流複製工具。它作為一個背景行程執行,並安全地將變化增量複製到另一個檔案或S3。Litestream只通過SQLite API與SQLite進行通訊,所以它不會破壞你的資料庫。
✍ 更多開源資訊,歡迎加入 Discord Github 俱樂部 https://discord.gg/DGR7uDqSSW
https://github.com/benbjohnson/litestream
streaming api 在 GamingDose Facebook 的精選貼文
ทุกวันนี้เทคโนโลยี Streaming เพื่อการชมภาพยนตร์และเล่นเกมกำลังได้รับความสนใจมากขึ้น และการมาของ Google Stadia ก็เป็นหนึ่งในแพลตฟอร์มที่กำลังถูกจับตามองมากที่สุดในเวลานี้ แต่ก็ดูเหมือนว่าร้านขายเกมยักษ์ใหญ่อย่าง Steam เองก็อาจจะกำลังเข้ามาสู่การแข่งขันในครั้งนี้ด้วยเหมือนกัน
.
รายงานจากทาง Steam Database/Steam Tracking ที่มีการเผยข้อมูลออกมาว่า ในหน้า Web Page ของ Steam Partner Portal Page มีโค้ดรูปแบบใหม่ปรากฏขึ้นมา โดยเขียนเอาไว้ว่า “function SignLatestCloudGamingAddendum( returnURL ).” ที่น่าจะแปลความได้ว่าน่าจะเป็นการให้บริการ Game Streaming ที่มาจากการร่วมมือกันของเหล่าพาร์ทเนอร์ ซึ่งน่าจะมีการปรับเอาไปใช้งานใน Steam API ต่อไป
.
ซึ่งในตอนนี้ทาง Steam Data Base ยังไม่กล้ายืนยันหรือฟันธงว่าจะมีระบบ Game Streaming แบบเดียวกันกับ Stadia ที่พัฒนาโดย Google แต่ถ้าทำได้จริง ก็ถือว่าเป็นสิ่งที่น่าสนใจอย่างยิ่ง และคาดว่าตลาดการแข่งขันในด้าน Game Streaming จะดุเดือดมากขึ้นในอนาคตแน่นอน
.
โดยในเวลานี้ Valve ยังไม่มีความเห็นเกี่ยวกับเรื่องดังกล่าวออกมาแต่อย่างใดครับ
.
ที่มา: https://www.pcgamesn.com/steam/steam-streaming
#ข่าวเกม #gamingdose #Steam
streaming api 在 JJ Lin林俊傑 Youtube 的精選貼文
Simultaneous live performance and recording, in a multiple-room environment.
多重空間進行現場演出同步錄影
Binaural "dummy head" recording: An unparalleled live streaming concert experience
雙路立體聲錄音(人頭錄音):體驗真實音場的實時直播
State-of-the art lighting and stage technology
頂尖精進的燈光及舞台設備科技
5.1 Surround Sound ready, analog/digital equipment for professional hybrid recordings and post production.
5.1環音全配,類比與數位兼具的專業錄音及後製
--------------------------------------------------------------------------------------------------------
AUDIO EQUIPMENT LIST:
--- CONSOLE ---
Neve Genesys Black G64
with 1073 mic/line preamps,
1084 classic EQ & Neve VCA Dynamic
--- RECORDING SYSTEM ---
Mac Pro
2.7GHz 12 Core Processor / 64GB Memory
AVID Pro Tools HDX2+HD MADI
Apogee Symphony I/O MKII
UAD-2 Octo PCIe
Mercury M76m Custom Shop Version Mic Pre
Manley VariMu Mastering Version Compressor
Universal Audio LA-2A Compressor/Limiter
Pete’s Place BAC-500 FET Compressor
API 527 Compressor/Limiter
Empirical Labs ELDS DerrEsser
Maag Addio PREQ4
Bricasti M7 System 1 Reverb
--- MONITORING SYSTEM ---
ATC SCM150ASL
Neumann KH420
Neumann KH870
Neumann KH120
Trinnov D-Mon 8
Aviom AN-16i/ v.2
Aviom D800
Aviom A360
K-Array KP 102
K-Array KU212
K-Array KA84
— MICROPHONES —
Telefunken ELA M 251E
Telefunken C12
Telefunken M82
Telefunken M80
Neumann U 87
Neumann KM 184
AKG C414
Aston Microphones
Spirit Slate Digital VMS
Mojave MA-200
STAGE AND VIDEO EQUIPMENT SUMMARY:
• Full LED studio and state-of-the-art system: this includes a three-sided LED wall complete with interactive LED floor installation, to showcase Virtual Reality and/or all-rounded 360 degree, customizable graphic effects and visual - one of the first in Asia
• Coolux system: a server to load customized visual or video content for LED walls. It comes with limitless layers and is capable of supporting resolution up to 4k videography
• User-friendly Barco Encore 2 system: installed in control room to enable fitting and stitching of content or videos from the Coolux system or any external playback devices
• Delayed and LIVE broadcast-ready studio: With face lighting and multiple camera shot variations
• Multi-robotic cameras: which can be controlled and mixed remotely, without anyone manning it, in the studio during live performances or recordings
• GrandMA Dot 2 board and multiple-roving LED lights: for various lighting designs and effects
• Pan-tilt zoom camera controller: which enables control of up to 100 sets of cameras, capturing Full HD images from all cameras
• Web Presenter: to enable simultaneous web broadcast during live show recordings
streaming api 在 Live Video API - Documentation - Facebook for Developers 的推薦與評價
As long as your app can produce a live RTMPS stream, you can stream to Facebook using the Live Video API. Common Uses. Broadcasting a live video stream on a ... ... <看更多>
streaming api 在 YouTube Live Streaming API Overview | Google Developers 的推薦與評價
The YouTube Live Streaming API lets you create, update, and manage live events on YouTube. Using the API, you can schedule events (broadcasts) and associate them with video streams, which represent the actual broadcast content.
The Live Streaming API is actually comprised of components of the YouTube Data API and the YouTube Content ID API. The Data API enables YouTube users to manage their YouTube accounts, while the YouTube Content ID API enables interactions with YouTube's rights management system. However, all of the resources that make up the Live Streaming API are used only to create and manage live events.
This document is intended for developers who want to write applications to facilitate live broadcasting on YouTube. It explains basic concepts of YouTube and of the API itself. It also provides an overview of the different functions that the API supports.
Core conceptsbroadcasts
A broadcast represents an event that can be watched on YouTube as it happens. Broadcasts can also be recorded and saved as YouTube videos so that users can watch them after they happen. streams
A stream identifies the audio-video content that is being communicated to YouTube. Each broadcast is associated with one video stream. cuepoints
A cuepoint represents an ad break that can be inserted into a live broadcast.
API use cases
The list below suggests several ways to use the API in your application:
Schedule broadcasts and define broadcast settings. Your application could enable users to predefine broadcast settings and then select the settings to apply to a particular broadcast.
Associate video streams and broadcasts.
Enable broadcasters to define information about a broadcast and its video (using the YouTube Data API) at the same time.
Simplify transitions between broadcast states (for example,
testing
orlive
) and enable users to insert cuepoints.Before you start
You need a Google Account to access the Google API Console, request an API key, and register your application.
Register your application with Google so that it can submit API requests.
After registering your application, select the YouTube Data API as one of the services that your application uses:
Go to the API Console and select the project that you just registered.
Visit the Enabled APIs page.
In the list of APIs, make sure the status is ON for the YouTube Data API v3 and, if you are a YouTube Content Partner, the YouTube Content ID API.
Familiarize yourself with the core concepts of the JavaScript Object Notation (JSON) data format. JSON is a common, language-independent data format that provides a simple text representation of arbitrary data structures. For more information, see json.org.
Authorizing API requests
As noted above, the Live Streaming API uses functionality that is technically part of either the YouTube Data API or the YouTube Content ID API. You can use the Content ID API to provide YouTube with metadata, ownership information, and policy information for your assets. (A live video broadcast is an example of an asset.) The API also lets you claim videos and set ad policies for your videos.
This section explains the authorization requirements for requests to the Content ID API, which are different from the requirements for authorizing other Live Streaming API requests.
Calling the Data API
The API request must be authorized by the Google Account that owns the broadcasting YouTube channel. Calling the Content ID API
The API request must be authorized by a Google Account that is linked to the content owner that owns the broadcasting YouTube channel.
Resources and resource types
A resource is an individual data entity with a unique identifier. The table below describes the
different types of resources that you will interact with using the
Live Streaming API. Technically, all of these resources are
actually defined as part of either the YouTube Data API
or the YouTube Content ID API. However, the
liveBroadcast
,liveStream
, andcuepoint
resources areonly used to create and manage live events.
Resources
liveBroadcast
Contains information about an event that you are broadcasting on YouTube. A
liveBroadcast
resource is an extension of a YouTube video resource and sets thevideo metadata that would be pertinent to a live broadcast but not to other YouTube videos.
As such, a
liveBroadcast
resource corresponds to exactly one YouTube video resource.In fact, the
liveBroadcast
resource and the
video
resource share thesame ID. And after creating the broadcast using the Live Streaming API, you can use the
YouTube Data API to provide additional metadata about the video.
liveStream
Contains information about the video stream that you are transmitting to YouTube. The stream
provides the content that will be broadcast to YouTube users. Once created, a
liveStream
resource can be bound to exactly one
liveBroadcast
resource. Similarly, theliveBroadcast
resource can only be bound to oneliveStream
resource.cuepoint
Inserts a cuepoint in the broadcast video stream, which might trigger an ad break. Use the
liveBroadcasts.cuepoint
method to insert a cuepoint during a broadcast.
video
Represents a single YouTube video. As noted above, a
liveBroadcast
resource is an extension of avideo
resource. You can use the YouTube Data API to update metadata about the video, such as the recording location or the regions where the broadcast will be viewable.videoAdvertisingOptions
Defines the advertising settings for a video (or broadcast). You use the YouTube Content ID API to set advertising options.
asset
Represents a piece of intellectual property, such as a movie or an episode of a show. In this case, the broadcast video is the asset. You will use the YouTube Content ID API to create and manage
asset
resources.claim
Links a video to an asset that the video matches. You create a claim, using the YouTube Content ID API, to identify yourself as the owner of the broadcast video.
policy
Defines rules that specify the circumstances under which you want your content to be viewable on YouTube or blocked from appearing on YouTube. You need to apply a policy to your broadcast video and can also specify a policy that YouTube will apply to user-uploaded videos that match your broadcast video.
Supported operations
The following table shows the different methods that the API supports:
Operations
list
Retrieves (
GET
) a list of zero or more resources.insert
Creates (
POST
) a new resource.update
Modifies (
PUT
) an existing resource to reflect data in your request.bind
Links a
liveBroadcast
resource with aliveStream
resource or removes such a link.transition
Changes the status of a
liveBroadcast
resource and initiates any processes associated with the new status. For example, when you transition a broadcast's status totesting
, YouTube starts to transmit video to that broadcast's monitor stream.delete
Removes (
DELETE
) a specific resource.The table below identifies the operations that are supported for different types of resources. Operations that insert, update, or delete resources always require user authorization. In some cases,
list
methods support both authorized and unauthorized requests, where unauthorized requests only retrieve public data while authorized requests can also retrieve information that is restricted to the currently authenticated user.Supported Operations
list
insert
update
bind
transition
cuepoint
delete
liveBroadcast
liveStream
Partial resources
The API allows, and actually requires, the retrieval of partial resources so that applications avoid transferring, parsing, and storing unneeded data. This approach also ensures that the API uses network, CPU, and memory resources more efficiently.
The
part
parameter is a required parameter for any API request that retrieves or returns a YouTube Data API resource. The parameter identifies one or more top-level (non-nested) resource properties that should be included in an API response. For example, aliveStream
resource has the following parts:snippet
cdn
status
All of these parts are objects that contain nested properties, and you can think of these objects as groups of metadata fields that the API server might (or might not) retrieve. As such, the
part
parameter requires you to select the resource components that your application actually uses. This requirement serves two important purposes:It reduces latency by preventing the API server from spending time retrieving metadata fields that your application doesn't use.
It reduces bandwidth usage by reducing (or eliminating) the amount of unnecessary data that your application might retrieve.
Over time, as resources add more parts, these benefits will only increase since your application will not be requesting newly introduced properties that it doesn't support.
Tips and best practicesClaim your contentIf you would like to show ads during your broadcast, you need to claim the broadcast video before the event begins. To claim content, you must be a YouTube Content Partner participating in the Content ID program.
The process for claiming your live broadcast video is different than the normal process for claiming a video. When claiming live video, you need to create your claim before the video actually exists. The API does support this, and the life of a broadcast document explains the YouTube Content ID API calls that enable you to create your claim.
Preview and test your contentUpon receiving your inbound video stream, YouTube can then broadcast that video on two different outbound streams:
The monitor stream enables you to preview (and test) your video broadcast. It is a private stream that is only accessible to you. You can only transition a broadcast to the
testing
phase if the broadcast's monitor stream is enabled. The monitor stream does not show ad breaks.The broadcast stream is the stream visible to your audience. You can set the broadcast's privacy status to either
public
,private
, orunlisted
. (A private broadcast is only visible to users who have been explicitly invited to watch it, while an unlisted broadcast is visible to anyone with a link to view it.)You can choose to delay the broadcast stream so that it does not run concurrently with the monitor stream. By delaying the broadcast stream, you can have more fine-grained control over the time that you insert cuepoints into the broadcast.
However, delaying the broadcast stream makes it difficult for your live presenters to interact with your viewing audience. In addition, delaying the broadcast increases the likelihood that viewers will discover key details about the event from sources other than your broadcast. For example, if you are broadcasting a sporting event on a 60-second delay, viewers might learn about critical moments in the event from other real-time news sources before actually seeing them in the broadcast.
YouTube recommends that you enable the monitor stream for your broadcast so that you can test your content. You should choose whether to also delay your broadcast based on your desire to control timing of cuepoints as opposed to your desire to interact with your audience or provide real-time coverage of an event.
Running midroll ads during a broadcast streamDuring a broadcast, you can insert a cuepoint to indicate that an ad break should start in
the broadcast as soon as possible or at a specified time. The ad break enables YouTube to run
midroll ads during the broadcast.
Ad breaks have the following characteristics:
It has a predefined length of time, which you set using the
cuepoint
resource'sdurationSecs
property. After the ad break concludes, viewers return to the live broadcast.
When an ad break happens, an ad only plays in the video player for viewers who are watching
the broadcast when the cuepoint is inserted. An ad does not run when viewers refresh the page
where the broadcast is playing or when visitors start watching the broadcast after the
cuepoint is inserted.
The sequence of steps below reflects the best practice for inserting an ad break during your broadcast:
Set time offsetsWhen inserting a cuepoint, you can specify that it should be inserted right away or that it
should be inserted at a specific point in the broadcast. Your options depend on whether the
broadcast stream for your video is delayed.
If your broadcast stream is not delayed, then you can insert the cuepoint immediately or use
the
walltimeMs
property to have the ad break start at a particular time.
To start the ad break immediately, call the
liveBroadcasts.cuepoint
method. In theresource in the request body, set the
insertionOffsetTimeMs
property'svalue to
0
or do not specify a value for that property and do not specifya value for the
walltimeMs
property.
Important: Note that viewers do not see the resulting ad
content immediately. There may be a delay of around 30 seconds before the ad content is
visible to users. During that delay, your broadcast stream will still be visible to your
viewers, and you need to watch the broadcast stream to determine when the ad content
actually displays instead of your monitor stream.
To start the ad break at a particular time, call the
liveBroadcasts.cuepoint
method and use the
walltimeMs
property to specify the desired time. The property value is an integer that represents
an epoch timestamp.
If your broadcast stream is delayed, then you can insert the cuepoint immediately as
described above, specify a clock time as described above, or you can specify a time offset to
determine when the ad break will start. The time offset specifies a point in your broadcast
when viewers should see an ad.
The offset value is measured in milliseconds from the beginning of the monitor stream for
your broadcast. Note that if your broadcast has a testing phase, then the monitor stream
starts when your broadcast transitions to the
testing
status. Otherwise, yourmonitor stream starts when your broadcast transitions to the
live
status.When inserting a cuepoint, set the
cuepoint
resource'sinsertionOffsetTimeMs
property to the desired offset.
Calculate the time offset value
To retrieve the offset value, call the YouTube Player API's
getCurrentTime
function for the player that is playing the monitor stream. Use the retrieved value to insert the cuepoint in the broadcast stream at that time.The possible values for the offset time can be calculated as the following range:
The
Δ
is a five-second buffer at the beginning and end of the possible time offsets when YouTube cannot precisely insert a cuepoint. For example:A broadcast has a five-minute testing phase.
The broadcast stream is delayed 60 seconds after the monitor stream.
The broadcaster is inserting the cuepoint four minutes after the broadcast transitions to
live
status. (This is three minutes after the broadcast stream becomes visible.)In this case, the possible range of offset times is
[(485,000), (535,000)]
.These times are specified in milliseconds, and are calculated using the following values:
Troubleshooting and error handlingelapsed_time=540000
– The monitor stream has run for nineminutes (540 seconds, 540000 milliseconds) when the
liveBroadcasts.cuepoint
method is called.broadcast_delay=60000
– The broadcast stream is delayed by 60 seconds, or 60000 milliseconds.Δ=5000
– The five-second buffer when the cuepoint cannot be reliably inserted.The following guidelines explain how to resolve specific problems that may arise. For the lists
of errors that each API method might return, see YouTube Live Streaming API - Errors.
When a broadcast transitions from one status to another, it may temporarily be assigned with another status while YouTube completes the actions associated with the transition. For example, if you send a
liveBroadcasts.transition
request to change a broadcast's status fromready
totesting
, YouTube will set the broadcast's status totestStarting
and then complete the actions associated with the status change. When all of those actions have been completed, YouTube will update the broadcast's status totesting
, thereby indicating that the transition is complete.If a broadcast becomes stuck with a
testStarting
orliveStarting
status, you need to call theliveBroadcasts.delete
method and delete the broadcast. Then create a new broadcast, bind it to your live stream, and continue with the testing process.As noted in the
liveBroadcasts.transition
method's documentation, you should confirm that the value of thestatus.streamStatus
property for the stream bound to your broadcast isactive
before calling that method.... <看更多>
相關內容