新媒體時代,廣告樣式越來越豐富。相較於傳統的圖文信息,視頻類廣告更具有直觀性,能夠讓消費者在瞭解產品知識和功能的同時加深對產品的印象。 因此在各類網站或App上投放視頻類廣告是個很好的宣傳方式,但廣告商們如果想在網站上展示視頻廣告,必須確保視頻廣告投放協議與發佈渠道的播放器相容;如果不能相容,廣告商 ...
新媒體時代,廣告樣式越來越豐富。相較於傳統的圖文信息,視頻類廣告更具有直觀性,能夠讓消費者在瞭解產品知識和功能的同時加深對產品的印象。
因此在各類網站或App上投放視頻類廣告是個很好的宣傳方式,但廣告商們如果想在網站上展示視頻廣告,必須確保視頻廣告投放協議與發佈渠道的播放器相容;如果不能相容,廣告商或者視頻廣告投放平臺必須創建不同的響應,來與特定視頻播放器相容。為此,互聯網廣告署(IAB)開發了視頻廣告投放模板 (VAST)這種 XML 模式,允許通過視頻廣告伺服器提供流內視頻廣告,併在多個網站和設備上的視頻播放器中播放,不僅解決相容性問題,還提高了視頻廣告投放的效率和可擴展性。
為幫助廣告商們更好投放廣告,華為鯨鴻動能平臺提供了HUAWEI VAST SDK的集成,目前僅支持符合VAST協議的線性廣告(投放形式為前、中、後貼片廣告)。
開發準備
集成SDK
使用VAST協議時需要集成HUAWEI VAST SDK。同時如果您需要使用預設的播放器,請集成HUAWEI Player SDK。
- 配置Maven倉地址。
Android Studio的代碼庫配置在Gradle 插件7.0以下版本、7.0版本和7.1及以上版本有所不同。請根據您當前的Gradle 插件版本,選擇對應的配置過程。
以7.0版本為例:
a) 打開Android Studio項目級“build.gradle”文件。
b) 添加Maven代碼庫。
在“buildscript > repositories”中配置Maven倉地址。
buildscript {
repositories {
google()
jcenter()
// 配置鯨鴻動能SDK的Maven倉地址
maven {url 'https://developer.huawei.com/repo/'}
}
}
c) 打開項目級“settings.gradle”文件,配置Maven倉地址。
dependencyResolutionManagement {
...
repositories {
google()
jcenter()
// 配置鯨鴻動能SDK的Maven倉地址
maven {url 'https://developer.huawei.com/repo/'}
}
}
配置網路許可權
在targetSdkVersion 28及以上的手機上允許HTTP(S)網路請求,在“AndroidManifest.xml”做以下配置。
<application
...
android:usesCleartextTraffic="true"
>
...
</application>
配置混淆腳本
您編譯APK前需要配置混淆配置文件,避免混淆HUAWEI VAST SDK導致功能異常。
打開Android工程應用級根目錄下的“proguard-rules.pro”混淆配置文件,加入排除HUAWEI VAST SDK的混淆配置。
-keep class com.huawei.openalliance.ad.** { *; }
-keep class com.huawei.hms.ads.** { *; }
初始化SDK
初始化HUAWEI VAST SDK
集成HUAWEI VAST SDK後,在應用的DemoApplication類中,初始化HUAWEI VAST SDK。
// 當用戶同意廣告服務獲取數據時,調用下麵的方法
SdkFactory.userAcceptAdLicense(true);
開發步驟
實現VAST廣告
使用預設播放器播放線性廣告
播放線性廣告可以使用預設的播放器,也可使用您實現的自定義播放器。
- 在XML文件中,初始化播放器的佈局。示例代碼如下:
<FrameLayout
android:id="@+id/fl_linear_ad"
android:layout_width="match_parent"
android:layout_height="250dp"
android:background="@android:color/black"
android:visibility="gone"
android:layout_alignParentEnd="true"
android:layout_alignParentStart="true"
android:layout_alignParentTop="true" />
```
2. 生成預設的廣告播放控制器,註冊線性廣告視圖。示例代碼如下:
private void registerLinearAdView() {
mLinearAdView = findViewById(R.id.fl_linear_ad);
mProgressBar = findViewById(R.id.progress);
VastAdPlayer.getInstance().registerLinearAdView(mLinearAdView, getController());
}
private BaseVideoController getController() {
return mAdConfig.isCustomVideoPlayer() ? new DefaultVideoController(this) : new CustomVideoController(this);
}
3. 請求播放線性廣告。示例代碼如下:
VastAdPlayer.getInstance().startLinearAd(linearAdSlot, new AdsRequestListener() {
@Override
public void onSuccess(View view, int responseCode) {
}
@Override
public void onFailed(View view, int responseCode) {
}
@Override
public void playAdReady() {
mLinearAdView.setVisibility(View.VISIBLE);
}
@Override
public void playAdFinish() {
mLinearAdView.setVisibility(View.INVISIBLE);
}
@Override
public void onBufferStart() {
mProgressBar.setVisibility(View.VISIBLE);
}
@Override
public void onBufferEnd() {
mProgressBar.setVisibility(View.INVISIBLE);
}
});
#### 使用自定義播放器播放線性廣告
1. 在XML文件中,初始化播放器的佈局。示例代碼如下:
```
- 實現自定義的廣告播放器控制器。示例代碼如下:
public class CustomVideoController extends BaseVideoController implements VastPlayerListener {
public CustomVideoController(Context context) {
this(context, null);
}
public CustomVideoController(Context context, AttributeSet attrs) {
this(context, attrs, 0);
}
public CustomVideoController(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initView();
}
@Override
public int getLayoutId() {
return R.layout.activity_video_player;
}
private void initView(){
...
}
}
- 生成自定義的廣告播放器控制器,註冊線性廣告視圖。示例代碼如下:
private void registerLinearAdView() {
mLinearAdView = findViewById(R.id.fl_linear_ad);
mProgressBar = findViewById(R.id.progress);
VastAdPlayer.getInstance().registerLinearAdView(mLinearAdView, getController());
}
private BaseVideoController getController() {
return mAdConfig.isCustomVideoPlayer() ? new DefaultVideoController(this) : new CustomVideoController(this);
}
- 請求播放線性廣告。示例代碼如下:
VastAdPlayer.getInstance().startLinearAd(linearAdSlot, new AdsRequestListener() {
@Override
public void onSuccess(View view, int responseCode) {
}
@Override
public void onFailed(View view, int responseCode) {
}
@Override
public void playAdReady() {
mLinearAdView.setVisibility(View.VISIBLE);
}
@Override
public void playAdFinish() {
mLinearAdView.setVisibility(View.INVISIBLE);
}
@Override
public void onBufferStart() {
mProgressBar.setVisibility(View.VISIBLE);
}
@Override
public void onBufferEnd() {
mProgressBar.setVisibility(View.INVISIBLE);
}
});
播放廣告莢
廣告莢的播放與線性廣告的播放,只在使用自定義播放器請求播放廣告步驟4中有區別,請求播放廣告莢的示例代碼如下:
VastAdPlayer.getInstance().startAdPods(linearAdSlot, new AdsRequestListener() {
@Override
public void onSuccess(View view, int responseCode) {
}
@Override
public void onFailed(View view, int responseCode) {
}
@Override
public void playAdReady() {
mLinearAdView.setVisibility(View.VISIBLE);
}
@Override
public void playAdFinish() {
mLinearAdView.setVisibility(View.INVISIBLE);
}
@Override
public void onBufferStart() {
mProgressBar.setVisibility(View.VISIBLE);
}
@Override
public void onBufferEnd() {
mProgressBar.setVisibility(View.INVISIBLE);
}
});
測試VAST廣告
您需要使用專門的測試廣告位ID來獲取測試廣告,以避免在測試過程中產生無效的廣告點擊量。測試廣告位ID,僅可用於調測廣告功能,不可用於廣告變現,在應用正式發佈前需替換為正式的廣告位ID。您應在應用發佈前先進入流量變現官網,點擊“開始變現”,登錄鯨鴻動能媒體服務平臺,申請正式的廣告位ID並替換測試廣告位ID,具體操作詳情請參見展示位創建。以下表格中提供了VAST廣告的專用測試廣告位ID:
下載VAST廣告的示例代碼並運行,可以看到如下效果圖:
瞭解更多詳情>>
訪問華為開發者聯盟官網
獲取開髮指導文檔
華為移動服務開源倉庫地址:GitHub、Gitee
關註我們,第一時間瞭解 HMS Core 最新技術資訊~