- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 MainActivity 类和 AsyncTask 类。我有代码的工作版本,但后来我决定将 AsyncTask 类分离到另一个包中。之后我遇到了一些问题,我正在努力解决它们。这是我的代码的最后一个工作版本。
public class MainActivity extends AppCompatActivity implements NavigationView.OnNavigationItemSelectedListener, SwipeRefreshLayout.OnRefreshListener {
private static final String TAG = "MainActivity";
private static final int LAYOUT = R.layout.activity_main;
private static final String URL = "http://killpls.me";
private Toolbar toolbar;
private DrawerLayout drawerLayout;
private NavigationView navigationView;
private ActionBarDrawerToggle toggle;
private FloatingActionButton fab;
private ProgressDialog progressDialog;
private SwipeRefreshLayout mSwipeRefreshLayout;
private NewPostsAsyncTask newPostsAsyncTask;
public Elements content;
public ArrayList<String> titleList = new ArrayList<String>();
public ArrayAdapter<String> adapter;
public ListView listView;
private int navigationDrawerItemId;
private boolean isNavigationDrawerItemEnabled = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(LAYOUT);
initToolbar();
initNavigationView();
initActionBarDrawerToggle(); // Добавляет возможность открыть NavigationDrawer через значок
initFloatingActionButton();
initSwipeRefreshLayout();
listView = (ListView) findViewById(R.id.listView);
}
private void initToolbar() {
toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
return false;
}
});
}
private void initNavigationView() {
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
navigationView = (NavigationView) findViewById(R.id.nav_view);
navigationView.setNavigationItemSelectedListener(this);
}
private void initActionBarDrawerToggle() {
toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
drawerLayout.setDrawerListener(toggle);
toggle.syncState();
}
private void initFloatingActionButton() {
fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
.setAction("Action", null).show();
}
});
}
private void initSwipeRefreshLayout() {
mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container);
mSwipeRefreshLayout.setOnRefreshListener(this);
mSwipeRefreshLayout.setColorSchemeResources(android.R.color.holo_blue_bright,
android.R.color.holo_green_light,
android.R.color.holo_orange_light,
android.R.color.holo_red_light);
}
@Override
public void onBackPressed() {
DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
if (drawer.isDrawerOpen(GravityCompat.START)) {
drawer.closeDrawer(GravityCompat.START);
} else {
super.onBackPressed();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@SuppressWarnings("StatementWithEmptyBody")
@Override
public boolean onNavigationItemSelected(MenuItem item) {
// Handle navigation view item clicks here.
navigationDrawerItemId = item.getItemId();
if (navigationDrawerItemId == R.id.new_posts) {
Log.i(TAG, "Выбрано раздел \"Новые\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
newPostsAsyncTask = new NewPostsAsyncTask();
newPostsAsyncTask.execute();
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.moderation) {
Log.i(TAG, "Выбрано раздел \"Модерация\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.tell_story) {
Log.i(TAG, "Выбрано раздел \"Рассказать историю\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.most_terrible_stories) {
Log.i(TAG, "Выбрано раздел \"Самые страшные\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.random_story) {
Log.i(TAG, "Выбрано раздел \"Случайная\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.happy_end) {
Log.i(TAG, "Выбрано раздел \"Happy end\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.about_project) {
Log.i(TAG, "Выбрано раздел \"О проекте\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
} else if (navigationDrawerItemId == R.id.help_all) {
Log.i(TAG, "Выбрано раздел \"Хочу помочь всем\" в Navigation Drawer");
adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.item, titleList);
if (!adapter.isEmpty()) adapter.clear();
isNavigationDrawerItemEnabled = true;
}
DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
drawer.closeDrawer(GravityCompat.START);
return true;
}
@Override
public void onRefresh() {
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
if (navigationDrawerItemId == R.id.new_posts) {
Log.i(TAG, "Обновленно раздел \"Новые\" в Navigation Drawer");
newPostsAsyncTask = new NewPostsAsyncTask();
newPostsAsyncTask.execute();
} else if (navigationDrawerItemId == R.id.moderation) {
Log.i(TAG, "Обновленно раздел \"Модерация\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.tell_story) {
Log.i(TAG, "Обновленно раздел \"Рассказать историю\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.most_terrible_stories) {
Log.i(TAG, "Обновленно раздел \"Самые страшные\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.random_story) {
Log.i(TAG, "Обновленно раздел \"Случайная\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.happy_end) {
Log.i(TAG, "Обновленно раздел \"Happy end\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.about_project) {
Log.i(TAG, "Обновленно раздел \"О проекте\" в Navigation Drawer");
} else if (navigationDrawerItemId == R.id.help_all) {
Log.i(TAG, "Обновленно раздел \"Хочу помочь всем\" в Navigation Drawer");
} else {
Log.i(TAG, "Попытка обновить главную страницу");
}
// Когда обновление закончено, вызываем метод setRefreshing(boolean) и передаем ему false.
mSwipeRefreshLayout.setRefreshing(false);
}
}, 2000);
if (!adapter.isEmpty()) adapter.clear();
}
class NewPostsAsyncTask extends AsyncTask<String, Void, String> {
@Override
protected void onPreExecute() {
super.onPreExecute();
if (!isNavigationDrawerItemEnabled) {
progressDialog = new ProgressDialog(MainActivity.this);
progressDialog.setTitle("Новые");
progressDialog.setMessage("Загрузка...");
progressDialog.setIndeterminate(false);
progressDialog.show();
}
}
@Override
protected String doInBackground(String... params) {
Document doc;
try {
doc = Jsoup.connect(URL).get(); // Считываем заголовок страницы
// Получение номера страницы селектором и преобразование его в число
Elements pageSpan = doc.select("div.paginator > span:first-child");
int pageCount = Integer.parseInt(pageSpan.first().text());
// Стоит еще проверить, что элементы нашлись, вызовом !pageSpan.isEmpty(),
// first() для пустого списка возвращает null.
for (int i = pageCount; i > 0; i--) {
String pageCountString = Integer.toString(i);
doc = Jsoup.connect("http://killpls.me/page/" + pageCountString).get();
parseDocument(doc);
if (i == 1697) {
break; // Ограничение до 1697 страницы, чтобы не лагало. Надо исправить.
}
}
} catch (IOException e) {
e.printStackTrace(); // Если не получилось считать
}
return null;
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
listView.setAdapter(adapter);
progressDialog.dismiss();
}
}
public void parseDocument(Document doc) {
// Парсит посты на странице
content = doc.select("[style=margin:0.5em 0;line-height:1.785em]");
for (Element contents : content) {
if (!contents.text().contains("18+")) {
// Выводит только посты без ссылки на 18+
titleList.add(contents.text());
}
}
}
}
我在使用 MainActivity 类的适配器时遇到问题。这是另一个包中新 AsyncTask 类的代码。我在 mainActivity.listView.setAdapter(mainActivity.adapter);
行中有 NullPointerException 你能告诉我为什么吗?
public class NewPostsAsyncTask extends AsyncTask<String, Void, String> {
private static final String URL = "http://killpls.me";
private ProgressDialog progressDialog;
private Elements content;
private Context context;
public NewPostsAsyncTask(Context context) {
this.context = context;
}
MainActivity mainActivity = new MainActivity();
@Override
protected void onPreExecute() {
super.onPreExecute();
if (!MainActivity.isNavigationDrawerItemEnabled) {
progressDialog = new ProgressDialog(context); //MainActivity.this
progressDialog.setTitle("Новые");
progressDialog.setMessage("Загрузка...");
progressDialog.setIndeterminate(false);
progressDialog.show();
}
}
@Override
protected String doInBackground(String... params) {
Document doc;
try {
doc = Jsoup.connect(URL).get(); // Считываем заголовок страницы
// Получение номера страницы селектором и преобразование его в число
Elements pageSpan = doc.select("div.paginator > span:first-child");
int pageCount = Integer.parseInt(pageSpan.first().text());
// Стоит еще проверить, что элементы нашлись, вызовом !pageSpan.isEmpty(),
// first() для пустого списка возвращает null.
for (int i = pageCount; i > 0; i--) {
String pageCountString = Integer.toString(i);
doc = Jsoup.connect("http://killpls.me/page/" + pageCountString).get();
parseDocument(doc);
if (i == 1697) {
break; // Ограничение до 1697 страницы, чтобы не лагало. Надо исправить.
}
}
} catch (IOException e) {
e.printStackTrace(); // Если не получилось считать
}
return null;
}
private void parseDocument(Document doc) {
// Парсит посты на странице
content = doc.select("[style=margin:0.5em 0;line-height:1.785em]");
for (Element contents : content) {
if (!contents.text().contains("18+")) {
// Выводит только посты без ссылки на 18+
mainActivity.titleList.add(contents.text());
//titleList.add(contents.text());
}
}
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
mainActivity.listView.setAdapter(mainActivity.adapter);
//listView.setAdapter(adapter);
progressDialog.dismiss();
}
}
最佳答案
因为您通过创建 MainActivity 构造函数从 AsyncTask 直接引用 MainActivity 的成员字段,这是错误的。
只需在 AsyncTask 的构造函数中传递您想要的任何成员字段并使用该字段即可,
喜欢,
private Context context;
private ListView mListView;
private ArrayAdapter<String> adapter;
private List<String> titleList = new ArrayList<String>();
public NewPostsAsyncTask(Context context, ListView listview) {
this.context = context;
this.mListView = listview;
}
private void parseDocument(Document doc) {
// Парсит посты на странице
content = doc.select("[style=margin:0.5em 0;line-height:1.785em]");
for (Element contents : content) {
if (!contents.text().contains("18+")) {
// Выводит только посты без ссылки на 18+
titleList.add(contents.text());
}
}
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
adapter = new ArrayAdapter<String>(context, R.layout.list_item, R.id.item, titleList);
mListView.setAdapter(adapter);
progressDialog.dismiss();
}
}
并删除,MainActivity mainActivity = new MainActivity();
现在从 Activity 调用 AsyncTask,例如,
newPostsAsyncTask = new NewPostsAsyncTask(MainActivity.this, listView);
newPostsAsyncTask.execute();
关于java - 为什么我无法在 AsyncTask 中为另一个类的 ListView 设置适配器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34619188/
我有 3 个 AutoCompleteTextView,我想在它们上面注册 2 个 String[] 适配器。目前,我正在这样做: atw_from.setAdapter(new ArrayAdapt
我需要实现一个 recyclerView 来显示我对 Parse 的查询,所以我已经做到了: private class Pagination extends RecyclerView.OnScro
我对 BizTalk 相当陌生,目前我只是探索它的功能并了解不同部分(架构、编排、端口等)如何协同工作。我对其适配器有疑问: 不同的适配器是否已经随 BizTalk 服务器安装一起预装并准备好配置,或
我在 BizTalk 中测试 MQSC 适配器以与 Z/OS 主机上的队列通信时遇到问题。 测试场景:通过 Biztalk 发送消息时,我(强制)停止并启动主机 channel ,以模拟主机 IPL。
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我想用我的音频单元在iPhone上录制一条音频信号,该信号来自一条普通的3.5毫米音频电缆(例如,另一部iPhone作为声源)。 由于iPhone具有4端口耳机插孔,因此无法直接插入。 我尝试了不同种
[请参阅下面的更新] 我很难定义模式。我的同事说这是适配器模式。我不知道。我们陷入困境主要是因为我们想要正确命名我们的组件。 问题:是适配器模式吗?如果不是的话是什么?如果是其他事情,这是实现这个想法
我有点不熟悉Java KeyAdapter有效,并且使用 KeyAdapter 使用以下代码得到了意想不到的结果。当按下一个键而另一个键已按下时,就会出现此问题,无论 isKeyPressed() 是
我想知道如何通过 ORM 适配器使用 Node.js 在 MySQL 中创建多个表。我通过模型创建了一个表,即“us.js” module.exports = { identity: 'us'
我有一个 JavaFx 客户端。我正在使用一个具有 ObservableSet 作为字段的 bean 作为模型。我想将这些数据显示到 ListView 中,但我无法将我的字段类型更改为 Observa
我正在尝试在 native iOS 应用程序中实现基于表单的身份验证,但我需要在没有收到质询的情况下登录,我想打开一个表单并登录。我实现了一个包含 isCustomResponse 函数的 Chall
我正在尝试为我的迭代器和 const_iterator 类实现反向迭代器适配器,但遇到了一些麻烦。如果有人可以指导我解决这个问题,将不胜感激! 我的想法是我应该能够从我的 rbegin() 和 ren
使用 spring-integration-sftp,创建任意数量的入站 channel 适配器对象的推荐方法是什么?我的应用程序需要监视多个远程目录(1 到 n),直到运行时才知道。 最佳答案 当前
我正在尝试为我们自己的框架创建适配器。我们的框架使用自己的断言机制,因此我需要编写适配器。 适配器类非常简单,如下所示: public class AllureReportListener {
有没有什么方法可以使用命令行而不是使用 Worklight 控制台来部署 Worklight 适配器? (因为我的 worklight 服务器安装在 WAS 上,wsadmin 命令或类似的命令...
我想构建自己的自定义 log4j(网络)适配器来解决我的问题 that I posted here. 我查看了 log4j 的文档,但看不到开发人员在哪里/是否讨论如何执行此操作。 有人能给我指出正确
我使用消息驱动 channel 适配器从 weblogic JMS 队列接收作为字符串的 xml 消息,然后将此消息传递到 spring 集成 channel 以存储到数据库中,转换为不同的 xml,
有没有什么方法可以使用命令行而不是使用 Worklight 控制台来部署 Worklight 适配器? (因为我的 worklight 服务器安装在 WAS 上,wsadmin 命令或类似的命令...
我试图为 Android 制作一个聊天应用程序,所以我使用了 RecyclerView 。我的适配器有问题,我的聊天室收到的 JSON 响应显示为空白。我的代码是否遗漏了某些内容? 这是我的适配器类
如果这是重复的,我提前道歉。我对 Android 开发还是新手,并尝试寻找解决方案,但找不到有效的解决方案。 我正在创建一个待办事项应用程序并在我的适配器中收到此错误。 java.lang.NullP
我是一名优秀的程序员,十分优秀!