بیایید به ساختارهای داده کلیدی نگاه کنیم، که ورودی و خروجی خط لوله رندر هستند.
این ساختارهای داده عبارتند از:
- درختان فریم از گره های محلی و راه دور تشکیل شده اند که نشان می دهد کدام اسناد وب در کدام فرآیند رندر و کدام رندر Blink هستند.
- درخت قطعه تغییرناپذیر خروجی (و ورودی به) الگوریتم محدودیت طرح را نشان می دهد.
- درخت های ویژگی نشان دهنده سلسله مراتب تبدیل، کلیپ، افکت و اسکرول یک سند وب هستند. اینها در سراسر خط لوله استفاده می شوند.
- لیست های نمایش و تکه های رنگ ورودی الگوریتم های شطرنجی و لایه بندی هستند.
- فریم های کامپوزیتور سطوح، سطوح رندر و کاشی های بافت گرافیکی را که برای ترسیم با استفاده از GPU استفاده می شوند، محصور می کنند.
قبل از قدم زدن در میان این ساختارهای داده، مثال زیر بر روی یکی از بررسی معماری بنا شده است. این مثال در سراسر این سند با نمایش نحوه اعمال ساختارهای داده در آن استفاده می شود.
<!-- Example code -->
<html>
<div style="overflow: hidden; width: 100px; height: 100px;">
<iframe style="filter: blur(3px);
transform: rotateZ(1deg);
width: 100px; height: 300px"
id="one" src="foo.com/etc"></iframe>
</div>
<iframe style="top:200px;
transform: scale(1.1) translateX(200px)"
id="two" src="bar.com"></iframe>
</html>
درختان قاب
Chrome ممکن است گاهی اوقات انتخاب کند که یک فریم با منشاء متقاطع را در یک فرآیند رندر متفاوت از قاب اصلی خود ارائه دهد.
در کد مثال، سه فریم وجود دارد:
با جداسازی سایت، Chromium از دو فرآیند رندر برای ارائه این صفحه وب استفاده می کند. هر فرآیند رندر نمایش خاص خود را از درخت فریم برای آن صفحه وب دارد:
یک فریم ارائه شده در یک فرآیند متفاوت به عنوان یک قاب از راه دور نشان داده می شود. یک قاب از راه دور حداقل اطلاعات مورد نیاز برای عمل به عنوان یک مکان نگهدار در رندر را در خود دارد، مثلاً ابعاد آن. در غیر این صورت، قاب از راه دور حاوی اطلاعات مورد نیاز برای ارائه محتوای واقعی آن نیست.
در مقابل، یک قاب محلی، فریمی را نشان می دهد که از خط لوله رندر استاندارد عبور می کند. فریم محلی شامل تمام اطلاعات مورد نیاز برای تبدیل داده های آن فریم (مانند درخت DOM و داده های سبک) به چیزی است که می تواند رندر و نمایش داده شود.
خط لوله رندر بر اساس دانه بندی قطعه درخت قاب محلی عمل می کند. مثال پیچیده تری را با foo.com
به عنوان فریم اصلی در نظر بگیرید:
<iframe src="bar.com"></iframe>
و زیر فریم bar.com
زیر:
<iframe src="foo.com/etc"></iframe>
اگرچه هنوز تنها دو رندر وجود دارد، اما اکنون سه قطعه درخت قاب محلی وجود دارد که دو قطعه در فرآیند رندر برای foo.com
و یکی در فرآیند رندر برای bar.com
هستند:
برای تولید یک فریم کامپوزیتور برای صفحه وب، Viz به طور همزمان از فریم ریشه هر یک از سه درخت فریم محلی یک فریم کامپوزیتور درخواست می کند و سپس آنها را جمع می کند . همچنین به بخش فریم های کامپوزیتور مراجعه کنید.
فریم اصلی foo.com
و زیرفریم foo.com/other-page
بخشی از یک درخت فریم هستند و در یک فرآیند ارائه می شوند. با این حال، این دو فریم هنوز دارای چرخه عمر سند مستقل هستند زیرا بخشی از قطعات درخت قاب محلی مختلف هستند. به همین دلیل، تولید یک فریم ترکیبی برای هر دو در یک به روز رسانی غیرممکن است. فرآیند رندر اطلاعات کافی برای ترکیب قاب کامپوزیتور ایجاد شده برای foo.com/other-page
مستقیماً در فریم کامپوزیتور برای فریم اصلی foo.com
ندارد. به عنوان مثال، فریم مادر خارج از فرآیند bar.com
ممکن است با تبدیل iframe با CSS یا مسدود کردن بخشهایی از iframe با عناصر دیگر در DOM، بر نمایش iframe foo.com/other-url
تأثیر بگذارد.
آبشار به روز رسانی اموال بصری
ویژگیهای بصری مانند ضریب مقیاس دستگاه و اندازه دید در خروجی رندر شده تأثیر میگذارند و باید بین قطعات درخت قاب محلی همگام شوند. ریشه هر قطعه درخت فریم محلی یک شی ویجت مرتبط با آن دارد. بهروزرسانیهای ویژگی ویژوال قبل از انتشار به ویجتهای باقیمانده از بالا به پایین، به ویجت فریم اصلی میروند.
به عنوان مثال، هنگامی که اندازه Viewport تغییر می کند:
این فرآیند آنی نیست، بنابراین ویژگیهای بصری تکرار شده شامل یک نشانه همگامسازی نیز میشود. سازنده Viz از این نشانه همگامسازی استفاده میکند تا منتظر بماند تا تمام قطعات درخت قاب محلی یک فریم ترکیبکننده را با نشانه همگامسازی فعلی ارسال کنند. این فرآیند از اختلاط فریم های کامپوزیتور با ویژگی های بصری متفاوت جلوگیری می کند.
درخت قطعه غیرقابل تغییر
درخت قطعه غیرقابل تغییر خروجی مرحله طرح بندی خط لوله رندر است. این نشان دهنده موقعیت و اندازه همه عناصر در صفحه (بدون اعمال تبدیل) است.
هر قطعه نشان دهنده بخشی از یک عنصر DOM است. معمولاً فقط یک قطعه در هر عنصر وجود دارد، اما اگر هنگام چاپ در صفحات مختلف یا در یک زمینه چند ستونی در ستونها تقسیم شود، ممکن است تعداد بیشتری نیز وجود داشته باشد.
پس از طرح، هر قطعه تغییر ناپذیر می شود و دیگر هرگز تغییر نمی کند. نکته مهم این است که ما چند محدودیت اضافی نیز قائل هستیم. ما این کار را نمی کنیم:
- به هر ارجاع "بالا" در درخت اجازه دهید. (کودک نمی تواند یک اشاره گر به والدین خود داشته باشد.)
- داده های "حباب" در درخت (کودک فقط اطلاعات را از فرزندان خود می خواند، نه از والدین خود).
این محدودیتها به ما اجازه میدهد تا از یک قطعه برای طرحبندی بعدی استفاده مجدد کنیم. بدون این محدودیتها، اغلب باید کل درخت را بازسازی کنیم، که گران است.
اکثر طرحبندیها معمولاً بهروزرسانیهای افزایشی هستند، برای مثال، یک برنامه وب در پاسخ به کلیک کاربر روی یک عنصر، بخش کوچکی از رابط کاربری را بهروزرسانی میکند. در حالت ایدهآل، چیدمان باید فقط متناسب با آنچه روی صفحه تغییر کرده است انجام دهد. ما میتوانیم با استفاده مجدد از هر چه بیشتر قسمتهای درخت قبلی به این هدف برسیم. این بدان معنی است که (معمولا) ما فقط باید ستون فقرات درخت را بازسازی کنیم.
در آینده، این طراحی تغییرناپذیر میتواند به ما امکان انجام کارهای جالبی مانند عبور درخت قطعه غیرقابل تغییر از مرزهای رشته در صورت نیاز (برای اجرای مراحل بعدی در یک رشته مختلف)، ایجاد چندین درخت برای یک انیمیشن چیدمان صاف، یا اجرای طرحبندیهای فرضی موازی را بدهد. . همچنین به ما پتانسیل طرحبندی چند رشتهای را میدهد.
موارد قطعه درون خطی
محتوای درون خطی (متن سبک غالباً) از نمایش کمی متفاوت استفاده می کند. به جای یک ساختار درختی با جعبه ها و نشانگرها، محتوای درون خطی را در یک لیست مسطح نشان می دهیم که درخت را نشان می دهد. مزیت اصلی این است که نمایش لیست مسطح برای خطوط داخلی سریع است، برای بازرسی یا پرس و جوی ساختارهای داده درون خطی مفید است و حافظه کارآمد است. این برای عملکرد رندر وب بسیار مهم است، زیرا رندر متن بسیار پیچیده است و به راحتی می تواند به کندترین بخش خط لوله تبدیل شود مگر اینکه بهینه سازی شده باشد.
فهرست مسطح برای هر زمینه قالب بندی درون خطی به ترتیب جستجوی عمقی در زیردرخت طرح بندی درون خطی آن ایجاد می شود. هر ورودی در لیست چند تا (شیء، تعداد فرزندان) است. به عنوان مثال، این DOM را در نظر بگیرید:
<div style="width: 0;">
<span style="color: blue; position: relative;">Hi</span> <b>there</b>.
</div>
ویژگی width
روی 0 تنظیم شده است تا خط بین «سلام» و «آنجا» قرار گیرد.
هنگامی که زمینه قالببندی درون خطی برای این وضعیت به صورت درختی نشان داده میشود، به شکل زیر به نظر میرسد:
{
"Line box": {
"Box <span>": {
"Text": "Hi"
}
},
"Line box": {
"Box <b>": {
"Text": "There"
}
},
{
"Text": "."
}
}
لیست تخت به این صورت است:
- (جعبه خط، 2)
- (جعبه <span>، 1)
- (متن "سلام"، 0)
- (جعبه خط، 3)
- (جعبه <b>، 1)
- (متن "آنجا"، 0)
- (متن "."، 0)
مصرف کنندگان زیادی از این ساختار داده وجود دارد: APIهای دسترسی و APIهای هندسی مانند getClientRects
و contenteditable
. هر کدام نیازهای متفاوتی دارند. این اجزا از طریق یک مکان نما به ساختار داده مسطح دسترسی دارند.
مکاننما دارای APIهایی مانند MoveToNext
، MoveToNextLine
، CursorForChildren
. این نمایش مکان نما به دلایل متعدد برای محتوای متنی بسیار قدرتمند است:
- تکرار در ترتیب جستجوی عمقی بسیار سریع است. این بسیار اغلب استفاده می شود، زیرا شبیه به حرکات چرخشی است. از آنجایی که این یک لیست مسطح است، جستجوی اول عمق فقط افست آرایه را افزایش می دهد و تکرار سریع و محل حافظه را ارائه می دهد.
- این جستجوی وسعت اول را ارائه میکند، که برای مثال، زمانی که پسزمینه جعبههای خطی و خطی را نقاشی میکنید، ضروری است.
- دانستن تعداد فرزندان باعث می شود سریع به سمت خواهر یا برادر بعدی حرکت کنید (فقط آرایه را با آن عدد افزایش دهید).
درختان ملکی
DOM درختی از عناصر (به اضافه گره های متنی) است و CSS می تواند سبک های مختلفی را برای عناصر اعمال کند.
این به چهار صورت ظاهر می شود:
- Layout: ورودی های الگوریتم محدودیت طرح.
- رنگ: نحوه رنگ آمیزی و شطرنجی عنصر (اما نه فرزندان آن).
- بصری: جلوههای شطرنجی/تقسیمی که روی زیردرخت DOM اعمال میشود، مانند تبدیلها، فیلترها و برش.
- پیمایش: تراز محوری و گرد گوشه و پیمایش زیردرخت موجود.
درختهای ویژگی ساختارهای دادهای هستند که نحوه اعمال جلوههای بصری و پیمایشی را برای عناصر DOM توضیح میدهند. آنها ابزاری را برای پاسخ به سؤالاتی فراهم می کنند: با توجه به اندازه طرح و موقعیت آن، نسبت به صفحه، یک عنصر DOM داده شده کجاست؟ و: برای اعمال جلوه های بصری و اسکرول از چه ترتیبی از عملیات GPU باید استفاده شود؟
جلوه های بصری و اسکرول در وب در شکوه کامل خود بسیار پیچیده هستند. بنابراین مهمترین کاری که درختهای ویژگی انجام میدهند این است که این پیچیدگی را به یک ساختار داده واحد ترجمه میکنند که دقیقاً ساختار و معنای آنها را نشان میدهد، در حالی که در عین حال بقیه پیچیدگیهای DOM و CSS را حذف میکنند. این به ما امکان می دهد الگوریتم هایی را برای ترکیب و پیمایش با اطمینان بسیار بیشتری پیاده سازی کنیم. به طور خاص:
- هندسه مستعد خطا و سایر محاسبات را می توان در یک مکان متمرکز کرد.
- پیچیدگی ساخت و به روز رسانی درختان دارایی در یک مرحله خط لوله رندر جدا شده است.
- ارسال درختهای دارایی به رشتهها و فرآیندهای مختلف بسیار آسانتر و سریعتر از حالت DOM کامل است، در نتیجه استفاده از آنها برای بسیاری از موارد استفاده ممکن میشود.
- هرچه موارد استفاده بیشتری وجود داشته باشد، ما میتوانیم برندههای بیشتری از کش هندسی ساخته شده در بالا به دست آوریم، زیرا آنها میتوانند از حافظه پنهان یکدیگر استفاده مجدد کنند.
RenderingNG از درخت های دارایی برای اهداف زیادی استفاده می کند، از جمله:
- جداسازی کامپوزیت از رنگ و کامپوزیت کردن از نخ اصلی.
- تعیین استراتژی ترکیب / ترسیم بهینه
- اندازه گیری هندسه IntersectionObserver .
- اجتناب از کار برای عناصر خارج از صفحه و کاشیهای بافت GPU.
- ابطال کارآمد و دقیق رنگ و شطرنجی.
- اندازه گیری تغییر چیدمان و بزرگترین رنگ محتوایی در Core Web Vitals.
هر سند وب دارای چهار درخت ویژگی جداگانه است: transform، clip، effect و scroll. (یک تبدیل اسکرول به عنوان یک ماتریس تبدیل دوبعدی نشان داده می شود.) درخت کلیپ کلیپ های سرریز را نشان می دهد. درخت افکت همه جلوههای بصری دیگر را نشان میدهد: کدورت، فیلترها، ماسکها، حالتهای ترکیبی، و انواع دیگر کلیپها مانند مسیر کلیپ. درخت اسکرول اطلاعاتی را در مورد پیمایش نشان می دهد، مانند اینکه چگونه اسکرول ها به یکدیگر متصل می شوند . برای انجام اسکرول روی رشته کامپوزیتور لازم است. هر گره در یک درخت ویژگی یک اسکرول یا جلوه بصری اعمال شده توسط یک عنصر DOM را نشان می دهد. اگر چندین اثر داشته باشد، ممکن است بیش از یک گره درخت ویژگی در هر درخت برای یک عنصر وجود داشته باشد.
توپولوژی هر درخت مانند یک نمایش پراکنده از DOM است. برای مثال، اگر سه عنصر DOM با کلیپهای سرریز وجود داشته باشد، سه گره درخت کلیپ وجود خواهد داشت و ساختار درخت کلیپ از رابطه بلوک حاوی بین کلیپهای سرریز پیروی میکند. همچنین پیوندهایی بین درختان وجود دارد. این پیوندها سلسله مراتب نسبی DOM و در نتیجه ترتیب کاربرد گره ها را نشان می دهد. به عنوان مثال، اگر یک تبدیل در یک عنصر DOM زیر یک عنصر DOM دیگر با یک فیلتر باشد، البته تبدیل قبل از فیلتر اعمال می شود.
هر عنصر DOM دارای یک حالت درخت ویژگی است که یک حالت 4 تایی (تبدیل، کلیپ، افکت، اسکرول) است که نزدیکترین گرههای درخت کلیپ، تبدیل و افکت را نشان میدهد که روی آن عنصر اثر میگذارند. این بسیار راحت است، زیرا با این اطلاعات ما دقیقاً لیست کلیپ ها، تبدیل ها و افکت هایی را می دانیم که برای آن عنصر اعمال می شود و به چه ترتیبی. این به ما می گوید که کجا روی صفحه است و چگونه آن را ترسیم کنیم.
مثال
( منبع )
<html>
<div style="overflow: scroll; width: 100px; height: 100px;">
<iframe style="filter: blur(3px);
transform: rotateZ(1deg);
width: 100px; height: 300px"
id="one" srcdoc="iframe one"></iframe>
</div>
<iframe style="top:200px;
transform: scale(1.1) translateX(200px)" id=two
srcdoc="iframe two"></iframe>
</html>
برای مثال قبلی (که کمی متفاوت از مثال در مقدمه است)، در اینجا عناصر کلیدی درخت های ویژگی تولید شده آورده شده است:
نمایش لیست ها و تکه های رنگ
یک آیتم نمایشگر حاوی دستورات ترسیم سطح پایینی است ( اینجا را ببینید) که می توانند با Skia شطرنجی شوند. آیتم های نمایش معمولاً ساده هستند و فقط با چند دستور ترسیم مانند ترسیم یک حاشیه یا پس زمینه وجود دارد. پیادهروی درخت رنگ بر روی درخت طرحبندی و قطعات مرتبط به دنبال دستور نقاشی CSS تکرار میشود تا فهرست آیتمهای نمایشی تولید شود.
به عنوان مثال:
<div id="green" style="background:green; width:80px;">
Hello world
</div>
<div id="blue" style="width:100px;
height:100px; background:blue;
position:absolute;
top:0; left:0; z-index:-1;">
</div>
این HTML و CSS لیست نمایش زیر را تولید می کند که در آن هر سلول یک آیتم نمایش است:
پس زمینه را مشاهده کنید | پس زمینه #blue | #green پس زمینه سبز | #متن درون خطی #green |
---|---|---|---|
drawRect با سایز 800x600 و رنگ سفید. | drawRect با اندازه 100x100 در موقعیت 0.0 و رنگ آبی. | drawRect با اندازه 80x18 در موقعیت 8،8 و رنگ سبز. | drawTextBlob با موقعیت 8،8 و متن "Hello world". |
لیست آیتم های نمایش داده شده پشت به جلو مرتب می شود. در مثال بالا، div سبز قبل از div آبی به ترتیب DOM است، اما ترتیب رنگ CSS مستلزم آن است که div آبی با شاخص z منفی قبل از ( مرحله 3 ) div سبز ( مرحله 4.1 ) رنگ آمیزی کند. موارد نمایش تقریباً با مراحل اتمی مشخصات سفارش رنگ CSS مطابقت دارند. یک عنصر DOM منفرد ممکن است منجر به چندین آیتم نمایشی شود، مانند اینکه #green یک آیتم نمایش برای پسزمینه و یک آیتم نمایش دیگر برای متن درون خطی دارد. این دانه بندی برای نشان دادن پیچیدگی کامل مشخصات سفارش رنگ CSS، مانند interleaving ایجاد شده توسط حاشیه منفی مهم است:
<div id="green" style="background:green; width:80px;">
Hello world
</div>
<div id="gray" style="width:35px; height:20px;
background:gray;margin-top:-10px;"></div>
این لیست نمایش زیر را تولید می کند که در آن هر سلول یک آیتم نمایش است:
پس زمینه را مشاهده کنید | #green پس زمینه سبز | پس زمینه #gray | #متن درون خطی #green |
---|---|---|---|
drawRect با سایز 800x600 و رنگ سفید. | drawRect با اندازه 80x18 در موقعیت 8،8 و رنگ سبز. | drawRect با اندازه 35x20 در موقعیت 8،16 و رنگ خاکستری. | drawTextBlob با موقعیت 8،8 و متن "Hello world". |
لیست آیتم های نمایشی ذخیره می شود و توسط به روز رسانی های بعدی مجددا استفاده می شود. اگر یک شی طرح بندی در طول پیاده روی درخت رنگ تغییر نکرده باشد، موارد نمایش آن از لیست قبلی کپی می شود. یک بهینهسازی اضافی متکی به ویژگیهای سفارش رنگ CSS است: انباشتن زمینهها به صورت اتمی رنگ میکنند. اگر هیچ شیء چیدمانی در یک زمینه انباشته شدن تغییر نکرده باشد، مسیر درخت رنگ از بافت انباشته می گذرد و کل دنباله آیتم های نمایشی را از لیست قبلی کپی می کند.
وضعیت درخت ویژگی فعلی در طول پیادهروی درخت رنگ حفظ میشود و فهرست آیتمهای نمایشی به «تکههایی» از آیتمهای نمایشی گروهبندی میشود که حالت درخت ویژگی یکسانی دارند. این در مثال زیر نشان داده شده است:
<div id="scroll" style="background:pink; width:100px;
height:100px; overflow:scroll;
position:absolute; top:0; left:0;">
Hello world
<div id="orange" style="width:75px; height:200px;
background:orange; transform:rotateZ(25deg);">
I'm falling
</div>
</div>
این لیست نمایش زیر را تولید می کند که در آن هر سلول یک آیتم نمایش است:
پس زمینه را مشاهده کنید | #scroll پس زمینه | #scroll متن درون خطی | پس زمینه #orange | متن درون خطی #orange |
---|---|---|---|---|
drawRect با سایز 800x600 و رنگ سفید. | drawRect با اندازه 100x100 در موقعیت 0.0 و رنگ صورتی. | drawTextBlob با موقعیت 0.0 و متن "Hello world". | drawRect با اندازه 75x200 در موقعیت 0.0 و رنگ نارنجی. | drawTextBlob با موقعیت 0,0 و متن "I'm falling". |
درخت ویژگی تبدیل و تکههای رنگ پس از آن (برای اختصار سادهسازی میشود):
فهرست مرتب شده از تکههای رنگ، که گروههایی از آیتمهای نمایشی و حالت درخت ویژگی هستند، ورودیهای مرحله لایهبندی خط لوله رندر هستند. کل فهرست تکههای رنگ را میتوان در یک لایه ترکیبی ادغام کرد و با هم شطرنجی کرد، اما هر بار که کاربر پیمایش میکرد این نیاز به شطرنجیسازی گران قیمت دارد. میتوان یک لایه ترکیبی برای هر تکه رنگ ایجاد کرد و بهصورت جداگانه شطرنجی کرد تا از همهی تشریحسازی مجدد جلوگیری شود، اما به سرعت حافظه GPU را خسته میکند. مرحله لایهبندی باید بین حافظه GPU و کاهش هزینهها در هنگام تغییر ایجاد کند. یک رویکرد کلی خوب این است که تکهها را بهطور پیشفرض ادغام کنیم، و تکههای رنگی را که حالتهای درخت ویژگیهایی دارند که انتظار میرود در رشته ترکیبکننده تغییر کنند، مانند انیمیشنهای تبدیل رشته ترکیبکننده یا تبدیل رشتههای ترکیبکننده، ادغام نمیشوند.
مثال قبل باید به طور ایده آل دو لایه ترکیبی تولید کند:
- یک لایه ترکیبی 800x600 حاوی دستورات ترسیمی:
-
drawRect
با سایز 800x600 و رنگ سفید -
drawRect
با اندازه 100x100 در موقعیت 0.0 و رنگ صورتی
-
- یک لایه ترکیبی 144x224 حاوی دستورات ترسیمی:
-
drawTextBlob
با موقعیت 0.0 و متن "Hello world" - ترجمه 0,18
-
rotateZ(25deg)
-
drawRect
با اندازه 75x200 در موقعیت 0.0 و رنگ نارنجی -
drawTextBlob
با موقعیت 0.0 و متن "I'm falling"
-
اگر کاربر #scroll
را اسکرول کند، لایه ترکیبی دوم منتقل میشود، اما نیازی به شطرنجسازی نیست.
برای مثال ، از بخش قبلی در مورد درختان دارایی، شش تکه رنگ وجود دارد. همراه با حالت های درخت ویژگی (تبدیل، کلیپ، افکت، اسکرول) آنها عبارتند از:
- پس زمینه سند: اسکرول سند، کلیپ سند، ریشه، پیمایش سند.
- گوشه افقی، عمودی و اسکرول برای div (سه تکه رنگ جداگانه): اسکرول سند، گیره سند،
#one
blur، پیمایش سند. - Ifframe
#one
:#one
rotate، کلیپ اسکرول سرریز،#one
blur، div scroll. - Iframe
#two
:#two
مقیاس، کلیپ سند، ریشه، اسکرول سند.
فریم های کامپوزیتور: سطوح، سطوح رندر و کاشی های بافت گرافیکی
فرآیندهای مرورگر و رندر، شطرنجی کردن محتوا را مدیریت میکنند، سپس فریمهای ترکیبکننده را برای نمایش در صفحه به فرآیند Viz ارسال میکنند. فریم های کامپوزیتور نشان می دهد که چگونه می توان محتوای شطرنجی شده را به هم متصل کرد و آن را با استفاده از GPU به طور موثر ترسیم کرد.
کاشی
در تئوری، یک فرآیند رندر یا ترکیبکننده فرآیند مرورگر میتواند پیکسلها را به یک بافت واحد به اندازه کامل نمای رندر تبدیل کند و آن بافت را به Viz ارسال کند. برای نمایش آن، سازنده نمایشگر فقط باید پیکسل ها را از آن بافت واحد در موقعیت مناسب در بافر فریم (مثلاً صفحه) کپی کند. با این حال، اگر آن کامپوزیتور بخواهد حتی یک پیکسل را به روز کند، باید نمای کامل را مجدداً شطرنجی کند و یک بافت جدید را به Viz ارسال کند.
در عوض، viewport به کاشیها تقسیم میشود. یک کاشی بافت گرافیکی جداگانه هر کاشی را با پیکسلهای شطرنجی بخشی از درگاه دید پشتیبان میدهد. سپس رندر می تواند کاشی های جداگانه را به روز کند یا حتی موقعیت کاشی های موجود را روی صفحه تغییر دهد. به عنوان مثال، هنگام پیمایش یک وبسایت، موقعیت کاشیهای موجود به سمت بالا تغییر میکند و فقط گاهی اوقات یک کاشی جدید برای محتوای بیشتر در صفحه باید شطرنجی شود.
چهارگوش و سطوح
کاشیهای بافت گرافیکی نوع خاصی از چهارتایی هستند که فقط یک نام فانتزی برای یک دسته بافت یا دیگری است. چهارگانه بافت ورودی را مشخص میکند و نحوه تبدیل و اعمال جلوههای بصری روی آن را نشان میدهد. برای مثال، کاشیهای محتوای معمولی دارای تبدیلی هستند که موقعیت x، y آنها را در شبکه کاشی نشان میدهد.
این کاشیهای شطرنجیشده در یک پاس رندر پیچیده شدهاند که فهرستی از چهارگوش است. پاس رندر حاوی هیچ اطلاعات پیکسلی نیست. در عوض، دستورالعملهایی در مورد مکان و نحوه ترسیم هر کواد برای تولید خروجی پیکسل مورد نظر دارد. برای هر کاشی بافت گرافیکی یک چهارتایی ترسیمی وجود دارد. ترکیبکننده نمایشگر فقط باید فهرست چهارتاییها را تکرار کند و هر کدام را با جلوههای بصری مشخصشده ترسیم کند تا خروجی پیکسل مورد نظر را برای پاس رندر تولید کند. ترکیب چهارتایی ترسیم برای پاس رندر را می توان به طور موثر بر روی GPU انجام داد، زیرا جلوه های بصری مجاز با دقت انتخاب می شوند تا به طور مستقیم به ویژگی های GPU نگاشت شوند.
فراتر از کاشیهای شطرنجی، انواع دیگری از چهارتاییهای ترسیمی وجود دارد. به عنوان مثال، چهارتایی ترسیم تک رنگ وجود دارد که به هیچ وجه با بافت پشتیبان نیستند، یا چهارتایی ترسیم بافت برای بافت های غیر کاشی مانند ویدیو یا بوم وجود دارد.
همچنین این امکان وجود دارد که یک فریم کامپوزیتور فریم دیگری را تعبیه کند. به عنوان مثال، کامپوزیتور مرورگر یک قاب ترکیبکننده با رابط کاربری مرورگر و یک مستطیل خالی که محتوای رندر کامپوزیتور در آن جاسازی میشود، تولید میکند. مثال دیگر iframe های ایزوله شده سایت است. این تعبیه از طریق سطوح انجام می شود.
هنگامی که یک کامپوزیتور یک فریم کامپوزیتور را ارسال می کند، با یک شناسه به نام شناسه سطحی همراه می شود که به سایر فریم های کامپوزیتور اجازه می دهد آن را با مرجع جاسازی کنند. جدیدترین قاب کامپوزیتور ارسال شده با شناسه سطحی خاص توسط Viz ذخیره می شود. یک فریم کامپوزیتور دیگر میتواند بعداً از طریق چهارتایی ترسیم سطحی به آن مراجعه کند، و بنابراین Viz میداند چه چیزی را بکشد. (توجه داشته باشید که کوادهای ترسیم سطحی فقط حاوی شناسه های سطح هستند و نه بافت ها.)
پاس های رندر متوسط
برخی از جلوههای بصری، مانند بسیاری از فیلترها یا حالتهای ترکیبی پیشرفته، نیاز دارند که دو یا چند چهارتایی به یک بافت میانی کشیده شوند. سپس بافت میانی به یک بافر مقصد روی GPU (یا احتمالاً بافت میانی دیگری) کشیده میشود و همزمان جلوه بصری را اعمال میکند. برای اجازه دادن به این امر، یک فریم کامپوزیتور در واقع حاوی لیستی از پاس های رندر است. همیشه یک پاس رندر ریشه وجود دارد که آخرین آن ترسیم می شود و مقصد آن مربوط به بافر فریم است و ممکن است تعداد بیشتری نیز وجود داشته باشد.
امکان پاس های رندر متعدد، نام «رندر پاس» را توضیح می دهد. هر پاس باید به صورت متوالی بر روی GPU، در چندین "گذر" اجرا شود، در حالی که یک پاس واحد را می توان در یک محاسبات GPU موازی انبوه تکمیل کرد.
تجمع
چندین فریم ترکیبکننده به Viz ارسال میشوند و باید با هم به صفحه کشیده شوند. این کار توسط یک مرحله تجمع انجام می شود که آنها را به یک فریم ترکیبی واحد تبدیل می کند. Aggregation جایگزین quads ترسیم سطحی توسط فریم های ترکیبی که آنها مشخص می کنند می شود. همچنین فرصتی برای بهینهسازی بافتهای میانی غیرضروری یا محتوای خارج از صفحه است. به عنوان مثال، در بسیاری از موارد، فریم کامپوزیتور برای یک iframe ایزوله سایت نیازی به بافت میانی خود ندارد و میتواند مستقیماً از طریق quads ترسیم مناسب به درون بافر فریم کشیده شود. مرحله تجمیع چنین بهینهسازیهایی را مشخص میکند و آنها را بر اساس دانش جهانی که برای ترکیبکنندههای رندر منفرد در دسترس نیست، اعمال میکند.
مثال
در اینجا فریم های کامپوزیتوری هستند که نمونه ای را از ابتدای این پست نشان می دهند.
- سطح
foo.com/index.html
: id=0- Render pass 0: draw to output.
- Render pass draw quad: با تاری 3 پیکسل بکشید و در رندر پاس 0 کلیپ کنید.
- رندر پاس 1:
- برای محتویات کاشی
#one
iframe، با موقعیت های x و y برای هر کدام، چهارتایی بکشید.
- برای محتویات کاشی
- رندر پاس 1:
- چهارتایی ترسیم سطح: با شناسه 2، ترسیم شده با تبدیل مقیاس و ترجمه.
- Render pass draw quad: با تاری 3 پیکسل بکشید و در رندر پاس 0 کلیپ کنید.
- Render pass 0: draw to output.
- سطح رابط کاربری مرورگر: ID=1
- Render pass 0: draw to output.
- ترسیم quads برای رابط کاربری مرورگر (همچنین کاشی شده)
- Render pass 0: draw to output.
-
bar.com/index.html
سطح: ID=2- Render pass 0: draw to output.
- چهار عدد برای محتویات
#two
iframe با موقعیت های x و y برای هر کدام بکشید.
- چهار عدد برای محتویات
- Render pass 0: draw to output.
تصاویر توسط Una Kravets.