از ناحیه نوار عنوان در کنار کنترل های پنجره استفاده کنید تا PWA خود را بیشتر شبیه یک برنامه کنید.
اگر مقاله من را به خاطر بیاورید که PWA خود را بیشتر شبیه یک برنامه کنید ، ممکن است به یاد بیاورید که چگونه به شخصی سازی نوار عنوان برنامه خود به عنوان استراتژی برای ایجاد تجربه ای شبیه به برنامه اشاره کردم. در اینجا مثالی از نحوه نمایش برنامه پادکست macOS ارائه شده است.
اکنون ممکن است وسوسه شوید که با گفتن اینکه پادکست یک برنامه macOS مخصوص پلتفرم است که در مرورگر اجرا نمی شود و بنابراین می تواند آنچه را که می خواهد بدون نیاز به اجرای قوانین مرورگر انجام دهد، مخالفت کنید. درست است، اما خبر خوب این است که ویژگی Window Controls Overlay، که موضوع همین مقاله است، به زودی به شما امکان می دهد رابط های کاربری مشابهی برای PWA خود ایجاد کنید.
کنترل های پنجره اجزای پوشش
Windows Controls Overlay از چهار ویژگی فرعی تشکیل شده است:
- مقدار
"window-controls-overlay"
برای قسمت"display_override"
در مانیفست برنامه وب. - متغیرهای محیط CSS
titlebar-area-x
،titlebar-area-y
،titlebar-area-width
، وtitlebar-area-height
. - استاندارد کردن ویژگی CSS اختصاصی قبلی
-webkit-app-region
به عنوان ویژگیapp-region
برای تعریف مناطق قابل کشیدن در محتوای وب. - مکانیزمی برای پرس و جو و کار در اطراف منطقه کنترل های پنجره از طریق عضو
windowControlsOverlay
window.navigator
.
Windows Controls Overlay چیست
ناحیه نوار عنوان به فضای سمت چپ یا راست کنترلهای پنجره (یعنی دکمههای کوچک کردن، حداکثر کردن، بستن و غیره) اشاره دارد و اغلب شامل عنوان برنامه است. Window Controls Overlay به برنامه های کاربردی وب مترقی (PWA) اجازه می دهد تا با تعویض نوار عنوان تمام عرض موجود با یک پوشش کوچک حاوی کنترل های پنجره، احساسی شبیه به برنامه ایجاد کنند. این به توسعه دهندگان اجازه می دهد تا محتوای سفارشی را در قسمتی که قبلاً قسمت نوار عنوان تحت کنترل مرورگر بود قرار دهند.
وضعیت فعلی
مرحله | وضعیت |
---|---|
1. توضیح دهنده ایجاد کنید | کامل شود |
2. پیش نویس اولیه مشخصات را ایجاد کنید | کامل شود |
3. جمع آوری بازخورد و تکرار در طراحی | در حال انجام است |
4. آزمایش مبدا | کامل شود |
5. راه اندازی کنید | کامل (در Chromium 104) |
نحوه استفاده از Windows Controls Overlay
افزودن window-controls-overlay
به مانیفست برنامه وب
یک برنامه وب پیشرفته میتواند با افزودن "window-controls-overlay"
بهعنوان عضو اصلی "display_override"
در مانیفست برنامه وب، روی همپوشانی کنترلهای پنجره شرکت کند:
{
"display_override": ["window-controls-overlay"]
}
پوشش کنترل های پنجره تنها زمانی قابل مشاهده خواهد بود که همه شرایط زیر برآورده شوند:
- برنامه در مرورگر باز نمی شود، بلکه در یک پنجره PWA جداگانه باز می شود.
- مانیفست شامل
"display_override": ["window-controls-overlay"]
. (مقادیر دیگر پس از آن مجاز هستند.) - PWA روی یک سیستم عامل دسکتاپ اجرا می شود.
- مبدا فعلی با مبدایی که PWA برای آن نصب شده است مطابقت دارد.
نتیجه این یک ناحیه خالی نوار عنوان با کنترل های پنجره معمولی در سمت چپ یا راست است، بسته به سیستم عامل.
انتقال محتوا به نوار عنوان
اکنون که فضایی در نوار عنوان وجود دارد، می توانید چیزی را به آنجا منتقل کنید. برای این مقاله، من یک PWA محتوای ویژه ویکیمدیا ساختم. یک ویژگی مفید برای این برنامه ممکن است جستجوی کلمات در عنوان مقاله باشد. HTML برای ویژگی جستجو به صورت زیر است:
<div class="search">
<img src="logo.svg" alt="Wikimedia logo." width="32" height="32" />
<label>
<input type="search" />
Search for words in articles
</label>
</div>
برای انتقال این div
به بالا در نوار عنوان، مقداری CSS مورد نیاز است:
.search {
/* Make sure the `div` stays there, even when scrolling. */
position: fixed;
/**
* Gradient, because why not. Endless opportunities.
* The gradient ends in `#36c`, which happens to be the app's
* `<meta name="theme-color" content="#36c">`.
*/
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
/* Use the environment variable for the left anchoring with a fallback. */
left: env(titlebar-area-x, 0);
/* Use the environment variable for the top anchoring with a fallback. */
top: env(titlebar-area-y, 0);
/* Use the environment variable for setting the width with a fallback. */
width: env(titlebar-area-width, 100%);
/* Use the environment variable for setting the height with a fallback. */
height: env(titlebar-area-height, 33px);
}
در تصویر زیر می توانید تاثیر این کد را مشاهده کنید. نوار عنوان کاملاً پاسخگو است. هنگامی که اندازه پنجره PWA را تغییر می دهید، نوار عنوان به گونه ای واکنش نشان می دهد که گویی از محتوای معمولی HTML تشکیل شده است، که در واقع همینطور است.
تعیین اینکه کدام بخش از نوار عنوان قابل کشیدن است
در حالی که اسکرین شات بالا نشان می دهد که کار شما تمام شده است، هنوز کاملاً تمام نشده اید. پنجره PWA دیگر قابل کشیدن نیست (به غیر از یک منطقه بسیار کوچک)، زیرا دکمه های کنترل پنجره مناطق کشیدن نیستند و بقیه نوار عنوان از ویجت جستجو تشکیل شده است. با استفاده از ویژگی app-region
CSS با مقدار drag
این مشکل را برطرف کنید. در مورد بتن، خوب است که همه چیز را علاوه بر عنصر input
قابل کشیدن باشد.
/* The entire search `div` is draggable… */
.search {
-webkit-app-region: drag;
app-region: drag;
}
/* …except for the `input`. */
input {
-webkit-app-region: no-drag;
app-region: no-drag;
}
با قرار دادن این CSS، کاربر میتواند پنجره برنامه را طبق معمول با کشیدن div
، img
یا label
بکشد. فقط عنصر input
تعاملی است بنابراین عبارت جستجو را می توان وارد کرد.
تشخیص ویژگی
پشتیبانی از Windows Controls Overlay را می توان با آزمایش وجود windowControlsOverlay
تشخیص داد:
if ('windowControlsOverlay' in navigator) {
// Window Controls Overlay is supported.
}
پرس و جو از منطقه کنترل های پنجره با windowControlsOverlay
کد تا کنون یک مشکل دارد: در برخی از سیستم عامل ها کنترل های پنجره در سمت راست و در برخی دیگر در سمت چپ قرار دارند. بدتر از همه، منوی "سه نقطه" کروم نیز بر اساس پلتفرم، موقعیت خود را تغییر می دهد. این بدان معناست که تصویر پسزمینه گرادیان خطی باید بهصورت پویا برای اجرا از #131313
→ maroon
مایل به maroon
← #131313
→ maroon
تطبیق داده شود، به طوری که با رنگ پسزمینه maroon
نوار عنوان که توسط <meta name="theme-color" content="maroon">
تعیین میشود، ترکیب شود. <meta name="theme-color" content="maroon">
. این را می توان با جستجو در API getTitlebarAreaRect()
در ویژگی navigator.windowControlsOverlay
به دست آورد.
if ('windowControlsOverlay' in navigator) {
const { x } = navigator.windowControlsOverlay.getTitlebarAreaRect();
// Window controls are on the right (like on Windows).
// Chrome menu is left of the window controls.
// [ windowControlsOverlay___________________ […] [_] [■] [X] ]
if (x === 0) {
div.classList.add('search-controls-right');
}
// Window controls are on the left (like on macOS).
// Chrome menu is right of the window controls overlay.
// [ [X] [_] [■] ___________________windowControlsOverlay [⋮] ]
else {
div.classList.add('search-controls-left');
}
} else {
// When running in a non-supporting browser tab.
div.classList.add('search-controls-right');
}
به جای داشتن تصویر پسزمینه در قوانین CSS کلاس .search
(مانند قبل)، اکنون کد اصلاحشده از دو کلاس استفاده میکند که کد بالا به صورت پویا تنظیم میکند.
/* For macOS: */
.search-controls-left {
background-image: linear-gradient(90deg, #36c, 45%, #131313, 90%, #36c);
}
/* For Windows: */
.search-controls-right {
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
}
تعیین اینکه آیا پوشش کنترلهای پنجره قابل مشاهده است یا خیر
پوشش کنترل های پنجره در هر شرایطی در ناحیه نوار عنوان قابل مشاهده نخواهد بود. در حالی که طبیعتاً در مرورگرهایی که از ویژگی Window Controls Overlay پشتیبانی نمیکنند وجود نخواهد داشت، زمانی که PWA مورد نظر در یک برگه اجرا میشود نیز وجود نخواهد داشت. برای تشخیص این وضعیت، می توانید ویژگی visible
windowControlsOverlay
را پرس و جو کنید:
if (navigator.windowControlsOverlay.visible) {
// The window controls overlay is visible in the title bar area.
}
از طرف دیگر، می توانید از پرس و جو رسانه display-mode
در جاوا اسکریپت و/یا CSS نیز استفاده کنید:
// Create the query list.
const mediaQueryList = window.matchMedia('(display-mode: window-controls-overlay)');
// Define a callback function for the event listener.
function handleDisplayModeChange(mql) {
// React on display mode changes.
}
// Run the display mode change handler once.
handleDisplayChange(mediaQueryList);
// Add the callback function as a listener to the query list.
mediaQueryList.addEventListener('change', handleDisplayModeChange);
@media (display-mode: window-controls-overlay) {
/* React on display mode changes. */
}
مطلع شدن از تغییرات هندسی
پرسوجو در ناحیه همپوشانی کنترلهای پنجره با getTitlebarAreaRect()
میتواند برای کارهای تکی مانند تنظیم تصویر پسزمینه صحیح بر اساس مکان کنترلهای پنجره کافی باشد، اما در موارد دیگر، کنترل دقیقتری لازم است. به عنوان مثال، یک مورد استفاده ممکن می تواند تطبیق همپوشانی کنترل های پنجره بر اساس فضای موجود و اضافه کردن یک جوک درست در پوشش کنترل پنجره زمانی که فضای کافی وجود دارد، باشد.
میتوانید با عضویت در navigator.windowControlsOverlay.ongeometrychange
یا با تنظیم یک شنونده رویداد برای رویداد geometrychange
از تغییرات هندسه مطلع شوید. این رویداد فقط زمانی فعال میشود که همپوشانی کنترلهای پنجره قابل مشاهده باشد، یعنی زمانی که navigator.windowControlsOverlay.visible
true
باشد.
const debounce = (func, wait) => {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func(...args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
};
if ('windowControlsOverlay' in navigator) {
navigator.windowControlsOverlay.ongeometrychange = debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250);
}
به جای تخصیص یک تابع به ongeometrychange
، میتوانید یک شنونده رویداد را نیز مانند زیر به windowControlsOverlay
اضافه کنید. می توانید در مورد تفاوت بین این دو در MDN بخوانید.
navigator.windowControlsOverlay.addEventListener(
'geometrychange',
debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250),
);
سازگاری هنگام اجرا در یک برگه و در مرورگرهای غیر پشتیبانی
دو مورد ممکن برای بررسی وجود دارد:
- موردی که یک برنامه در مرورگری اجرا میشود که از Windows Controls Overlay پشتیبانی میکند ، اما در آن برنامه در برگه مرورگر استفاده میشود.
- موردی که یک برنامه در مرورگری اجرا میشود که از پوشش کنترلهای پنجره پشتیبانی نمیکند .
در هر دو مورد، بهطور پیشفرض HTML ساختهشده برای همپوشانی کنترلهای پنجره، مانند محتوای معمولی HTML درون خطی نمایش داده میشود و مقادیر بازگشتی متغیرهای env()
برای موقعیتیابی وارد میشوند. در مرورگرهای پشتیبانی کننده، همچنین می توانید تصمیم بگیرید که HTML تعیین شده برای همپوشانی کنترل های پنجره را با بررسی ویژگی visible
روکش نمایش داده نشود و اگر false
گزارش شود، محتوای HTML را پنهان کنید.
به عنوان یادآوری، مرورگرهای غیر پشتیبانی یا اصلاً ویژگی مانیفست برنامه وب "display_override"
در نظر نمی گیرند یا "window-controls-overlay"
نمی شناسند و بنابراین از مقدار ممکن بعدی مطابق با زنجیره بازگشتی استفاده می کنند، برای مثال، "standalone"
.
ملاحظات UI
در حالی که ممکن است وسوسه انگیز باشد، ایجاد یک منوی کشویی کلاسیک در ناحیه Window Controls Overlay توصیه نمی شود. انجام این کار ، دستورالعملهای طراحی در macOS را نقض میکند، پلتفرمی که در آن کاربران انتظار دارند نوارهای منو (هم منوهای ارائهشده توسط سیستم و هم موارد سفارشی) در بالای صفحه نمایش داشته باشند.
اگر برنامه شما یک تجربه تمام صفحه ارائه می دهد، به دقت بررسی کنید که آیا منطقی است که پوشش کنترل های پنجره شما بخشی از نمای تمام صفحه باشد. به طور بالقوه ممکن است بخواهید زمانی که رویداد onfullscreenchange
فعال می شود، چیدمان خود را دوباره تنظیم کنید.
نسخه ی نمایشی
من یک نسخه آزمایشی ایجاد کرده ام که می توانید با آن در مرورگرهای مختلف پشتیبانی کننده و غیر پشتیبانی کننده و در حالت نصب شده و غیر نصب شده بازی کنید. برای تجربه واقعی Windows Controls Overlay، باید برنامه را نصب کنید. در زیر می توانید دو اسکرین شات از آنچه را که باید انتظار داشته باشید را مشاهده کنید. کد منبع برنامه در Glitch موجود است.
ویژگی جستجو در پوشش کنترل های پنجره کاملاً کاربردی است:
ملاحظات امنیتی
تیم Chromium با استفاده از اصول اصلی تعریف شده در کنترل دسترسی به ویژگیهای قدرتمند پلتفرم وب ، از جمله کنترل کاربر، شفافیت و ارگونومی، Windows Controls Overlay API را طراحی و اجرا کرد.
جعل
دادن کنترل جزئی نوار عنوان به سایتها، فضایی را برای توسعهدهندگان ایجاد میکند تا محتوا را در منطقهای که قبلاً منطقهای قابل اعتماد و تحت کنترل مرورگر بود، جعل کنند. در حال حاضر، در مرورگرهای Chromium، حالت مستقل شامل یک نوار عنوان است که در راهاندازی اولیه، عنوان صفحه وب را در سمت چپ، و مبدا صفحه را در سمت راست نمایش میدهد (به دنبال آن دکمه «تنظیمات و موارد دیگر» و کنترلهای پنجره را دنبال میکند. . پس از چند ثانیه، متن اصلی ناپدید می شود. اگر مرورگر روی زبان راست به چپ (RTL) تنظیم شده باشد، این طرح به گونهای برگردانده میشود که متن اصلی در سمت چپ باشد. در صورت عدم وجود بالشتک کافی بین مبدا و لبه سمت راست روکش، همپوشانی کنترلهای پنجره باز میشود تا مبدا را جعل کند. به عنوان مثال، منبع "evil.ltd" را می توان به یک سایت قابل اعتماد "google.com" اضافه کرد، که باعث می شود کاربران باور کنند که منبع قابل اعتماد است. برنامه این است که این متن اصلی حفظ شود تا کاربران بدانند منشاء برنامه چیست و بتوانند اطمینان حاصل کنند که با انتظارات آنها مطابقت دارد. برای مرورگرهای پیکربندی شده RTL، باید به اندازه کافی بالشتک در سمت راست متن اصلی وجود داشته باشد تا از اضافه کردن منبع ناامن به منبع قابل اعتماد توسط یک وب سایت مخرب جلوگیری شود.
انگشت نگاری
فعال کردن همپوشانی کنترلهای پنجره و مناطق قابل کشیدن، به جز تشخیص ویژگی، نگرانیهای قابلتوجهی را برای حفظ حریم خصوصی ایجاد نمیکند. با این حال، با توجه به اندازه ها و موقعیت های مختلف دکمه های کنترل پنجره در سیستم عامل، navigator. windowControlsOverlay. getTitlebarAreaRect()
متد navigator. windowControlsOverlay. getTitlebarAreaRect()
DOMRect
برمی گرداند که موقعیت و ابعاد آن اطلاعاتی را در مورد سیستم عاملی که مرورگر بر روی آن اجرا می شود نشان می دهد. در حال حاضر، توسعهدهندگان میتوانند سیستم عامل را از رشته عامل کاربر کشف کنند، اما به دلیل نگرانیهای مربوط به اثر انگشت، بحث در مورد مسدود کردن رشته UA و یکپارچهسازی نسخههای سیستم عامل وجود دارد. تلاشهای مداومی در جامعه مرورگر وجود دارد تا بفهمیم که اندازه کنترلهای پنجره چند بار روی پلتفرمها تغییر میکند، زیرا فرض فعلی این است که این کنترلها در نسخههای سیستمعامل نسبتاً پایدار هستند و بنابراین برای مشاهده نسخههای سیستمعامل کوچک مفید نیستند. اگرچه این یک مشکل بالقوه اثر انگشت است، اما فقط برای PWA های نصب شده که از ویژگی نوار عنوان سفارشی استفاده می کنند اعمال می شود و برای استفاده عمومی مرورگر اعمال نمی شود. علاوه بر این، navigator. windowControlsOverlay
API برای iframe های تعبیه شده در یک PWA در دسترس نخواهد بود.
ناوبری
پیمایش به مبدأ متفاوت در یک PWA باعث میشود که به نوار عنوان مستقل عادی برگردد، حتی اگر معیارهای بالا را برآورده کند و با پوشش کنترلهای پنجره راهاندازی شود. این برای قرار دادن نوار سیاهی است که در مسیریابی به مبدأ متفاوت ظاهر می شود. پس از بازگشت به مبدا اصلی، همپوشانی کنترل های پنجره دوباره استفاده خواهد شد.
بازخورد
تیم Chromium میخواهد درباره تجربیات شما با Windows Controls Overlay API بشنود.
در مورد طراحی API به ما بگویید
آیا چیزی در مورد API وجود دارد که آنطور که انتظار داشتید کار نمی کند؟ یا آیا روش ها یا ویژگی هایی وجود دارد که برای اجرای ایده خود به آنها نیاز دارید؟ سوال یا نظری در مورد مدل امنیتی دارید؟ یک مشکل مشخصات را در مخزن GitHub مربوطه ثبت کنید یا افکار خود را به یک مشکل موجود اضافه کنید.
گزارش مشکل در اجرا
آیا با اجرای Chromium اشکالی پیدا کردید؟ یا اجرا با مشخصات متفاوت است؟ یک اشکال را در new.crbug.com ثبت کنید. اطمینان حاصل کنید که تا جایی که می توانید جزئیات، دستورالعمل های ساده برای بازتولید را وارد کنید و UI>Browser>WebAppInstalls
را در کادر Components وارد کنید. Glitch برای به اشتراک گذاری سریع و آسان تکرارها عالی عمل می کند.
پشتیبانی از API را نشان دهید
آیا قصد دارید از Windows Controls Overlay API استفاده کنید؟ پشتیبانی عمومی شما به تیم Chromium کمک میکند تا ویژگیها را اولویتبندی کند و به سایر فروشندگان مرورگر نشان میدهد که چقدر حمایت از آنها ضروری است.
با هشتگ #WindowControlsOverlay
یک توییت به ChromiumDev@ ارسال کنید و به ما اطلاع دهید کجا و چگونه از آن استفاده میکنید.
لینک های مفید
- توضیح دهنده
- پیش نویس مشخصات
- اشکال کروم
- ورودی وضعیت پلتفرم Chrome
- بررسی تگ
- اسناد مربوط به Microsoft Edge
قدردانی
Window Controls Overlay توسط آماندا بیکر از تیم Microsoft Edge پیاده سازی و مشخص شد. این مقاله توسط Joe Medley و Kenneth Rohde Christiansen بررسی شده است. تصویر قهرمان توسط زیگموند در Unsplash .
،از ناحیه نوار عنوان در کنار کنترل های پنجره استفاده کنید تا PWA خود را بیشتر شبیه یک برنامه کنید.
اگر مقاله من را به خاطر بیاورید که PWA خود را بیشتر شبیه یک برنامه کنید ، ممکن است به یاد بیاورید که چگونه به شخصی سازی نوار عنوان برنامه خود به عنوان استراتژی برای ایجاد تجربه ای شبیه به برنامه اشاره کردم. در اینجا مثالی از نحوه نمایش برنامه پادکست macOS ارائه شده است.
اکنون ممکن است وسوسه شوید که با گفتن اینکه پادکست یک برنامه macOS مخصوص پلتفرم است که در مرورگر اجرا نمی شود و بنابراین می تواند آنچه را که می خواهد بدون نیاز به اجرای قوانین مرورگر انجام دهد، مخالفت کنید. درست است، اما خبر خوب این است که ویژگی Window Controls Overlay، که موضوع همین مقاله است، به زودی به شما امکان می دهد رابط های کاربری مشابهی برای PWA خود ایجاد کنید.
کنترل های پنجره اجزای پوشش
Windows Controls Overlay از چهار ویژگی فرعی تشکیل شده است:
- مقدار
"window-controls-overlay"
برای قسمت"display_override"
در مانیفست برنامه وب. - متغیرهای محیط CSS
titlebar-area-x
،titlebar-area-y
،titlebar-area-width
، وtitlebar-area-height
. - استاندارد کردن ویژگی CSS اختصاصی قبلی
-webkit-app-region
به عنوان ویژگیapp-region
برای تعریف مناطق قابل کشیدن در محتوای وب. - مکانیزمی برای پرس و جو و کار در اطراف منطقه کنترل های پنجره از طریق عضو
windowControlsOverlay
window.navigator
.
Windows Controls Overlay چیست
ناحیه نوار عنوان به فضای سمت چپ یا راست کنترلهای پنجره (یعنی دکمههای کوچک کردن، حداکثر کردن، بستن و غیره) اشاره دارد و اغلب شامل عنوان برنامه است. Window Controls Overlay به برنامه های کاربردی وب مترقی (PWA) اجازه می دهد تا با تعویض نوار عنوان تمام عرض موجود با یک پوشش کوچک حاوی کنترل های پنجره، احساسی شبیه به برنامه ایجاد کنند. این به توسعه دهندگان اجازه می دهد تا محتوای سفارشی را در قسمتی که قبلاً قسمت نوار عنوان تحت کنترل مرورگر بود قرار دهند.
وضعیت فعلی
مرحله | وضعیت |
---|---|
1. توضیح دهنده ایجاد کنید | کامل شود |
2. پیش نویس اولیه مشخصات را ایجاد کنید | کامل شود |
3. جمع آوری بازخورد و تکرار در طراحی | در حال انجام است |
4. آزمایش مبدا | کامل شود |
5. راه اندازی کنید | کامل (در Chromium 104) |
نحوه استفاده از Windows Controls Overlay
افزودن window-controls-overlay
به مانیفست برنامه وب
یک برنامه وب پیشرفته میتواند با افزودن "window-controls-overlay"
بهعنوان عضو اصلی "display_override"
در مانیفست برنامه وب، روی همپوشانی کنترلهای پنجره شرکت کند:
{
"display_override": ["window-controls-overlay"]
}
پوشش کنترل های پنجره تنها زمانی قابل مشاهده خواهد بود که همه شرایط زیر برآورده شوند:
- برنامه در مرورگر باز نمی شود، بلکه در یک پنجره PWA جداگانه باز می شود.
- مانیفست شامل
"display_override": ["window-controls-overlay"]
. (مقادیر دیگر پس از آن مجاز هستند.) - PWA روی یک سیستم عامل دسکتاپ اجرا می شود.
- مبدا فعلی با مبدایی که PWA برای آن نصب شده است مطابقت دارد.
نتیجه این یک ناحیه خالی نوار عنوان با کنترل های پنجره معمولی در سمت چپ یا راست است، بسته به سیستم عامل.
انتقال محتوا به نوار عنوان
اکنون که فضایی در نوار عنوان وجود دارد، می توانید چیزی را به آنجا منتقل کنید. برای این مقاله، من یک PWA محتوای ویژه ویکیمدیا ساختم. یک ویژگی مفید برای این برنامه ممکن است جستجوی کلمات در عنوان مقاله باشد. HTML برای ویژگی جستجو به صورت زیر است:
<div class="search">
<img src="logo.svg" alt="Wikimedia logo." width="32" height="32" />
<label>
<input type="search" />
Search for words in articles
</label>
</div>
برای انتقال این div
به بالا در نوار عنوان، مقداری CSS مورد نیاز است:
.search {
/* Make sure the `div` stays there, even when scrolling. */
position: fixed;
/**
* Gradient, because why not. Endless opportunities.
* The gradient ends in `#36c`, which happens to be the app's
* `<meta name="theme-color" content="#36c">`.
*/
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
/* Use the environment variable for the left anchoring with a fallback. */
left: env(titlebar-area-x, 0);
/* Use the environment variable for the top anchoring with a fallback. */
top: env(titlebar-area-y, 0);
/* Use the environment variable for setting the width with a fallback. */
width: env(titlebar-area-width, 100%);
/* Use the environment variable for setting the height with a fallback. */
height: env(titlebar-area-height, 33px);
}
در تصویر زیر می توانید تاثیر این کد را مشاهده کنید. نوار عنوان کاملاً پاسخگو است. هنگامی که اندازه پنجره PWA را تغییر می دهید، نوار عنوان به گونه ای واکنش نشان می دهد که گویی از محتوای معمولی HTML تشکیل شده است، که در واقع همینطور است.
تعیین اینکه کدام بخش از نوار عنوان قابل کشیدن است
در حالی که اسکرین شات بالا نشان می دهد که کار شما تمام شده است، هنوز کاملاً تمام نشده اید. پنجره PWA دیگر قابل کشیدن نیست (به غیر از یک منطقه بسیار کوچک)، زیرا دکمه های کنترل پنجره مناطق کشیدن نیستند و بقیه نوار عنوان از ویجت جستجو تشکیل شده است. با استفاده از ویژگی app-region
CSS با مقدار drag
این مشکل را برطرف کنید. در مورد بتن، خوب است که همه چیز را علاوه بر عنصر input
قابل کشیدن باشد.
/* The entire search `div` is draggable… */
.search {
-webkit-app-region: drag;
app-region: drag;
}
/* …except for the `input`. */
input {
-webkit-app-region: no-drag;
app-region: no-drag;
}
با قرار دادن این CSS، کاربر میتواند پنجره برنامه را طبق معمول با کشیدن div
، img
یا label
بکشد. فقط عنصر input
تعاملی است بنابراین عبارت جستجو را می توان وارد کرد.
تشخیص ویژگی
پشتیبانی از Windows Controls Overlay را می توان با آزمایش وجود windowControlsOverlay
تشخیص داد:
if ('windowControlsOverlay' in navigator) {
// Window Controls Overlay is supported.
}
پرس و جو از منطقه کنترل های پنجره با windowControlsOverlay
کد تا کنون یک مشکل دارد: در برخی از سیستم عامل ها کنترل های پنجره در سمت راست و در برخی دیگر در سمت چپ قرار دارند. بدتر از همه، منوی "سه نقطه" کروم نیز بر اساس پلتفرم، موقعیت خود را تغییر می دهد. این بدان معناست که تصویر پسزمینه گرادیان خطی باید بهصورت پویا برای اجرا از #131313
→ maroon
مایل به maroon
← #131313
→ maroon
تطبیق داده شود، به طوری که با رنگ پسزمینه maroon
نوار عنوان که توسط <meta name="theme-color" content="maroon">
تعیین میشود، ترکیب شود. <meta name="theme-color" content="maroon">
. این را می توان با جستجو در API getTitlebarAreaRect()
در ویژگی navigator.windowControlsOverlay
به دست آورد.
if ('windowControlsOverlay' in navigator) {
const { x } = navigator.windowControlsOverlay.getTitlebarAreaRect();
// Window controls are on the right (like on Windows).
// Chrome menu is left of the window controls.
// [ windowControlsOverlay___________________ […] [_] [■] [X] ]
if (x === 0) {
div.classList.add('search-controls-right');
}
// Window controls are on the left (like on macOS).
// Chrome menu is right of the window controls overlay.
// [ [X] [_] [■] ___________________windowControlsOverlay [⋮] ]
else {
div.classList.add('search-controls-left');
}
} else {
// When running in a non-supporting browser tab.
div.classList.add('search-controls-right');
}
به جای داشتن تصویر پسزمینه در قوانین CSS کلاس .search
(مانند قبل)، اکنون کد اصلاحشده از دو کلاس استفاده میکند که کد بالا به صورت پویا تنظیم میکند.
/* For macOS: */
.search-controls-left {
background-image: linear-gradient(90deg, #36c, 45%, #131313, 90%, #36c);
}
/* For Windows: */
.search-controls-right {
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
}
تعیین اینکه آیا پوشش کنترلهای پنجره قابل مشاهده است یا خیر
پوشش کنترل های پنجره در هر شرایطی در ناحیه نوار عنوان قابل مشاهده نخواهد بود. در حالی که طبیعتاً در مرورگرهایی که از ویژگی Window Controls Overlay پشتیبانی نمیکنند وجود نخواهد داشت، زمانی که PWA مورد نظر در یک برگه اجرا میشود نیز وجود نخواهد داشت. برای تشخیص این وضعیت، می توانید ویژگی visible
windowControlsOverlay
را پرس و جو کنید:
if (navigator.windowControlsOverlay.visible) {
// The window controls overlay is visible in the title bar area.
}
از طرف دیگر، می توانید از پرس و جو رسانه display-mode
در جاوا اسکریپت و/یا CSS نیز استفاده کنید:
// Create the query list.
const mediaQueryList = window.matchMedia('(display-mode: window-controls-overlay)');
// Define a callback function for the event listener.
function handleDisplayModeChange(mql) {
// React on display mode changes.
}
// Run the display mode change handler once.
handleDisplayChange(mediaQueryList);
// Add the callback function as a listener to the query list.
mediaQueryList.addEventListener('change', handleDisplayModeChange);
@media (display-mode: window-controls-overlay) {
/* React on display mode changes. */
}
مطلع شدن از تغییرات هندسی
پرسوجو در ناحیه همپوشانی کنترلهای پنجره با getTitlebarAreaRect()
میتواند برای کارهای تکی مانند تنظیم تصویر پسزمینه صحیح بر اساس مکان کنترلهای پنجره کافی باشد، اما در موارد دیگر، کنترل دقیقتری لازم است. به عنوان مثال، یک مورد استفاده ممکن می تواند تطبیق همپوشانی کنترل های پنجره بر اساس فضای موجود و اضافه کردن یک جوک درست در پوشش کنترل پنجره زمانی که فضای کافی وجود دارد، باشد.
میتوانید با عضویت در navigator.windowControlsOverlay.ongeometrychange
یا با تنظیم یک شنونده رویداد برای رویداد geometrychange
از تغییرات هندسه مطلع شوید. این رویداد فقط زمانی فعال میشود که همپوشانی کنترلهای پنجره قابل مشاهده باشد، یعنی زمانی که navigator.windowControlsOverlay.visible
true
باشد.
const debounce = (func, wait) => {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func(...args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
};
if ('windowControlsOverlay' in navigator) {
navigator.windowControlsOverlay.ongeometrychange = debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250);
}
به جای تخصیص یک تابع به ongeometrychange
، میتوانید یک شنونده رویداد را نیز مانند زیر به windowControlsOverlay
اضافه کنید. می توانید در مورد تفاوت بین این دو در MDN بخوانید.
navigator.windowControlsOverlay.addEventListener(
'geometrychange',
debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250),
);
سازگاری هنگام اجرا در یک برگه و در مرورگرهای غیر پشتیبانی
دو مورد ممکن برای بررسی وجود دارد:
- موردی که یک برنامه در مرورگری اجرا میشود که از Windows Controls Overlay پشتیبانی میکند ، اما در آن برنامه در برگه مرورگر استفاده میشود.
- موردی که یک برنامه در مرورگری اجرا میشود که از پوشش کنترلهای پنجره پشتیبانی نمیکند .
در هر دو مورد، بهطور پیشفرض HTML ساختهشده برای همپوشانی کنترلهای پنجره، مانند محتوای معمولی HTML درون خطی نمایش داده میشود و مقادیر بازگشتی متغیرهای env()
برای موقعیتیابی وارد میشوند. در مرورگرهای پشتیبانی کننده، همچنین می توانید تصمیم بگیرید که HTML تعیین شده برای همپوشانی کنترل های پنجره را با بررسی ویژگی visible
روکش نمایش داده نشود و اگر false
گزارش شود، محتوای HTML را پنهان کنید.
به عنوان یادآوری، مرورگرهای غیر پشتیبانی یا اصلاً ویژگی مانیفست برنامه وب "display_override"
در نظر نمی گیرند یا "window-controls-overlay"
نمی شناسند و بنابراین از مقدار ممکن بعدی مطابق با زنجیره بازگشتی استفاده می کنند، برای مثال، "standalone"
.
ملاحظات UI
در حالی که ممکن است وسوسه انگیز باشد، ایجاد یک منوی کشویی کلاسیک در ناحیه Window Controls Overlay توصیه نمی شود. انجام این کار ، دستورالعملهای طراحی در macOS را نقض میکند، پلتفرمی که در آن کاربران انتظار دارند نوارهای منو (هم منوهای ارائهشده توسط سیستم و هم موارد سفارشی) در بالای صفحه نمایش داشته باشند.
اگر برنامه شما یک تجربه تمام صفحه ارائه می دهد، به دقت بررسی کنید که آیا منطقی است که پوشش کنترل های پنجره شما بخشی از نمای تمام صفحه باشد. به طور بالقوه ممکن است بخواهید زمانی که رویداد onfullscreenchange
فعال می شود، چیدمان خود را دوباره تنظیم کنید.
نسخه ی نمایشی
من یک نسخه آزمایشی ایجاد کرده ام که می توانید با آن در مرورگرهای مختلف پشتیبانی کننده و غیر پشتیبانی کننده و در حالت نصب شده و غیر نصب شده بازی کنید. برای تجربه واقعی Windows Controls Overlay، باید برنامه را نصب کنید. در زیر می توانید دو اسکرین شات از آنچه را که باید انتظار داشته باشید را مشاهده کنید. کد منبع برنامه در Glitch موجود است.
ویژگی جستجو در پوشش کنترل های پنجره کاملاً کاربردی است:
ملاحظات امنیتی
تیم Chromium با استفاده از اصول اصلی تعریف شده در کنترل دسترسی به ویژگیهای قدرتمند پلتفرم وب ، از جمله کنترل کاربر، شفافیت و ارگونومی، Windows Controls Overlay API را طراحی و اجرا کرد.
جعل
دادن کنترل جزئی نوار عنوان به سایتها، فضایی را برای توسعهدهندگان ایجاد میکند تا محتوا را در منطقهای که قبلاً منطقهای قابل اعتماد و تحت کنترل مرورگر بود، جعل کنند. در حال حاضر، در مرورگرهای Chromium، حالت مستقل شامل یک نوار عنوان است که در راهاندازی اولیه، عنوان صفحه وب را در سمت چپ، و مبدا صفحه را در سمت راست نمایش میدهد (به دنبال آن دکمه «تنظیمات و موارد دیگر» و کنترلهای پنجره را دنبال میکند. . پس از چند ثانیه، متن اصلی ناپدید می شود. اگر مرورگر روی زبان راست به چپ (RTL) تنظیم شده باشد، این طرح به گونهای برگردانده میشود که متن اصلی در سمت چپ باشد. در صورت عدم وجود بالشتک کافی بین مبدا و لبه سمت راست روکش، همپوشانی کنترلهای پنجره باز میشود تا مبدا را جعل کند. به عنوان مثال، منبع "evil.ltd" را می توان به یک سایت قابل اعتماد "google.com" اضافه کرد، که باعث می شود کاربران باور کنند که منبع قابل اعتماد است. برنامه این است که این متن اصلی حفظ شود تا کاربران بدانند منشاء برنامه چیست و بتوانند اطمینان حاصل کنند که با انتظارات آنها مطابقت دارد. برای مرورگرهای پیکربندی شده RTL، باید به اندازه کافی بالشتک در سمت راست متن اصلی وجود داشته باشد تا از اضافه کردن منبع ناامن به منبع قابل اعتماد توسط یک وب سایت مخرب جلوگیری شود.
انگشت نگاری
فعال کردن همپوشانی کنترلهای پنجره و مناطق قابل کشیدن، به جز تشخیص ویژگی، نگرانیهای قابلتوجهی را برای حفظ حریم خصوصی ایجاد نمیکند. با این حال، با توجه به اندازه ها و موقعیت های مختلف دکمه های کنترل پنجره در سیستم عامل، navigator. windowControlsOverlay. getTitlebarAreaRect()
متد navigator. windowControlsOverlay. getTitlebarAreaRect()
DOMRect
برمی گرداند که موقعیت و ابعاد آن اطلاعاتی را در مورد سیستم عاملی که مرورگر بر روی آن اجرا می شود نشان می دهد. در حال حاضر، توسعهدهندگان میتوانند سیستم عامل را از رشته عامل کاربر کشف کنند، اما به دلیل نگرانیهای مربوط به اثر انگشت، بحث در مورد مسدود کردن رشته UA و یکپارچهسازی نسخههای سیستم عامل وجود دارد. تلاشهای مداومی در جامعه مرورگر وجود دارد تا بفهمیم که اندازه کنترلهای پنجره چند بار روی پلتفرمها تغییر میکند، زیرا فرض فعلی این است که این کنترلها در نسخههای سیستمعامل نسبتاً پایدار هستند و بنابراین برای مشاهده نسخههای سیستمعامل کوچک مفید نیستند. اگرچه این یک مشکل بالقوه اثر انگشت است، اما فقط برای PWA های نصب شده که از ویژگی نوار عنوان سفارشی استفاده می کنند اعمال می شود و برای استفاده عمومی مرورگر اعمال نمی شود. علاوه بر این، navigator. windowControlsOverlay
API برای iframe های تعبیه شده در یک PWA در دسترس نخواهد بود.
ناوبری
پیمایش به مبدأ متفاوت در یک PWA باعث میشود که به نوار عنوان مستقل عادی برگردد، حتی اگر معیارهای بالا را برآورده کند و با پوشش کنترلهای پنجره راهاندازی شود. این برای قرار دادن نوار سیاهی است که در مسیریابی به مبدأ متفاوت ظاهر می شود. پس از بازگشت به مبدا اصلی، همپوشانی کنترل های پنجره دوباره استفاده خواهد شد.
بازخورد
تیم Chromium میخواهد درباره تجربیات شما با Windows Controls Overlay API بشنود.
در مورد طراحی API به ما بگویید
آیا چیزی در مورد API وجود دارد که آنطور که انتظار داشتید کار نمی کند؟ یا آیا روش ها یا ویژگی هایی وجود دارد که برای اجرای ایده خود به آنها نیاز دارید؟ سوال یا نظری در مورد مدل امنیتی دارید؟ یک مشکل مشخصات را در مخزن GitHub مربوطه ثبت کنید یا افکار خود را به یک مشکل موجود اضافه کنید.
گزارش مشکل در اجرا
آیا با اجرای Chromium اشکالی پیدا کردید؟ یا اجرا با مشخصات متفاوت است؟ یک اشکال را در new.crbug.com ثبت کنید. اطمینان حاصل کنید که تا جایی که می توانید جزئیات، دستورالعمل های ساده برای بازتولید را وارد کنید و UI>Browser>WebAppInstalls
را در کادر Components وارد کنید. Glitch برای به اشتراک گذاری سریع و آسان تکرارها عالی عمل می کند.
پشتیبانی از API را نشان دهید
آیا قصد دارید از Windows Controls Overlay API استفاده کنید؟ پشتیبانی عمومی شما به تیم Chromium کمک میکند تا ویژگیها را اولویتبندی کند و به سایر فروشندگان مرورگر نشان میدهد که چقدر حمایت از آنها ضروری است.
با هشتگ #WindowControlsOverlay
یک توییت به ChromiumDev@ ارسال کنید و به ما اطلاع دهید کجا و چگونه از آن استفاده میکنید.
لینک های مفید
- توضیح دهنده
- پیش نویس مشخصات
- اشکال کروم
- ورودی وضعیت پلتفرم Chrome
- بررسی تگ
- اسناد مربوط به Microsoft Edge
قدردانی
Window Controls Overlay توسط آماندا بیکر از تیم Microsoft Edge پیاده سازی و مشخص شد. این مقاله توسط Joe Medley و Kenneth Rohde Christiansen بررسی شده است. تصویر قهرمان توسط زیگموند در Unsplash .
،از ناحیه نوار عنوان در کنار کنترل های پنجره استفاده کنید تا PWA خود را بیشتر شبیه یک برنامه کنید.
اگر مقاله من را به خاطر بیاورید که PWA خود را بیشتر شبیه یک برنامه کنید ، ممکن است به یاد بیاورید که چگونه به شخصی سازی نوار عنوان برنامه خود به عنوان استراتژی برای ایجاد تجربه ای شبیه به برنامه اشاره کردم. در اینجا مثالی از نحوه نمایش برنامه پادکست macOS ارائه شده است.
اکنون ممکن است وسوسه شوید که با گفتن اینکه پادکست یک برنامه macOS مخصوص پلتفرم است که در مرورگر اجرا نمی شود و بنابراین می تواند آنچه را که می خواهد بدون نیاز به اجرای قوانین مرورگر انجام دهد، مخالفت کنید. درست است، اما خبر خوب این است که ویژگی Window Controls Overlay، که موضوع همین مقاله است، به زودی به شما امکان می دهد رابط های کاربری مشابهی برای PWA خود ایجاد کنید.
کنترل های پنجره اجزای پوشش
Windows Controls Overlay از چهار ویژگی فرعی تشکیل شده است:
- مقدار
"window-controls-overlay"
برای قسمت"display_override"
در مانیفست برنامه وب. - متغیرهای محیط CSS
titlebar-area-x
،titlebar-area-y
،titlebar-area-width
وtitlebar-area-height
. - استاندارد سازی ویژگی CSS قبلاً اختصاصی
-webkit-app-region
به عنوان ویژگیapp-region
برای تعریف مناطق قابل کشیدن در محتوای وب. - مکانیسمی برای پرس و جو و کار در اطراف منطقه کنترل پنجره از طریق عضو
windowControlsOverlay
ازwindow.navigator
.
پوشش کنترل پنجره چیست
منطقه نوار عنوان به فضای سمت چپ یا راست کنترل پنجره (یعنی دکمه های برای به حداقل رساندن ، به حداکثر رساندن ، بستن و غیره) اشاره دارد و اغلب حاوی عنوان برنامه است. کنترل های پنجره به برنامه های وب مترقی (PWAS) اجازه می دهد تا با تعویض نوار عنوان تمام عرض موجود برای یک پوشش کوچک حاوی کنترل های پنجره ، احساس برنامه ای مانند را فراهم کند. این به توسعه دهندگان این امکان را می دهد تا محتوای سفارشی را در آنچه که قبلاً منطقه نوار عنوان با کنترل مرورگر بود قرار دهند.
وضعیت فعلی
مرحله | وضعیت |
---|---|
1. توضیح دهنده ایجاد کنید | کامل شود |
2. پیش نویس اولیه مشخصات را ایجاد کنید | کامل شود |
3. بازخورد و تکرار در طراحی را جمع کنید | در حال انجام است |
4- محاکمه مبدا | کامل شود |
5. راه اندازی کنید | کامل (در کروم 104) |
نحوه استفاده از پوشش کنترل پنجره
افزودن window-controls-overlay
به مانیفست برنامه وب
یک برنامه وب مترقی می تواند با اضافه کردن "window-controls-overlay"
به عنوان عضو اصلی "display_override"
در برنامه وب ، به پوشش کنترل پنجره بپردازد:
{
"display_override": ["window-controls-overlay"]
}
پوشش کنترل پنجره فقط در شرایطی که تمام شرایط زیر راضی باشد قابل مشاهده خواهد بود:
- برنامه در مرورگر باز نمی شود ، بلکه در یک پنجره جداگانه PWA است.
- مانیفست شامل
"display_override": ["window-controls-overlay"]
. (مقادیر دیگر پس از آن مجاز است.) - PWA روی سیستم عامل دسک تاپ کار می کند.
- منشأ فعلی با منشاء نصب شده PWA مطابقت دارد.
نتیجه این یک قسمت نوار عنوان خالی است که بسته به سیستم عامل ، کنترل های پنجره معمولی در سمت چپ یا راست را کنترل می کند.
انتقال محتوا به نوار عنوان
اکنون که در نوار عنوان فضا وجود دارد ، می توانید چیزی را در آنجا جابجا کنید. برای این مقاله ، من یک محتوای PWA ویکی مدیا ساختم. یک ویژگی مفید برای این برنامه ممکن است جستجوی کلمات در عناوین مقاله باشد. HTML برای ویژگی جستجو به این شکل است:
<div class="search">
<img src="logo.svg" alt="Wikimedia logo." width="32" height="32" />
<label>
<input type="search" />
Search for words in articles
</label>
</div>
برای انتقال این div
به نوار عنوان ، برخی از CSS مورد نیاز است:
.search {
/* Make sure the `div` stays there, even when scrolling. */
position: fixed;
/**
* Gradient, because why not. Endless opportunities.
* The gradient ends in `#36c`, which happens to be the app's
* `<meta name="theme-color" content="#36c">`.
*/
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
/* Use the environment variable for the left anchoring with a fallback. */
left: env(titlebar-area-x, 0);
/* Use the environment variable for the top anchoring with a fallback. */
top: env(titlebar-area-y, 0);
/* Use the environment variable for setting the width with a fallback. */
width: env(titlebar-area-width, 100%);
/* Use the environment variable for setting the height with a fallback. */
height: env(titlebar-area-height, 33px);
}
می توانید تأثیر این کد را در تصویر زیر مشاهده کنید. نوار عنوان کاملاً پاسخگو است. هنگامی که پنجره PWA را تغییر اندازه می دهید ، نوار عنوان واکنش نشان می دهد که گویی از محتوای منظم HTML تشکیل شده است ، که در واقع چنین است.
تعیین کدام قسمت از نوار عنوان قابل کشیدن است
در حالی که تصویر بالا نشان می دهد که شما تمام شده اید ، هنوز کاملاً انجام نشده است. پنجره PWA دیگر قابل کشش نیست (جدا از یک منطقه بسیار کوچک) ، زیرا دکمه های کنترل پنجره مناطق کشیده نیستند و بقیه نوار عنوان شامل ویجت جستجو است. این کار را با استفاده از ویژگی CSS app-region
با مقدار drag
برطرف کنید. در مورد بتونی ، خوب است که همه چیز را علاوه بر عنصر input
قابل کشش بسازیم.
/* The entire search `div` is draggable… */
.search {
-webkit-app-region: drag;
app-region: drag;
}
/* …except for the `input`. */
input {
-webkit-app-region: no-drag;
app-region: no-drag;
}
با استفاده از این CSS ، کاربر می تواند با کشیدن div
، img
یا label
، پنجره برنامه را طبق معمول بکشد. فقط عنصر input
تعاملی است بنابراین می توان پرس و جو جستجو را وارد کرد.
تشخیص ویژگی
پشتیبانی از پوشش کنترل پنجره با آزمایش وجود windowControlsOverlay
را می توان تشخیص داد:
if ('windowControlsOverlay' in navigator) {
// Window Controls Overlay is supported.
}
پرس و جو منطقه کنترل پنجره با windowControlsOverlay
کد تاکنون یک مشکل دارد: در بعضی از سیستم عامل ها کنترل های پنجره در سمت راست قرار دارند و در بعضی دیگر آنها در سمت چپ قرار دارند. برای بدتر شدن اوضاع ، منوی Chrome "سه نقطه" نیز بر اساس سکو ، موقعیت را تغییر می دهد. این بدان معنی است که تصویر پس زمینه شیب خطی باید به صورت پویا سازگار شود تا از #131313
→ maroon
یا maroon
→ #131313
→ maroon
اجرا شود ، به طوری که با رنگ پس زمینه maroon
نوار عنوان که توسط <meta name="theme-color" content="maroon">
تعیین می شود ، مخلوط شود <meta name="theme-color" content="maroon">
. این امر می تواند با پرس و جو از API getTitlebarAreaRect()
در ویژگی navigator.windowControlsOverlay
حاصل شود.
if ('windowControlsOverlay' in navigator) {
const { x } = navigator.windowControlsOverlay.getTitlebarAreaRect();
// Window controls are on the right (like on Windows).
// Chrome menu is left of the window controls.
// [ windowControlsOverlay___________________ […] [_] [■] [X] ]
if (x === 0) {
div.classList.add('search-controls-right');
}
// Window controls are on the left (like on macOS).
// Chrome menu is right of the window controls overlay.
// [ [X] [_] [■] ___________________windowControlsOverlay [⋮] ]
else {
div.classList.add('search-controls-left');
}
} else {
// When running in a non-supporting browser tab.
div.classList.add('search-controls-right');
}
کد اصلاح شده به جای داشتن تصویر پس زمینه در کلاس .search
Class CSS (مانند گذشته) ، اکنون از دو کلاس استفاده می کند که کد فوق به صورت پویا تعیین می کند.
/* For macOS: */
.search-controls-left {
background-image: linear-gradient(90deg, #36c, 45%, #131313, 90%, #36c);
}
/* For Windows: */
.search-controls-right {
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
}
تعیین اینکه آیا پوشش کنترل پنجره قابل مشاهده است
پوشش کنترل پنجره در هر شرایطی در منطقه نوار عنوان قابل مشاهده نخواهد بود. در حالی که طبیعتاً در مرورگرهایی وجود نخواهد داشت که از ویژگی های پوشش کنترل پنجره پشتیبانی نمی کنند ، وقتی PWA مورد نظر در یک برگه اجرا می شود ، در آنجا نخواهد بود. برای تشخیص این وضعیت ، می توانید از ویژگی visible
windowControlsOverlay
پرس و جو کنید:
if (navigator.windowControlsOverlay.visible) {
// The window controls overlay is visible in the title bar area.
}
از طرف دیگر ، شما همچنین می توانید از پرس و جو رسانه ای display-mode
در JavaScript و/یا CSS استفاده کنید:
// Create the query list.
const mediaQueryList = window.matchMedia('(display-mode: window-controls-overlay)');
// Define a callback function for the event listener.
function handleDisplayModeChange(mql) {
// React on display mode changes.
}
// Run the display mode change handler once.
handleDisplayChange(mediaQueryList);
// Add the callback function as a listener to the query list.
mediaQueryList.addEventListener('change', handleDisplayModeChange);
@media (display-mode: window-controls-overlay) {
/* React on display mode changes. */
}
از تغییرات هندسه مطلع می شود
پرس و جو از منطقه کنترل پنجره با getTitlebarAreaRect()
می تواند برای موارد یک طرفه مانند تنظیم تصویر پس زمینه صحیح بر اساس جایی که کنترل پنجره ها وجود دارد ، کافی باشد ، اما در موارد دیگر ، کنترل ریز دانه بیشتر ضروری است. به عنوان مثال ، یک مورد استفاده احتمالی می تواند تطبیق پوشش های کنترل پنجره بر اساس فضای موجود و اضافه کردن یک شوخی درست در پوشش کنترل پنجره در هنگام وجود فضای کافی باشد.
با عضویت در navigator.windowControlsOverlay.ongeometrychange
یا با تنظیم شنونده رویداد برای رویداد geometrychange
می توانید از تغییرات هندسه مطلع شوید. این رویداد فقط هنگامی آتش می گیرد که پوشش کنترل پنجره قابل مشاهده باشد ، یعنی وقتی navigator.windowControlsOverlay.visible
true
است.
const debounce = (func, wait) => {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func(...args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
};
if ('windowControlsOverlay' in navigator) {
navigator.windowControlsOverlay.ongeometrychange = debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250);
}
به جای اختصاص یک تابع به ongeometrychange
، می توانید یک شنونده رویداد را نیز به windowControlsOverlay
به شرح زیر اضافه کنید. می توانید در مورد تفاوت بین این دو در MDN بخوانید.
navigator.windowControlsOverlay.addEventListener(
'geometrychange',
debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250),
);
سازگاری هنگام کار در یک برگه و مرورگرهای غیر پشتیبانی
دو مورد ممکن برای در نظر گرفتن وجود دارد:
- موردی که یک برنامه در یک مرورگر در حال اجرا است که از پوشش کنترل پنجره ها پشتیبانی می کند ، اما جایی که برنامه در یک برگه مرورگر استفاده می شود.
- موردی که یک برنامه در یک مرورگر در حال اجرا است که از پوشش کنترل پنجره پشتیبانی نمی کند .
در هر دو مورد ، به طور پیش فرض HTML ساخته شده برای کنترل پنجره ها به صورت داخلی مانند محتوای HTML معمولی نمایش داده می شود و مقادیر برگشتی متغیرهای env()
برای موقعیت یابی شروع می شود. در مورد مرورگرهای پشتیبانی ، همچنین می توانید با بررسی ویژگی visible
روکش ، HTML تعیین شده برای کنترل پنجره ها را نمایش ندهید ، و اگر false
گزارش می کند ، سپس آن محتوای HTML را پنهان کنید.
به عنوان یک یادآوری ، مرورگرهای غیر پشتیبانی یا به هیچ وجه ویژگی "display_override"
را در نظر نمی گیرند ، یا "window-controls-overlay"
"standalone"
.
ملاحظات UI
در حالی که ممکن است وسوسه انگیز باشد ، ایجاد یک منوی کشویی کلاسیک در قسمت Overlay Controls Window Controls توصیه نمی شود. با انجام این کار ، دستورالعمل های طراحی در MACOS را نقض می کند ، سکویی که کاربران از آن انتظار می رود میله های منو (هم از سیستم های ارائه شده با سیستم و هم سفارشی) در بالای صفحه باشد.
اگر برنامه شما یک تجربه تمام صفحه را ارائه می دهد ، با دقت در نظر بگیرید که آیا این امر باعث می شود که کنترل های پنجره شما بخشی از نمای تمام صفحه باشد. به طور بالقوه ممکن است بخواهید هنگام آتش سوزی رویداد onfullscreenchange
، طرح خود را دوباره تنظیم کنید.
نسخه ی نمایشی
من یک نسخه ی نمایشی ایجاد کرده ام که می توانید در مرورگرهای مختلف پشتیبانی و غیر پشتیبانی و در حالت نصب شده و غیر نصب شده با آن بازی کنید. برای تجربه واقعی کنترل پنجره ، باید برنامه را نصب کنید. می توانید دو تصویر از آنچه در زیر انتظار دارید را ببینید. کد منبع برنامه در Glitch در دسترس است.
ویژگی جستجو در پوشش Window Controls کاملاً کاربردی است:
ملاحظات امنیتی
تیم Chromium با استفاده از اصول اصلی تعریف شده در کنترل دسترسی به ویژگی های قدرتمند بستر های نرم افزاری وب ، از جمله کنترل کاربر ، شفافیت و ارگونومی ، API Overlay Window Controls را طراحی و پیاده سازی کرده است.
جعل
کنترل جزئی از نوار عنوان ، اتاق را برای توسعه دهندگان فراهم می کند تا محتوای خود را در منطقه مورد اعتماد و کنترل شده مرورگر قرار دهند. در حال حاضر ، در مرورگرهای کروم ، حالت مستقل شامل یک نوار عنوان است که در راه اندازی اولیه عنوان صفحه وب را در سمت چپ نشان می دهد و منشأ صفحه در سمت راست (به دنبال آن دکمه "تنظیمات و بیشتر" و کنترل پنجره ها) . پس از چند ثانیه ، متن مبدا ناپدید می شود. اگر مرورگر روی یک زبان راست به چپ (RTL) تنظیم شود ، این طرح به گونه ای تلنگر می شود که متن مبدا در سمت چپ باشد. در صورت عدم وجود بالشتک کافی بین مبدا و لبه سمت راست پوشش ، این پوشش را کنترل می کند تا منشأ را فریب دهد. به عنوان مثال ، مبدا "evil.ltd" می تواند با یک سایت قابل اعتماد "google.com" ضمیمه شود و کاربران را به این باور برساند که این منبع قابل اعتماد است. برنامه این است که این متن مبدا را حفظ کنیم تا کاربران بدانند که منشأ برنامه چیست و می تواند اطمینان حاصل کند که با انتظارات آنها مطابقت دارد. برای مرورگرهای پیکربندی شده RTL ، باید به اندازه کافی در سمت راست متن مبدا وجود داشته باشد تا از یک وب سایت مخرب از منشأ ناامن با منشأ معتبر جلوگیری کند.
انگشت نگاری
فعال کردن پوشش های پوشش پنجره و مناطق قابل کشیدن ، نگرانی های حریم خصوصی قابل توجهی به غیر از تشخیص ویژگی ایجاد نمی کند. با این حال ، به دلیل اندازه و موقعیت های مختلف دکمه های کنترل پنجره در سیستم عامل ، navigator. windowControlsOverlay. getTitlebarAreaRect()
روش navigator. windowControlsOverlay. getTitlebarAreaRect()
یک DOMRect
برمی گرداند که موقعیت و ابعاد آن اطلاعات مربوط به سیستم عامل را که در آن مرورگر در حال اجرا است ، نشان می دهد. در حال حاضر ، توسعه دهندگان می توانند سیستم عامل را از رشته عامل کاربر کشف کنند ، اما به دلیل نگرانی های اثر انگشت ، بحث در مورد انجماد رشته UA و متحد کردن نسخه های سیستم عامل وجود دارد. تلاش مداوم در جامعه مرورگر وجود دارد تا بفهمد که چقدر اندازه پنجره ها در سکوها تغییر می کنند ، زیرا فرض فعلی این است که اینها در نسخه های سیستم عامل نسبتاً پایدار هستند و بنابراین برای مشاهده نسخه های جزئی سیستم عامل مفید نیستند. اگرچه این یک مسئله احتمالی اثر انگشت است ، اما فقط در مورد PWA های نصب شده که از ویژگی نوار عنوان سفارشی استفاده می کنند ، صدق می کند و در مورد استفاده عمومی مرورگر صدق نمی کند. علاوه بر این ، navigator. windowControlsOverlay
API در دسترس Iframes تعبیه شده در داخل PWA نخواهد بود.
ناوبری
پیمایش به منشأ متفاوت در PWA باعث می شود که آن را به نوار عنوان عادی مستقل برگردانید ، حتی اگر معیارهای فوق را برآورده کند و با پوشش کنترل پنجره ها راه اندازی شود. این برای اسکان نوار سیاه است که در ناوبری با منشأ متفاوت ظاهر می شود. پس از حرکت به منشأ اصلی ، از پوشش کنترل پنجره دوباره استفاده می شود.
بازخورد
تیم Chromium می خواهد در مورد تجربیات شما با API Overlay Controls Windows Controls بشنود.
در مورد طرح API برای ما بگویید
آیا چیزی در مورد API وجود دارد که همانطور که انتظار داشتید کار نمی کند؟ یا آیا روش ها یا خصوصیات گمشده ای وجود دارد که برای پیاده سازی ایده خود نیاز دارید؟ در مورد مدل امنیتی یک سوال یا اظهار نظر دارید؟ یک شماره مشخص را در مورد repo مربوطه GitHub ثبت کنید ، یا افکار خود را به یک مسئله موجود اضافه کنید.
گزارش یک مشکل در اجرای
آیا با اجرای کروم اشکالی پیدا کردید؟ یا آیا اجرای آن با مشخصات متفاوت است؟ یک اشکال را در new.crbug.com ثبت کنید. حتماً جزئیات بیشتری را در اختیار شما قرار دهید ، دستورالعمل های ساده ای برای تولید مثل ، و UI>Browser>WebAppInstalls
را در کادر اجزای وارد کنید. Glitch برای به اشتراک گذاشتن سریع و آسان دوباره کار می کند.
پشتیبانی از API را نشان دهید
آیا قصد دارید از API Overlay Controls Window Controls استفاده کنید؟ پشتیبانی عمومی شما به تیم Chromium کمک می کند تا ویژگی ها را در اولویت قرار دهد و سایر فروشندگان مرورگر را نشان می دهد که پشتیبانی از آنها چقدر مهم است.
با هشتگ #WindowControlsOverlay
یک توییت به chromiumdev ارسال کنید و به ما اطلاع دهید که از کجا و چگونه از آن استفاده می کنید.
لینک های مفید
- توضیح دهنده
- پیش نویس مشخصات
- اشکال
- ورود وضعیت بستر های نرم افزاری Chrome
- بررسی برچسب
- اسناد مرتبط با مایکروسافت Edge
قدردانی
پوشش کنترل پنجره توسط آماندا بیکر از تیم مایکروسافت Edge اجرا و مشخص شد. این مقاله توسط جو مدلی و کنت روهدی کریستینسن بررسی شده است. تصویر قهرمان توسط Sigmund در Unsplash .
،از قسمت نوار عنوان در کنار کنترل های پنجره استفاده کنید تا PWA شما بیشتر شبیه یک برنامه باشد.
اگر به یاد دارید مقاله من باعث می شود PWA شما بیشتر شبیه یک برنامه باشد ، ممکن است به یاد بیاورید که چگونه من به سفارشی کردن نوار عنوان برنامه خود به عنوان یک استراتژی برای ایجاد یک تجربه بیشتر برنامه اشاره کردم. در اینجا نمونه ای از چگونگی این امر می تواند به نمایش درآمدهای MacOS Podcasts ارائه شود.
اکنون ممکن است شما با گفتن اینکه پادکست ها یک برنامه MACOS خاص پلتفرم است که در یک مرورگر اجرا نمی شود و بنابراین می توانید بدون نیاز به بازی طبق قوانین مرورگر ، وسوسه شوید. درست است ، اما خبر خوب این است که ویژگی Window Controls Overlay ، که موضوع این مقاله است ، به زودی به شما امکان می دهد رابط های کاربر مشابه را برای PWA خود ایجاد کنید.
اجزای روکش کنترل پنجره
پوشش کنترل پنجره شامل چهار ویژگی فرعی است:
- مقدار
"window-controls-overlay"
برای قسمت"display_override"
در مانیفست برنامه وب. - متغیرهای محیط CSS
titlebar-area-x
،titlebar-area-y
،titlebar-area-width
وtitlebar-area-height
. - استاندارد سازی ویژگی CSS قبلاً اختصاصی
-webkit-app-region
به عنوان ویژگیapp-region
برای تعریف مناطق قابل کشیدن در محتوای وب. - مکانیسمی برای پرس و جو و کار در اطراف منطقه کنترل پنجره از طریق عضو
windowControlsOverlay
ازwindow.navigator
.
پوشش کنترل پنجره چیست
منطقه نوار عنوان به فضای سمت چپ یا راست کنترل پنجره (یعنی دکمه های برای به حداقل رساندن ، به حداکثر رساندن ، بستن و غیره) اشاره دارد و اغلب حاوی عنوان برنامه است. کنترل های پنجره به برنامه های وب مترقی (PWAS) اجازه می دهد تا با تعویض نوار عنوان تمام عرض موجود برای یک پوشش کوچک حاوی کنترل های پنجره ، احساس برنامه ای مانند را فراهم کند. این به توسعه دهندگان این امکان را می دهد تا محتوای سفارشی را در آنچه که قبلاً منطقه نوار عنوان با کنترل مرورگر بود قرار دهند.
وضعیت فعلی
مرحله | وضعیت |
---|---|
1. توضیح دهنده ایجاد کنید | کامل شود |
2. پیش نویس اولیه مشخصات را ایجاد کنید | کامل شود |
3. بازخورد و تکرار در طراحی را جمع کنید | در حال انجام است |
4- محاکمه مبدا | کامل شود |
5. راه اندازی کنید | کامل (در کروم 104) |
نحوه استفاده از پوشش کنترل پنجره
افزودن window-controls-overlay
به مانیفست برنامه وب
یک برنامه وب مترقی می تواند با اضافه کردن "window-controls-overlay"
به عنوان عضو اصلی "display_override"
در برنامه وب ، به پوشش کنترل پنجره بپردازد:
{
"display_override": ["window-controls-overlay"]
}
پوشش کنترل پنجره فقط در شرایطی که تمام شرایط زیر راضی باشد قابل مشاهده خواهد بود:
- برنامه در مرورگر باز نمی شود ، بلکه در یک پنجره جداگانه PWA است.
- مانیفست شامل
"display_override": ["window-controls-overlay"]
. (مقادیر دیگر پس از آن مجاز است.) - PWA روی سیستم عامل دسک تاپ کار می کند.
- منشأ فعلی با منشاء نصب شده PWA مطابقت دارد.
نتیجه این یک قسمت نوار عنوان خالی است که بسته به سیستم عامل ، کنترل های پنجره معمولی در سمت چپ یا راست را کنترل می کند.
انتقال محتوا به نوار عنوان
اکنون که در نوار عنوان فضا وجود دارد ، می توانید چیزی را در آنجا جابجا کنید. برای این مقاله ، من یک محتوای PWA ویکی مدیا ساختم. یک ویژگی مفید برای این برنامه ممکن است جستجوی کلمات در عناوین مقاله باشد. HTML برای ویژگی جستجو به این شکل است:
<div class="search">
<img src="logo.svg" alt="Wikimedia logo." width="32" height="32" />
<label>
<input type="search" />
Search for words in articles
</label>
</div>
برای انتقال این div
به نوار عنوان ، برخی از CSS مورد نیاز است:
.search {
/* Make sure the `div` stays there, even when scrolling. */
position: fixed;
/**
* Gradient, because why not. Endless opportunities.
* The gradient ends in `#36c`, which happens to be the app's
* `<meta name="theme-color" content="#36c">`.
*/
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
/* Use the environment variable for the left anchoring with a fallback. */
left: env(titlebar-area-x, 0);
/* Use the environment variable for the top anchoring with a fallback. */
top: env(titlebar-area-y, 0);
/* Use the environment variable for setting the width with a fallback. */
width: env(titlebar-area-width, 100%);
/* Use the environment variable for setting the height with a fallback. */
height: env(titlebar-area-height, 33px);
}
می توانید تأثیر این کد را در تصویر زیر مشاهده کنید. نوار عنوان کاملاً پاسخگو است. هنگامی که پنجره PWA را تغییر اندازه می دهید ، نوار عنوان واکنش نشان می دهد که گویی از محتوای منظم HTML تشکیل شده است ، که در واقع چنین است.
تعیین کدام قسمت از نوار عنوان قابل کشیدن است
در حالی که تصویر بالا نشان می دهد که شما تمام شده اید ، هنوز کاملاً انجام نشده است. پنجره PWA دیگر قابل کشش نیست (جدا از یک منطقه بسیار کوچک) ، زیرا دکمه های کنترل پنجره مناطق کشیده نیستند و بقیه نوار عنوان شامل ویجت جستجو است. این کار را با استفاده از ویژگی CSS app-region
با مقدار drag
برطرف کنید. در مورد بتونی ، خوب است که همه چیز را علاوه بر عنصر input
قابل کشش بسازیم.
/* The entire search `div` is draggable… */
.search {
-webkit-app-region: drag;
app-region: drag;
}
/* …except for the `input`. */
input {
-webkit-app-region: no-drag;
app-region: no-drag;
}
با استفاده از این CSS ، کاربر می تواند با کشیدن div
، img
یا label
، پنجره برنامه را طبق معمول بکشد. فقط عنصر input
تعاملی است بنابراین می توان پرس و جو جستجو را وارد کرد.
تشخیص ویژگی
پشتیبانی از پوشش کنترل پنجره با آزمایش وجود windowControlsOverlay
را می توان تشخیص داد:
if ('windowControlsOverlay' in navigator) {
// Window Controls Overlay is supported.
}
پرس و جو منطقه کنترل پنجره با windowControlsOverlay
کد تاکنون یک مشکل دارد: در بعضی از سیستم عامل ها کنترل های پنجره در سمت راست قرار دارند و در بعضی دیگر آنها در سمت چپ قرار دارند. برای بدتر شدن اوضاع ، منوی Chrome "سه نقطه" نیز بر اساس سکو ، موقعیت را تغییر می دهد. این بدان معنی است که تصویر پس زمینه شیب خطی باید به صورت پویا سازگار شود تا از #131313
→ maroon
یا maroon
→ #131313
→ maroon
اجرا شود ، به طوری که با رنگ پس زمینه maroon
نوار عنوان که توسط <meta name="theme-color" content="maroon">
تعیین می شود ، مخلوط شود <meta name="theme-color" content="maroon">
. این امر می تواند با پرس و جو از API getTitlebarAreaRect()
در ویژگی navigator.windowControlsOverlay
حاصل شود.
if ('windowControlsOverlay' in navigator) {
const { x } = navigator.windowControlsOverlay.getTitlebarAreaRect();
// Window controls are on the right (like on Windows).
// Chrome menu is left of the window controls.
// [ windowControlsOverlay___________________ […] [_] [■] [X] ]
if (x === 0) {
div.classList.add('search-controls-right');
}
// Window controls are on the left (like on macOS).
// Chrome menu is right of the window controls overlay.
// [ [X] [_] [■] ___________________windowControlsOverlay [⋮] ]
else {
div.classList.add('search-controls-left');
}
} else {
// When running in a non-supporting browser tab.
div.classList.add('search-controls-right');
}
کد اصلاح شده به جای داشتن تصویر پس زمینه در کلاس .search
Class CSS (مانند گذشته) ، اکنون از دو کلاس استفاده می کند که کد فوق به صورت پویا تعیین می کند.
/* For macOS: */
.search-controls-left {
background-image: linear-gradient(90deg, #36c, 45%, #131313, 90%, #36c);
}
/* For Windows: */
.search-controls-right {
background-image: linear-gradient(90deg, #36c, #131313, 33%, #36c);
}
تعیین اینکه آیا پوشش کنترل پنجره قابل مشاهده است
پوشش کنترل پنجره در هر شرایطی در منطقه نوار عنوان قابل مشاهده نخواهد بود. در حالی که طبیعتاً در مرورگرهایی وجود نخواهد داشت که از ویژگی های پوشش کنترل پنجره پشتیبانی نمی کنند ، وقتی PWA مورد نظر در یک برگه اجرا می شود ، در آنجا نخواهد بود. برای تشخیص این وضعیت ، می توانید از ویژگی visible
windowControlsOverlay
پرس و جو کنید:
if (navigator.windowControlsOverlay.visible) {
// The window controls overlay is visible in the title bar area.
}
از طرف دیگر ، شما همچنین می توانید از پرس و جو رسانه ای display-mode
در JavaScript و/یا CSS استفاده کنید:
// Create the query list.
const mediaQueryList = window.matchMedia('(display-mode: window-controls-overlay)');
// Define a callback function for the event listener.
function handleDisplayModeChange(mql) {
// React on display mode changes.
}
// Run the display mode change handler once.
handleDisplayChange(mediaQueryList);
// Add the callback function as a listener to the query list.
mediaQueryList.addEventListener('change', handleDisplayModeChange);
@media (display-mode: window-controls-overlay) {
/* React on display mode changes. */
}
از تغییرات هندسه مطلع می شود
پرس و جو از منطقه کنترل پنجره با getTitlebarAreaRect()
می تواند برای موارد یک طرفه مانند تنظیم تصویر پس زمینه صحیح بر اساس جایی که کنترل پنجره ها وجود دارد ، کافی باشد ، اما در موارد دیگر ، کنترل ریز دانه بیشتر ضروری است. به عنوان مثال ، یک مورد استفاده احتمالی می تواند تطبیق پوشش های کنترل پنجره بر اساس فضای موجود و اضافه کردن یک شوخی درست در پوشش کنترل پنجره در هنگام وجود فضای کافی باشد.
با عضویت در navigator.windowControlsOverlay.ongeometrychange
یا با تنظیم شنونده رویداد برای رویداد geometrychange
می توانید از تغییرات هندسه مطلع شوید. این رویداد فقط هنگامی آتش می گیرد که پوشش کنترل پنجره قابل مشاهده باشد ، یعنی وقتی navigator.windowControlsOverlay.visible
true
است.
const debounce = (func, wait) => {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func(...args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
};
if ('windowControlsOverlay' in navigator) {
navigator.windowControlsOverlay.ongeometrychange = debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250);
}
به جای اختصاص یک تابع به ongeometrychange
، می توانید یک شنونده رویداد را نیز به windowControlsOverlay
به شرح زیر اضافه کنید. می توانید در مورد تفاوت بین این دو در MDN بخوانید.
navigator.windowControlsOverlay.addEventListener(
'geometrychange',
debounce((e) => {
span.hidden = e.titlebarAreaRect.width < 800;
}, 250),
);
سازگاری هنگام کار در یک برگه و مرورگرهای غیر پشتیبانی
دو مورد ممکن برای در نظر گرفتن وجود دارد:
- موردی که یک برنامه در یک مرورگر در حال اجرا است که از پوشش کنترل پنجره ها پشتیبانی می کند ، اما جایی که برنامه در یک برگه مرورگر استفاده می شود.
- موردی که یک برنامه در یک مرورگر در حال اجرا است که از پوشش کنترل پنجره پشتیبانی نمی کند .
در هر دو مورد ، به طور پیش فرض HTML ساخته شده برای کنترل پنجره ها به صورت داخلی مانند محتوای HTML معمولی نمایش داده می شود و مقادیر برگشتی متغیرهای env()
برای موقعیت یابی شروع می شود. در مورد مرورگرهای پشتیبانی ، همچنین می توانید با بررسی ویژگی visible
روکش ، HTML تعیین شده برای کنترل پنجره ها را نمایش ندهید ، و اگر false
گزارش می کند ، سپس آن محتوای HTML را پنهان کنید.
به عنوان یک یادآوری ، مرورگرهای غیر پشتیبانی یا به هیچ وجه ویژگی "display_override"
را در نظر نمی گیرند ، یا "window-controls-overlay"
"standalone"
.
ملاحظات UI
در حالی که ممکن است وسوسه انگیز باشد ، ایجاد یک منوی کشویی کلاسیک در قسمت Overlay Controls Window Controls توصیه نمی شود. با انجام این کار ، دستورالعمل های طراحی در MACOS را نقض می کند ، سکویی که کاربران از آن انتظار می رود میله های منو (هم از سیستم های ارائه شده با سیستم و هم سفارشی) در بالای صفحه باشد.
اگر برنامه شما یک تجربه تمام صفحه را ارائه می دهد ، با دقت در نظر بگیرید که آیا این امر باعث می شود که کنترل های پنجره شما بخشی از نمای تمام صفحه باشد. به طور بالقوه ممکن است بخواهید هنگام آتش سوزی رویداد onfullscreenchange
، طرح خود را دوباره تنظیم کنید.
نسخه ی نمایشی
من یک نسخه ی نمایشی ایجاد کرده ام که می توانید در مرورگرهای مختلف پشتیبانی و غیر پشتیبانی و در حالت نصب شده و غیر نصب شده با آن بازی کنید. برای تجربه واقعی کنترل پنجره ، باید برنامه را نصب کنید. می توانید دو تصویر از آنچه در زیر انتظار دارید را ببینید. کد منبع برنامه در Glitch در دسترس است.
ویژگی جستجو در پوشش Window Controls کاملاً کاربردی است:
ملاحظات امنیتی
تیم Chromium با استفاده از اصول اصلی تعریف شده در کنترل دسترسی به ویژگی های قدرتمند بستر های نرم افزاری وب ، از جمله کنترل کاربر ، شفافیت و ارگونومی ، API Overlay Window Controls را طراحی و پیاده سازی کرده است.
جعل
کنترل جزئی از نوار عنوان ، اتاق را برای توسعه دهندگان فراهم می کند تا محتوای خود را در منطقه مورد اعتماد و کنترل شده مرورگر قرار دهند. در حال حاضر ، در مرورگرهای کروم ، حالت مستقل شامل یک نوار عنوان است که در راه اندازی اولیه عنوان صفحه وب را در سمت چپ نشان می دهد و منشأ صفحه در سمت راست (به دنبال آن دکمه "تنظیمات و بیشتر" و کنترل پنجره ها) . پس از چند ثانیه ، متن مبدا ناپدید می شود. اگر مرورگر روی یک زبان راست به چپ (RTL) تنظیم شود ، این طرح به گونه ای تلنگر می شود که متن مبدا در سمت چپ باشد. در صورت عدم وجود بالشتک کافی بین مبدا و لبه سمت راست پوشش ، این پوشش را کنترل می کند تا منشأ را فریب دهد. به عنوان مثال ، مبدا "evil.ltd" می تواند با یک سایت قابل اعتماد "google.com" ضمیمه شود و کاربران را به این باور برساند که این منبع قابل اعتماد است. برنامه این است که این متن مبدا را حفظ کنیم تا کاربران بدانند که منشأ برنامه چیست و می تواند اطمینان حاصل کند که با انتظارات آنها مطابقت دارد. برای مرورگرهای پیکربندی شده RTL ، باید به اندازه کافی در سمت راست متن مبدا وجود داشته باشد تا از یک وب سایت مخرب از منشأ ناامن با منشأ معتبر جلوگیری کند.
انگشت نگاری
فعال کردن پوشش های پوشش پنجره و مناطق قابل کشیدن ، نگرانی های حریم خصوصی قابل توجهی به غیر از تشخیص ویژگی ایجاد نمی کند. با این حال ، به دلیل اندازه و موقعیت های مختلف دکمه های کنترل پنجره در سیستم عامل ، navigator. windowControlsOverlay. getTitlebarAreaRect()
روش navigator. windowControlsOverlay. getTitlebarAreaRect()
یک DOMRect
برمی گرداند که موقعیت و ابعاد آن اطلاعات مربوط به سیستم عامل را که در آن مرورگر در حال اجرا است ، نشان می دهد. در حال حاضر ، توسعه دهندگان می توانند سیستم عامل را از رشته عامل کاربر کشف کنند ، اما به دلیل نگرانی های اثر انگشت ، بحث در مورد انجماد رشته UA و متحد کردن نسخه های سیستم عامل وجود دارد. تلاش مداوم در جامعه مرورگر وجود دارد تا بفهمد که چقدر اندازه پنجره ها در سکوها تغییر می کنند ، زیرا فرض فعلی این است که اینها در نسخه های سیستم عامل نسبتاً پایدار هستند و بنابراین برای مشاهده نسخه های جزئی سیستم عامل مفید نیستند. اگرچه این یک مسئله احتمالی اثر انگشت است ، اما فقط در مورد PWA های نصب شده که از ویژگی نوار عنوان سفارشی استفاده می کنند ، صدق می کند و در مورد استفاده عمومی مرورگر صدق نمی کند. علاوه بر این ، navigator. windowControlsOverlay
API در دسترس Iframes تعبیه شده در داخل PWA نخواهد بود.
ناوبری
پیمایش به منشأ متفاوت در PWA باعث می شود که آن را به نوار عنوان عادی مستقل برگردانید ، حتی اگر معیارهای فوق را برآورده کند و با پوشش کنترل پنجره ها راه اندازی شود. این برای اسکان نوار سیاه است که در ناوبری با منشأ متفاوت ظاهر می شود. پس از حرکت به منشأ اصلی ، از پوشش کنترل پنجره دوباره استفاده می شود.
بازخورد
تیم Chromium می خواهد در مورد تجربیات شما با API Overlay Controls Windows Controls بشنود.
در مورد طرح API برای ما بگویید
آیا چیزی در مورد API وجود دارد که همانطور که انتظار داشتید کار نمی کند؟ یا آیا روش ها یا خصوصیات گمشده ای وجود دارد که برای پیاده سازی ایده خود نیاز دارید؟ در مورد مدل امنیتی یک سوال یا اظهار نظر دارید؟ یک شماره مشخص را در مورد repo مربوطه GitHub ثبت کنید ، یا افکار خود را به یک مسئله موجود اضافه کنید.
گزارش یک مشکل در اجرای
آیا با اجرای کروم اشکالی پیدا کردید؟ یا آیا اجرای آن با مشخصات متفاوت است؟ یک اشکال را در new.crbug.com ثبت کنید. حتماً جزئیات بیشتری را در اختیار شما قرار دهید ، دستورالعمل های ساده ای برای تولید مثل ، و UI>Browser>WebAppInstalls
را در کادر اجزای وارد کنید. Glitch برای به اشتراک گذاشتن سریع و آسان دوباره کار می کند.
پشتیبانی از API را نشان دهید
آیا قصد دارید از API Overlay Controls Window Controls استفاده کنید؟ پشتیبانی عمومی شما به تیم Chromium کمک می کند تا ویژگی ها را در اولویت قرار دهد و سایر فروشندگان مرورگر را نشان می دهد که پشتیبانی از آنها چقدر مهم است.
با هشتگ #WindowControlsOverlay
یک توییت به chromiumdev ارسال کنید و به ما اطلاع دهید که از کجا و چگونه از آن استفاده می کنید.
لینک های مفید
- توضیح دهنده
- پیش نویس مشخصات
- اشکال
- ورود وضعیت بستر های نرم افزاری Chrome
- بررسی برچسب
- اسناد مرتبط با مایکروسافت Edge
قدردانی
پوشش کنترل پنجره توسط آماندا بیکر از تیم مایکروسافت Edge اجرا و مشخص شد. این مقاله توسط جو مدلی و کنت روهدی کریستینسن بررسی شده است. تصویر قهرمان توسط Sigmund در Unsplash .