檢視 Android Native Ads SDK8 的原始碼
←
Android Native Ads SDK8
跳至導覽
跳至搜尋
由於下列原因,您沒有權限進行編輯此頁面的動作:
您請求的操作只有這個群組的使用者能使用:
使用者
您可以檢視並複製此頁面的原始碼。
== <b>Native廣告支援內容</b> == :<span style="font-size:16px;">TAMedia Native廣告支援下列數種內容:</span> {| class="wikitable" style="width:50%" |- ! 廣告內容 !! 內容細節 !! 資料型別 |- | align="center"| ShortSubject || align="center"| 短標題 || align="center"| String |- | align="center"| LongSubject || align="center"| 長標題 || align="center"| String |- | align="center"| Body || align="center"| 內文 || align="center"| String |- | align="center"| CTA || align="center"| 行動呼籲 || align="center"| String |- | align="center"| iconRect || align="center"| 小圖 (長) || align="center"| TWMNativeAd.Image |- | align="center"| iconSquare || align="center"| 小圖 (方) || align="center"| TWMNativeAd.Image |- | align="center"| image960_640 || align="center"| 大圖 (960x640) || align="center"| TWMNativeAd.Image |- | align="center"| image1200_627 || align="center"| 大圖 (1200x627) || align="center"| TWMNativeAd.Imag |- | align="center"| mediaContent || align="center"| 多媒體素材(影音或主要圖片) || align="center"| TWMMediaContent |} <br><br> == <b>實作方式</b> == :步驟1 : 產生一個TWMNativeAd物件, 設定廣告版位adUnitId, 並呼叫load()請求原生廣告 : 監聽TWMAdListener, 透過onReceivedAd()取得原生廣告資訊TWMNativeAd.nativeAdContent <source> // Native ad assets. var body: String? = null var shortSubject: String? = null var longSubject: String? = null var callToAction:String? = null var iconRect: TWMNativeAd.Image? = null var iconSquare: TWMNativeAd.Image? = null var image960x640: TWMNativeAd.Image? = null var image1200x627: TWMNativeAd.Image? = null var mediaContent: TWMMediaContent? = null fun loadAd(context: Context, adUnitId: String) { nativeAd = TWMNativeAd(context, adUnitId) nativeAd?.setAdListener(this) nativeAd?.loadAd(TWMAdRequest()) } override fun onReceiveAd(ad: TWMAd) { this.body = nativeAd?.nativeAdContent?.body this.shortSubject = nativeAd?.nativeAdContent?.shortSubject this.longSubject = nativeAd?.nativeAdContent?.longSubject this.callToAction = nativeAd?.nativeAdContent?.callToAction this.iconRect = nativeAd?.nativeAdContent?.iconRect this.iconSquare = nativeAd?.nativeAdContent?.iconSquare this.image960x640 = nativeAd?.nativeAdContent?.image960_640 this.image1200x627 = nativeAd?.nativeAdContent?.image1200_627 this.mediaContent = nativeAd?.nativeAdContent?.mediaContent } </source> :步驟2 : 使用TWMNativeAdView作為廣告佈局容器, 開發者可在容器中可自行排列文字(TextView)圖形(ImageView)甚至影片(TWMMediaView)等原生廣告 : 下面以短標題, 小圖 (長), Call To Action, 及多媒體素材當範例 <source> <?xml version="1.0" encoding="utf-8"?> <com.taiwanmobile.pt.adp.view.TWMNativeAdView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/nativeAdView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@android:color/holo_orange_light"> <LinearLayout android:id="@+id/container" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="center" android:minHeight="50dp" android:orientation="vertical" android:paddingLeft="20dp" android:paddingRight="20dp"> <TextView android:id="@+id/tv_short_subject" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" /> <ImageView android:id="@+id/iv_icon_rect" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp"/> <TextView android:id="@+id/tv_call_to_action" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" /> <com.taiwanmobile.pt.adp.nativead.TWMMediaView android:id="@+id/ad_media" android:layout_width="150dp" android:layout_height="120dp" android:layout_marginTop="10dp"/> </LinearLayout> </com.taiwanmobile.pt.adp.view.TWMNativeAdView> </source> :步驟3 : 將TWMNativeAd.nativeAdContent的廣告資訊套用在上述廣告佈局中 : 並於TWMNativeAdView進行填充(ex. setShortSubjectView()), 賦予點擊後開啟廣告之功能 <source> val adContent: TWMNativeAdContent? = ad?.nativeAdContent // shortSubject adContent?.shortSubject.let { subject -> // 顯示短標題於TextView之中 vb.tvShortSubject.text = subject // 於TWMNativeAdView進行填充, 賦予點擊後開啟廣告之功能 vb.nativeAdView.setShortSubjectView(vb.tvShortSubject) } // rect icon adContent?.iconRect?.getDrawable().let { rectDrawable -> // 顯示小圖 (長)於ImageView之中 vb.ivIconRect.setImageDrawable(rectDrawable) vb.ivIconRect.adjustViewBounds = true // 於TWMNativeAdView進行填充, 賦予點擊後開啟廣告之功能 vb.nativeAdView.setRectangleIconView(vb.ivIconRect) } // call to action adContent?.callToAction?.let { cta -> // 顯示行動呼籲於TextView之中 vb.tvCallToAction.text = cta // 於TWMNativeAdView進行填充, 賦予點擊後開啟廣告之功能 vb.nativeAdView.setCallToActionView(vb.tvCallToAction) } </source> :步驟4 : 如欲顯示影片廣告, 將mediaContent指派給TWMMediaView, 用TWMMediaView來顯示影片 <source> // MediaContent adContent?.mediaContent?.let { content -> // 顯示TWMMediaContent於TWMMediaView vb.adMedia.setMediaContent(content) // 於TWMNativeAdView進行填充, 賦予點擊後開啟廣告之功能(前往了解) vb.nativeAdView.setMediaView(vb.adMedia) } </source> :步驟5 : 完成上述後, TWMNativeAd物件指派給TWMNativeAdView, 啟動原生廣告顯示 (重要!!!) <source> // nativeAd vb.nativeAdView.setNativeAd(nativeAd) </source> <br> <br> == <b>TWMNativeAdOptions</b> == TWMAdRequest.setNativeAdOptions()供開發者相關功能, 調整原生廣告屬性<br> :<span style="font-size:16px;">TAMedia Native廣告支援下列數種內容:</span> {| class="wikitable" style="width:50%" |- ! 廣告內容 !! 內容細節 |- | align="center"| DISABLE_IMAGE_LOADING || align="center"| TWMNativeAdContent.Image不含Drawable物件, 加速廣告下載速度 |- | align="center"| VIDEO_START_UNMUTED || align="center"| TWMMediaView影片初始為有聲音, 預設為靜音 |- | align="center"| VIDEO_CUSTOM_CONTROLS_REQUESTED || align="center"| TWMMediaView不提供影片控制項, 預設為提供 |- | align="center"| MEDIA_PREFER_IMAGE || align="center"| TWMMediaView總是顯示圖片, 預設為影片 |} : 下面例子為影片初始即有聲音 <source> val adRequest = TWMAdRequest() adRequest.setNativeAdOptions(arrayOf(TWMNativeAdOptions.VIDEO_START_UNMUTED)) nativeAd?.loadAd(adRequest) </source> <br> <br> == <b>釋放廣告</b> == <b><span style="color:#ff0000">請在Activity的生命週期中加入下述的呼叫, 正確釋放TWMNativeAd物件</span></b> override fun onDestroy() { super.onDestroy() nativeAd?.destroy() } <br><br> == <b>廣告畫面展示</b> == {| border="1" |- | align="center" | 文字 | align="center" | 影片 |- | align="center" | [[image:SDK8 nativead1.png | 300px]] | align="center" | [[image:SDK8 nativead2.png | 300px]] |} <br> <br> == <b>進階. 客製化影片撥放元件(選擇性實作, 非必要)</b> == 當TWMAdRequest.setNativeAdOptions()使用VIDEO_CUSTOM_CONTROLS_REQUESTED TWMVideoController / TWMMediaContent包含了下列功能, 提供影片相關資訊, 提供開發者客製化自己的影片控制項 <br> {| class="wikitable" style="width:50%" |- ! 函式名稱 !! 功能 |- | align="center"| TWMVideoController.isMuted() || align="center"| 影片是否靜音中 |- | align="center"| TWMVideoController.mute(boolean)|| align="center"| 影片靜音 |- | align="center"| TWMVideoController.setVideoLifecycleCallback(callback) || align="center"| 影片生命週期(VideoLifecycleCallback) |- | align="center"| TWMMediaContent.getCurrentTime() || align="center"| 取得目前撥放進度 |- | align="center"| TWMMediaContent.getDuration() || align="center"| 取得影片長度 |} == <b>進階. TWMMediaView 預設UI項目客製化(選擇性實作, 非必要)</b> == SDK8支援TWMMediaView UI項目客製化 <br> 開發者可透過TWMMediaView下列函式對預設UI控制項進行客製化 <br> {| class="wikitable" style="width:50%" |- ! 函式名稱 !! 功能 |- | align="center"| TWMMediaView.setCTAVisible(visible: Boolean) || align="center"| 設定CTA是否顯示 |- | align="center"| TWMMediaView.setCTATextSize(textSize: Float)|| align="center"| 設定CTA文字大小 |- | align="center"| TWMMediaView.setVideoCountdownTextSize(textSize: Float) || align="center"| 設定影片倒數文字大小 |- | align="center"| TWMMediaView.setVolumeImageSize(imageSize: Int) || align="center"| 設定靜音圖示大小 |} [[image:TWMMediaView_CustomUI_Demo.png | 300px]] == <b>進階. 支援Open-Measurement友善障礙物(選擇性實作, 非必要)</b> == SDK8支援Open-Measurement友善障礙物事件處理 <br> https://interactiveadvertisingbureau.github.io/Open-Measurement-SDKAndroid/ 開發者可透過TWMNativeAdView.addFriendlyObstruction(view, purpose)將與原生廣告相關的控制元件設定為友善障礙物 <br> 下面以FloatingActionButton為例子, 按鈕本身為影片靜音設定,使用FriendlyObstructionPurpose.VIDEO_CONTROLS為障礙物目的 <br> 於TWMNativeAd.setNativeAd()之前完成障礙物添加 <source> // friendlyObstruction vb.nativeAdView.addFriendlyObstruction(vb.fab, TWMNativeAdView.FriendlyObstructionPurpose.VIDEO_CONTROLS) vb.fab.setOnClickListener { adContent?.mediaContent?.getVideoController()?.let { videoController -> val isMute = videoController.isMuted() // 設定影片靜音 videoController.mute(!isMute) when (videoController.isMuted()) { true -> { vb.fab.setImageResource(R.drawable.ic_baseline_volume_up_24) } false -> { vb.fab.setImageResource(R.drawable.ic_baseline_volume_mute_24) } } } } // nativeAd vb.nativeAdView.setNativeAd(nativeAd) </source> {| class="wikitable" style="width:50%" |- ! 元件總類 !! 描述 |- | align="center"| FriendlyObstructionPurpose.VIDEO_CONTROLS || align="center"| 影音控制項 |- | align="center"| FriendlyObstructionPurpose.CLOSE_AD || align="center"| 關閉廣告 |- | align="center"| FriendlyObstructionPurpose.NOT_VISIBLE || align="center"| 透明元件 |- | align="center"| FriendlyObstructionPurpose.OTHER || align="center"| 非上述三種類別 |} [[Android SDK Developer Guide 2 | 回首頁]]
返回到「
Android Native Ads SDK8
」。
導覽選單
個人工具
登入
命名空間
頁面
討論
變體
已展開
已摺疊
視圖
閱讀
檢視原始碼
檢視歷史
更多
已展開
已摺疊
搜尋
導覽
首頁
近期變更
隨機頁面
有關 MediaWiki 的說明
工具
連結至此的頁面
相關變更
特殊頁面
頁面資訊