แบนเนอร์แบบปรับขนาดได้เป็นโฆษณาที่ปรับเปลี่ยนตามพื้นที่โฆษณารุ่นถัดไป ซึ่งเพิ่มประสิทธิภาพสูงสุดด้วยการเพิ่มประสิทธิภาพขนาดโฆษณาสำหรับอุปกรณ์แต่ละชนิด การปรับปรุงบนแบนเนอร์อัจฉริยะ ซึ่งรองรับเฉพาะความสูงคงที่เท่านั้น แบนเนอร์แบบปรับขนาดได้จะช่วยให้คุณระบุความกว้างของโฆษณาและใช้เกณฑ์นี้เพื่อกำหนดขนาดโฆษณาที่ดีที่สุดได้
แบนเนอร์แบบปรับขนาดได้จะใช้สัดส่วนภาพแบบคงที่แทนการใช้ความสูงคงที่ในการเลือกขนาดโฆษณาที่ดีที่สุด ซึ่งส่งผลให้โฆษณาแบนเนอร์ใช้พื้นที่ที่สอดคล้องกับส่วนหนึ่งของหน้าจอในอุปกรณ์ต่างๆ และมอบโอกาสในการปรับปรุงประสิทธิภาพ
เมื่อทำงานร่วมกับแบนเนอร์แบบปรับขนาดได้ โปรดทราบว่าแบนเนอร์จะแสดงผลขนาดคงที่สำหรับอุปกรณ์และความกว้างหนึ่งๆ เสมอ เมื่อทดสอบการจัดวางบนอุปกรณ์ที่กำหนดแล้ว คุณก็มั่นใจได้ว่าขนาดโฆษณาจะไม่เปลี่ยนแปลง อย่างไรก็ตาม ขนาดของโฆษณาแบนเนอร์อาจแตกต่างกันไปตามอุปกรณ์ต่างๆ เราจึงขอแนะนำให้การออกแบบของคุณรองรับความสูงโฆษณาที่ต่างกัน ในกรณีที่เกิดขึ้นไม่บ่อยนัก ขนาดที่ปรับได้เต็มรูปแบบอาจไม่ได้รับการเติมโฆษณา และครีเอทีฟโฆษณาขนาดมาตรฐานจะอยู่ตรงกลางของช่องนี้แทน
ข้อกำหนดเบื้องต้น
กรณีที่ควรใช้แบนเนอร์แบบปรับขนาดได้
แบนเนอร์แบบปรับขนาดได้ออกแบบมาเพื่อแทนที่ทั้งแบนเนอร์ขนาด 320x50 ที่เป็นมาตรฐานอุตสาหกรรมและรูปแบบแบนเนอร์อัจฉริยะ ซึ่งมาแทนที่ทั้งแบนเนอร์ขนาดมาตรฐานอุตสาหกรรม
ขนาดแบนเนอร์เหล่านี้มักใช้เป็นแบนเนอร์แบบตรึงบนหน้าจอ ซึ่งมักจะยึดติดกับด้านบนหรือด้านล่างของหน้าจอ
สําหรับแบนเนอร์ยึดตำแหน่งดังกล่าว สัดส่วนภาพเมื่อใช้แบนเนอร์แบบปรับขนาดได้จะคล้ายกับโฆษณามาตรฐานขนาด 320x50 ดังที่แสดงในตัวอย่าง 3 ตัวอย่างต่อไปนี้
แบนเนอร์ 320x50 |
แบนเนอร์แบบปรับขนาดได้ |
แบนเนอร์อัจฉริยะ |
แบนเนอร์แบบปรับขนาดได้จะช่วยให้ใช้ขนาดหน้าจอที่มีอยู่ได้ดียิ่งขึ้น นอกจากนี้ เมื่อเปรียบเทียบกับแบนเนอร์อัจฉริยะแล้ว แบนเนอร์แบบปรับขนาดได้เป็นตัวเลือกที่ดีกว่าเนื่องจากเหตุผลดังต่อไปนี้
โดยใช้ความกว้างตามที่คุณระบุแทนที่จะบังคับให้มีความกว้างเต็มหน้าจอ ซึ่งจะช่วยให้คุณคำนึงถึงพื้นที่ปลอดภัยใน iOS และแสดงรอยต่อบน Android ได้
โดยจะเลือกความสูงที่เหมาะสมสําหรับอุปกรณ์หนึ่งๆ แทนที่จะมีความสูงคงที่ในอุปกรณ์ขนาดต่างๆ เพื่อช่วยลดผลกระทบของการแยกอุปกรณ์
หมายเหตุการใช้งาน
โปรดคำนึงถึงสิ่งต่อไปนี้เมื่อใช้แบนเนอร์แบบปรับขนาดได้ในแอป
- คุณต้องทราบความกว้างของมุมมองที่จะวางโฆษณา และต้องพิจารณาความกว้างของอุปกรณ์และพื้นที่ปลอดภัยหรือรอยต่อที่ใช้ได้
- ตรวจสอบว่าพื้นหลังของมุมมองโฆษณาทึบเพื่อให้สอดคล้องกับนโยบาย AdMob หากขนาดโฆษณาที่เล็กกว่าแสดงซึ่งไม่เติมให้กับช่องโฆษณา
- ตรวจสอบว่าคุณกำลังใช้ปลั๊กอิน Google Mobile Ads Unity เวอร์ชันล่าสุด สำหรับสื่อกลาง ให้ใช้อะแดปเตอร์สื่อกลางเวอร์ชันล่าสุดแต่ละรายการ
- ขนาดของแบนเนอร์แบบปรับขนาดได้ออกแบบมาให้ทำงานได้ดีที่สุดเมื่อใช้ความกว้างที่ใช้ได้ทั้งหมด ในกรณีส่วนใหญ่ ค่านี้จะเป็นความกว้างของหน้าจอ ของอุปกรณ์ที่มีการใช้งานอยู่ โปรดคำนึงถึงพื้นที่ปลอดภัยที่เกี่ยวข้อง
- SDK โฆษณาในอุปกรณ์เคลื่อนที่ของ Google จะปรับขนาดของแบนเนอร์ให้มีความสูงของโฆษณาที่เหมาะกับความกว้างที่กําหนดเมื่อใช้ AdSize API แบบปรับขนาดได้
- วิธีการรับขนาดโฆษณาแบบปรับขนาดได้มี 3 วิธี ได้แก่
AdSize.GetLandscapeAnchoredAdaptiveBannerAdSizeWithWidth
สำหรับแนวนอนAdSize.GetPortraitAnchoredAdaptiveBannerAdSizeWithWidth
สำหรับแนวตั้ง และAdSize.GetCurrentOrientationAnchoredAdaptiveBannerAdSizeWithWidth
สำหรับการวางแนวปัจจุบัน ณ เวลาที่มีการดำเนินการ - ขนาดที่แสดงผลสำหรับความกว้างที่กําหนดในอุปกรณ์จะเท่ากันเสมอ ดังนั้นเมื่อทดสอบเลย์เอาต์ในอุปกรณ์แล้ว คุณจึงมั่นใจได้ว่าขนาดโฆษณาจะไม่เปลี่ยนแปลง
- ความสูงของแบนเนอร์โฆษณา Anchor ต้องไม่มากกว่า 15% ของความสูงอุปกรณ์หรือความละเอียดพิกเซลอิสระ 90 พิกเซล และต้องไม่น้อยกว่า 50 พิกเซลอิสระด้านความหนาแน่น
- สำหรับแบนเนอร์ความกว้างเต็ม คุณใช้แฟล็ก
AdSize.FullWidth
แทนการกำหนดความกว้างที่เจาะจงได้
คู่มือเริ่มใช้งานฉบับย่อ
ทำตามขั้นตอนด้านล่างเพื่อใช้งานแบนเนอร์ยึดตำแหน่งที่ปรับเปลี่ยนได้อย่างง่าย
- ดูขนาดโฆษณาแบนเนอร์แบบปรับขนาดได้ ขนาดที่คุณได้รับจะใช้สำหรับขอแบนเนอร์แบบปรับขนาดได้ โปรดตรวจสอบสิ่งต่อไปนี้เพื่อรับขนาดโฆษณาแบบปรับขนาดได้
- ดูความกว้างของอุปกรณ์ที่ใช้งานเป็นพิกเซลอิสระตามความหนาแน่น หรือตั้งค่าความกว้างของคุณเองหากคุณไม่ต้องการใช้ความกว้างของหน้าจอแบบเต็ม
เนื่องจาก Unity API เช่น
Screen.width
แสดงผลพิกเซลสัมบูรณ์ คุณจึงต้องหารด้วยขนาดของอุปกรณ์ (ดึงได้จากMobileAds.Utils.GetDeviceScale()
) - ใช้แฟล็ก
AdSize.FullWidth
สำหรับแบนเนอร์ขนาดเต็ม - ใช้วิธีการแบบคงที่ที่เหมาะสมในคลาสขนาดโฆษณา เช่น
AdSize.getCurrentOrientationAnchoredAdaptiveBannerAdSizeWithWidth(width)
เพื่อรับออบเจ็กต์AdSize
แบบปรับขนาดได้สำหรับการวางแนวปัจจุบัน
- ดูความกว้างของอุปกรณ์ที่ใช้งานเป็นพิกเซลอิสระตามความหนาแน่น หรือตั้งค่าความกว้างของคุณเองหากคุณไม่ต้องการใช้ความกว้างของหน้าจอแบบเต็ม
เนื่องจาก Unity API เช่น
- สร้างออบเจ็กต์
BannerView
โดยใช้รหัสหน่วยโฆษณา ขนาดที่ปรับได้ และตำแหน่งที่เกี่ยวข้องสําหรับโฆษณา - สร้างออบเจ็กต์คำขอโฆษณาและโหลดแบนเนอร์โดยใช้เมธอด
LoadAd()
ในมุมมองโฆษณาที่เตรียมไว้ เช่นเดียวกับที่คุณทำกับคำขอแบนเนอร์ปกติ
ตัวอย่างโค้ด
ต่อไปนี้คือตัวอย่างสคริปต์ที่โหลดและโหลดแบนเนอร์แบบปรับขนาดได้ซ้ำเพื่อให้พอดีกับความกว้างของหน้าจอเมื่อคำนึงถึงพื้นที่ปลอดภัย
using UnityEngine;
using System;
using GoogleMobileAds.Api;
public class AdaptiveBannerSample : MonoBehaviour
{
private BannerView _bannerView;
// Use this for initialization
void Start()
{
// Set your test devices.
// https://developers.google.com/ad-manager/mobile-ads-sdk/unity/test-ads
RequestConfiguration requestConfiguration = new RequestConfiguration
{
TestDeviceIds = new List<string>
{
AdRequest.TestDeviceSimulator,
// Add your test device IDs (replace with your own device IDs).
#if UNITY_IPHONE
"96e23e80653bb28980d3f40beb58915c"
#elif UNITY_ANDROID
"75EF8D155528C04DACBBA6F36F433035"
#endif
}
};
MobileAds.SetRequestConfiguration(requestConfiguration);
// Initialize the Google Mobile Ads SDK.
MobileAds.Initialize((InitializationStatus status) =>
{
RequestBanner();
});
}
public void OnGUI()
{
GUI.skin.label.fontSize = 60;
Rect textOutputRect = new Rect(
0.15f * Screen.width,
0.25f * Screen.height,
0.7f * Screen.width,
0.3f * Screen.height);
GUI.Label(textOutputRect, "Adaptive Banner Example");
}
private void RequestBanner()
{
// These ad units are configured to always serve test ads.
#if UNITY_EDITOR
string adUnitId = "unused";
#elif UNITY_ANDROID
string adUnitId = "ca-app-pub-3212738706492790/6113697308";
#elif UNITY_IPHONE
string adUnitId = "ca-app-pub-3212738706492790/5381898163";
#else
string adUnitId = "unexpected_platform";
#endif
// Clean up banner ad before creating a new one.
if (_bannerView != null)
{
_bannerView.Destroy();
}
AdSize adaptiveSize =
AdSize.GetCurrentOrientationAnchoredAdaptiveBannerAdSizeWithWidth(AdSize.FullWidth);
_bannerView = new BannerView(adUnitId, adaptiveSize, AdPosition.Bottom);
// Register for ad events.
_bannerView.OnBannerAdLoaded += OnBannerAdLoaded;
_bannerView.OnBannerAdLoadFailed += OnBannerAdLoadFailed;
AdRequest adRequest = new AdRequest();
// Load a banner ad.
_bannerView.LoadAd(adRequest);
}
#region Banner callback handlers
private void OnBannerAdLoaded(object sender, EventArgs args)
{
Debug.Log("Banner view loaded an ad with response : "
+ _bannerView.GetResponseInfo());
Debug.Log("Ad Height: {0}, width: {1}",
_bannerView.GetHeightInPixels(),
_bannerView.GetWidthInPixels());
}
private void OnBannerAdLoadFailed(LoadAdError error)
{
Debug.LogError("Banner view failed to load an ad with error : "
+ error);
}
#endregion
}
ในที่นี้ใช้ฟังก์ชัน AdSize.GetCurrentOrientationAnchoredAdaptiveBannerAdSizeWithWidth
เพื่อดูขนาดของแบนเนอร์ในตำแหน่งที่มีการตรึงสำหรับการวางแนวของอินเทอร์เฟซปัจจุบัน สำหรับการโหลดแบนเนอร์ยึดตำแหน่งล่วงหน้าในการวางแนวที่กำหนด ให้ใช้ฟังก์ชันที่เกี่ยวข้องจาก AdSize.GetPortraitAnchoredAdaptiveBannerAdSizeWithWidth
และ AdSize.GetLandscapeAnchoredAdaptiveBannerAdSizeWithWidth