- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要你的帮助。如何使用 Facebook Audience Network 在文章列表中添加广告单元 (NativeAd) https://developers.facebook.com/docs/audience-network/android/native-api 。我不是程序员,需要所有代码应有的样子。广告必须在帖子之间( ListView )谢谢
import com.facebook.ads.*;
public class Posts extends Fragment{
ArrayList<Post> mPosts;
private static final String KEY_CONTENT = "PostsFragment:array";
boolean isLoadMore = false;
int mPageCount = 0;
int mCurrectPage = 1;
PullToRefreshListView mListView;
MyAdapter mListViewAdapter;
View mLoadingFooter;
private Tracker tracker;
@SuppressWarnings("unchecked")
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.tracker = EasyTracker.getInstance(this.getActivity());
if ((savedInstanceState != null) && savedInstanceState.containsKey(KEY_CONTENT)) {
mPosts = (ArrayList<Post>) savedInstanceState.getSerializable(KEY_CONTENT);
mCurrectPage = 1;
mPosts.clear();
mLoadingFooter.setVisibility(View.VISIBLE);
isLoadMore = true;
loadPostsList();
}
}
@Override
public void onResume() {
super.onResume();
this.tracker.set(Fields.SCREEN_NAME, "Article");
this.tracker.send( MapBuilder.createAppView().build() );
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putSerializable(KEY_CONTENT, mPosts);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View _result = inflater.inflate(R.layout.list, null);
mLoadingFooter = inflater.inflate(R.layout.loading_footer, null);
mLoadingFooter.setVisibility(View.GONE);
if (mPosts == null)
{
mPosts = new ArrayList<Post>();
loadPostsList();
}
mListView = (PullToRefreshListView) _result.findViewById(R.id.listView);
mListViewAdapter = new MyAdapter(getActivity(), mPosts);
mListView.addFooterView(mLoadingFooter);
mListView.setAdapter(mListViewAdapter);
mListView.setOnRefreshListener(new OnRefreshListener<ListView>() {
@Override
public void onRefresh(PullToRefreshBase<ListView> refreshView) {
mCurrectPage = 1;
mPosts.clear();
mLoadingFooter.setVisibility(View.VISIBLE);
isLoadMore = true;
loadPostsList();
}
});
mListView.setOnScrollListener(new OnScrollListener() {
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
int lastInScreen = firstVisibleItem + visibleItemCount;
if (totalItemCount > Constant.MIN_ITEM_COUNT && lastInScreen >= (totalItemCount - Constant.MIN_ITEM_COUNT_HALF) && !isLoadMore && mCurrectPage <= mPageCount)
{
mLoadingFooter.setVisibility(View.VISIBLE);
isLoadMore = true;
loadPostsList();
}
}
});
return _result;
}
public void loadPostsList() {
isLoadMore = true;
mLoadingFooter.setVisibility(View.VISIBLE);
new AsynckRequestGet().execute(getActivity(), TYPE_GET_OPERATION.POSTS, CodeRequestManager.codePosts(TempData.getInstance().getToken(), mCurrectPage));
}
private class AsynckRequestGet extends AbstractAsyncRequestGet {
@Override
protected void onPostExecute(String result) {
super.onPostExecute(result);
isLoadMore = false;
if(!isDetached()) {
mLoadingFooter.setVisibility(View.GONE);
mListView.onRefreshComplete();
}
if(result == null) return;
int[] t = JsonParser.parsePageCountResponse(result);
mPageCount = t[0];
mCurrectPage = t[1] +1;
ArrayList<Post> temp = JsonParser.parsePostsResponse(result);
if(temp == null || isDetached())
return;
mPosts.addAll(temp);
mListViewAdapter.notifyDataSetChanged();
}
}
private class MyAdapter extends ArrayAdapter<Post> {
private LayoutInflater inflater;
public MyAdapter(Context context, ArrayList<Post> objects) {
super(context, R.layout.post_item, objects);
inflater = LayoutInflater.from(context);
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
convertView = inflater.inflate(R.layout.post_item, null);
final Post post = getItem(position);
final TextView postLikes = ((TextView) convertView.findViewById(R.id.post_likes));
final TextView postComments = ((TextView) convertView.findViewById(R.id.post_comments));
postComments.setText(post.getCountComment() + "");
postLikes.setText(post.getCountLike() + "");
if(post.isMyLike()) {
postLikes.setCompoundDrawablesWithIntrinsicBounds(R.drawable.like_my_icon, 0, 0, 0);
} else {
postLikes.setCompoundDrawablesWithIntrinsicBounds(R.drawable.like_icon, 0, 0, 0);
}
postLikes.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
new AbstractAsyncRequestGet().execute(getActivity(), TYPE_GET_OPERATION.LIKE, CodeRequestManager.codeLike(TempData.getInstance().getToken(), post.getId(), post.isMyLike()? 0 : 1));
post.setCountLike((post.getCountLike()) + (post.isMyLike()? -1 : 1));
post.setMyLike(post.isMyLike()? 0 : 1);
postLikes.setText(post.getCountLike() + "");
mListViewAdapter.notifyDataSetChanged();
}
});
mListView.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) {
((TrainingFragment) getParentFragment().getParentFragment()).showPostDetails(mPosts.get(arg2-1), new DetailListener() {
@Override
public void onRefresh() {
if(!isDetached())
mListViewAdapter.notifyDataSetChanged();
}
})
;}
});
((TextView) convertView.findViewById(R.id.post_title)).setText(post.getTitle());
((TextView) convertView.findViewById(R.id.post_content)).setText(post.getContent());
return convertView;
}
}
}
最佳答案
如果您获取最新的 Facebook Android SDK,您可以找到 NativeAdSample 项目,该项目更新了如何在 ListView 中显示原生广告。从示例中复制的代码:
package com.facebook.samples.NativeAdSample;
import java.util.ArrayList;
import java.util.List;
import com.facebook.ads.Ad;
import com.facebook.ads.AdError;
import com.facebook.ads.AdListener;
import com.facebook.ads.NativeAd;
import android.app.ListActivity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
public class NativeAdListActivity extends ListActivity implements AdListener {
private ListView listView;
private ListViewAdapter adapter;
private NativeAd listNativeAd;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
listNativeAd = new NativeAd(this, "YOUR_PLACEMENT_ID");
listNativeAd.setAdListener(this);
listNativeAd.loadAd();
listView = getListView();
adapter = new ListViewAdapter(getApplicationContext());
listView.setAdapter(adapter);
}
@Override
public void onAdClicked(Ad ad) {
Toast.makeText(this, "Ad Clicked", Toast.LENGTH_SHORT).show();
}
@Override
public void onAdLoaded(Ad ad) {
adapter.addNativeAd((NativeAd) ad);
}
@Override
public void onError(Ad ad, AdError error) {
Toast.makeText(this, "Ad failed to load: " + error.getErrorMessage(), Toast.LENGTH_SHORT).show();
}
class ListViewAdapter extends BaseAdapter {
private LayoutInflater inflater;
private List<Object> list;
private NativeAd ad;
private static final int AD_INDEX = 2;
public ListViewAdapter(Context context) {
list = new ArrayList<Object>();
inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
for (int i = 1; i <= 35; i++) {
list.add("ListView Item #" + i);
}
}
@Override
public int getCount() {
return list.size();
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (position == AD_INDEX && ad != null) {
// Return the native ad view
return (View) list.get(position);
} else {
TextView view; // Default item type (non-ad)
if (convertView != null && convertView instanceof TextView) {
view = (TextView) convertView;
} else {
view = (TextView) inflater.inflate(R.layout.list_item, parent, false);
}
view.setText((String) list.get(position));
return view;
}
}
public synchronized void addNativeAd(NativeAd ad) {
if (ad == null) {
return;
}
if (this.ad != null) {
// Clean up the old ad before inserting the new one
this.ad.unregisterView();
this.list.remove(AD_INDEX);
this.ad = null;
this.notifyDataSetChanged();
}
this.ad = ad;
View adView = inflater.inflate(R.layout.ad_unit, null);
NativeAdSampleActivity.inflateAd(ad, adView, NativeAdListActivity.this);
list.add(AD_INDEX, adView);
this.notifyDataSetChanged();
}
}
}
关于java - 需要使用 Facebook Audience Network 在文章列表中添加广告单元 (NativeAd),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25099144/
我正在使用 REST API 列出我的 Azure 数据湖存储帐户中的所有队列。 但我收到此错误: "Audience validation failed. Audience did not matc
我想根据上一次触发事件在Firebase中定义一个受众群体。例如,我想重新吸引过去30天未打开应用程序(事件:app_open)的用户。 我一直试图根据此标准定义受众,但没有成功。 任何帮助,将不胜感
我们在 Android 应用上使用 Firebase Analytics。我们创建了一个名为“卸载者”的受众群体(发送 app_remove 事件超过 0 次),以便为卸载我们应用的用户开展再营销事件
已经有多个标题相同的问题,但我相信这个是不同的。 我创建了 2 个受众。 一个用于app_exception 事件。 还有一个用于app_remove 事件。 当我检查特定日期范围内的这些事件时,20
这是FB提供的代码,但此广告放置在顶部横幅上,我希望它适合底部横幅。是否有简单的解决方法来更改FB广告的位置?此外,该实施正在运行,并且测试广告正在运行。 -(void)viewDidLoad {
我正在开发一个 Python 包,它由一个库模块和两个使用该库的脚本组成。其中一个脚本是打印一些文本的命令行工具,另一个脚本是 JSON API 服务器。这两个脚本也可以作为希望使用该库的开发人员的示
我在 firebase 中创建了自定义受众并生成了大量用户和事件,但两天后,除了所有用户之外,每个自定义受众的受众数据都是空的。 最佳答案 您在项目设置中设置的国家/地区是否与您居住的国家/地区相同?
我正在将 Firebase 分析集成到我的 Android 应用程序中。我已成功记录事件,并且能够看到用户数量和触发事件的计数。现在我已经为一个 Activity 创建了观众 add_to_cart_
我曾尝试将Facebook广告放入我的应用程序中,该应用程序先前已与Google Admob广告一起使用。但是,在我的gradle文件中添加此行时会出错。 compile 'com.facebook.
我的应用程序运行了好几个月,突然用户遇到应用程序崩溃的情况。 Firebase Crashalytics 向我显示此错误 Fatal Exception: java.lang.ArrayIndexOu
通过 Facebook Audience Network API,我有展示位置 ID,但没有展示位置名称 https://graph.facebook.com/v2.7/XXX/app_insight
我刚刚使用“Facebook Audience Integration”创建了一个应用程序,一切正常,我已经创建了我的展示位置 ID,我可以看到“测试广告”和“真实广告”(如果我移除我的测试设备)。
图标永远不会出现,其他元素显示正确。示例代码: private lazy var adIconView: FBMediaView = { var iconView = FBMediaView()
当我想在我的测试设备上的 iOS 应用程序中显示横幅时,按照规则,我添加如下代码: [FBAdSettings addTestDevice:@"HASHED ID"]; 然后广告正常工作。我想知道我是
首先让我向您展示我对 FBNativeAd 的实现: func getNativeAd() { self.FBnativeAd = FBNativeAd(placementID: PLACEM
我最近将我的应用程序的 facebook audience sdk 更新到最新版本,并且总是因为 onLoggingImpression 而崩溃,这是 AdListener 中的一个新方法,下面是我得
我的依赖项列表中有 facebook 受众网络依赖项。它曾经有效,但由于没有明显的原因而停止解决。 编译 'com.facebook.android:audience-network-sdk:4.+'
将 Facebook Audience Network SDK 版本更新到 4.26.0 后,根据 Firebase 崩溃报告,我的应用程序因以下问题而面临大量崩溃。 Caused by java.l
E/FBAudienceNetwork:您正在使用自定义应用程序类并且不调用 AudienceNetworkAds.isInAdsProcess()。多进程支持将被禁用。如果要支持多进程模式,请调用
我创建了一个新的示例项目,用于在我的 Activity 底部显示 Facebook 受众网络横幅广告。 我的应用程序正在设备中运行,但在底部没有显示任何内容。我已经为测试设备添加了哈希。 MainAc
我是一名优秀的程序员,十分优秀!