- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在 Debug模式下,应用程序运行平稳,但在 Release模式下尝试构建时,应用程序构建失败。
它给我一个错误提示com.karriapps.smartsiddur.LocationsActivity$3:在程序类 com.karriapps.smartsiddur.LocationsActivity 中找不到封闭方法“boolean onCreateOptionsMenu(android.view.Menu)”
但是我现在在这个 Activity 中没有使用菜单。我以前有 beofre,但我删除了它。
package com.karriapps.smartsiddur;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.Toolbar;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import com.karriapps.smartsiddur.fragments.LocationSearchFragment;
import com.karriapps.smartsiddur.model.ElavationService;
import com.karriapps.smartsiddur.model.Location;
import com.karriapps.smartsiddur.model.listeners.LocationListener;
import com.karriapps.smartsiddur.model.response.LocationResponse;
import com.karriapps.smartsiddur.util.LocationHandler;
import com.karriapps.smartsiddur.util.SSApp;
import com.karriapps.smartsiddur.views.LocationViewHolder;
import org.jetbrains.annotations.NotNull;
import java.util.List;
import io.realm.RealmResults;
public class LocationsActivity extends BaseActivity implements LocationSearchFragment.LocationSetListener {
public static final String BUNDLE_LOCATION_ID = "location_id";
public static final String BUNDLE_FROM_SEARCH = "from_search";
public static final int RESPONSE_OK = 0;
public static final int RESPONSE_SET = 1;
private Toolbar mToolbar;
private RecyclerView mLocationsRecyclerView;
private View mCurrentLocation;
private SearchView mSearchView;
private List<LocationResponse.Feature> mLocationsSuggestion;
private ArrayAdapter<String> mAdapter;
private LocationsAdapter mLocationsAdapter;
private RealmResults<Location> mLocations;
private View mProgressBar;
private boolean fromSearch;
private LocationSearchFragment mLocationSearchFragment;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
fromSearch = getIntent().getBooleanExtra(BUNDLE_FROM_SEARCH, false);
setContentView(R.layout.activity_locations);
mToolbar = (Toolbar) findViewById(R.id.toolbar_actionbar);
mCurrentLocation = findViewById(R.id.location_activity_current_location);
mProgressBar = findViewById(R.id.progressBar);
mLocationsRecyclerView = (RecyclerView) findViewById(R.id.locationsList);
mLocationsRecyclerView.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false));
setSupportActionBar(mToolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setTitle("");
loadLocations();
mLocationsAdapter = new LocationsAdapter();
mLocationsRecyclerView.setAdapter(mLocationsAdapter);
mLocationsRecyclerView.setItemAnimator(new DefaultItemAnimator());
mLocationSearchFragment = new LocationSearchFragment();
LocationHandler.getInstance().setLocationListener(new LocationListener() {
@Override
public void onLocationFailure() {
mProgressBar.setVisibility(View.GONE);
}
@Override
public void onLocationAchieved(Location location) {
SSApp.getInstance().addLocation(location);
loadLocations();
mLocationsAdapter.notifyDataSetChanged();
mProgressBar.setVisibility(View.GONE);
if (fromSearch) {
returnToCallingActivity();
}
}
});
findViewById(R.id.searchBtn).setOnClickListener(v -> {
mLocationSearchFragment.show(getSupportFragmentManager(), "places");
});
}
private void updateCurrentLocation() {
LocationViewHolder locationViewHolder = new LocationViewHolder(mCurrentLocation);
if (SSApp.getInstance().getLocation() != null) {
locationViewHolder.bind(SSApp.getInstance().getLocation(), new LocationViewHolder.OnLocationItemOperation() {
@Override
public void onDeleteLocationClick(int position) {
}
@Override
public void onDetailsChanged(int position, boolean inIsrael) {
updateIsInIsrael(SSApp.getInstance().getLocation(), inIsrael);
}
@Override
public void onSetLocationClick(int position) {
}
});
} else {
locationViewHolder.bind(SSApp.getInstance().getLocation(), null);
}
}
private void loadLocations() {
mLocations = SSApp.getInstance()
.getRealm()
.where(Location.class)
.equalTo("isActive", false)
.findAll();
updateCurrentLocation();
}
private void returnToCallingActivity() {
Intent intent = new Intent();
setResult(RESPONSE_SET, intent);
finish();
}
private void updateIsInIsrael(Location location, boolean inIsrael) {
if (location.isInIsrael() != inIsrael) {
SSApp.getInstance().getRealm().beginTransaction();
location.setIsInIsrael(inIsrael);
SSApp.getInstance().getRealm().commitTransaction();
mLocationsAdapter.notifyDataSetChanged();
updateCurrentLocation();
}
}
@Override
public void onLocationSet(@NotNull ElavationService.LatLng latLng) {
runOnUiThread(() -> {
if (mLocationSearchFragment != null && mLocationSearchFragment.isVisible()) {
mLocationSearchFragment.dismissAllowingStateLoss();
}
mProgressBar.setVisibility(View.VISIBLE);
});
LocationHandler.getInstance()
.setLocation(latLng.getLatitude(),
latLng.getLongitude(),
false
);
}
class LocationsAdapter extends RecyclerView.Adapter<LocationViewHolder> implements LocationViewHolder.OnLocationItemOperation {
@Override
public LocationViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(LocationsActivity.this)
.inflate(R.layout.location_row, parent, false);
return new LocationViewHolder(view);
}
@Override
public void onBindViewHolder(LocationViewHolder holder, int position) {
holder.bind(mLocations.get(position), this);
}
@Override
public int getItemCount() {
return mLocations == null ? 0 : mLocations.size();
}
@Override
public void onDeleteLocationClick(int position) {
SSApp.getInstance().removeLocation(mLocations.get(position));
loadLocations();
notifyItemRemoved(position);
}
@Override
public void onSetLocationClick(int position) {
SSApp.getInstance().setLocation(mLocations.get(position));
returnToCallingActivity();
}
@Override
public void onDetailsChanged(int position, boolean inIsrael) {
updateIsInIsrael(mLocations.get(position), inIsrael);
}
}
}
出于某种原因,它似乎仍在寻找它,但我不知道为什么
最佳答案
您的发布构建中间件中可能有一些旧文件导致了问题,引用了不再存在的代码。
干净的重建应该摆脱它们。
关于android - 无法构建发布应用程序,gradle 说找不到封闭方法 'boolean onCreateOptionsMenu(android.view.Menu),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57259994/
我以前制作过菜单,所以我不是一个完全的新手,但是我遇到了一个问题,Eclipse 告诉我必须删除 @Override,但显然如果我这样做,我的代码将不会运行到膨胀菜单。代码是: @Override p
我在 Android 应用程序中使用自己的样式,但它没有让我看到菜单(3 个点)和 Activity 标题。有什么建议吗? false true 但是在我的 MainActivit
菜单在应用程序的工具栏中可见,我可以打开它并查看菜单项,但是 onCreateOptionsMenu() 函数没有被调用,我通过设置断点知道这一点和调试,onOptionsItemSelected()
我是新手 Android 程序员,所以我想为我的应用程序制作菜单,但当我尝试将其启动到 AVD 时出现一些错误这是我的代码: import android.support.v7.app.AppComp
我的应用程序有两个 fragment ,一个是列表,一个是详细 View ,它们都以横向模式显示,只有列表以纵向显示。在配置更改时,如果我在两个 fragments 的 onCreateOptions
我的应用程序有这样的东西: TabActivity Tab 1 (ActivityGroup) Activity > Activity > MapActivity Ta
我正在使用 onCreateOptionsMenu 并且有一个我没有编程的默认菜单项。我想删除它,因为我对它没有用,它也没有做任何事情。这是它的样子: 我想去掉“设置”项。 @Override pub
由于我是 Android 编程的新手,我遇到了另一件我不明白的小事。为什么下面的 onCreateOptionsMenu 方法返回 super.onCreateOptionsMenu 而不是仅仅调用
我有一个简单的应用程序。 这里是MyActivity.java public class MyActivity extends Activity { /** * Called whe
我想从代码中调用 onCreateOptionsMenu 因为如果我使用: menu.setGroupEnabled(0, false); 与: public Menu menu; public bo
这是我创建的一个简单的 android 应用程序来演示我的问题: public class OptionMenuTest extends Activity { @Override pr
如何在我的代码中触发 Android onCreateOptionsMenu 函数,即无需用户单击手机上的选项菜单按钮? 最佳答案 Activity.openOptionsMenu(); 就可以了 关
我在这篇文章中发现了一些令我困惑的地方 http://developer.android.com/guide/topics/ui/menus.html 下面是一段简单的代码和输出当我在 android
我遇到的问题是,当我点击菜单按钮时,我的应用程序没有显示选项菜单。调试显示点击菜单按钮后未调用 onCreateOptionsMenu(Menu menu) 方法。我有另一个具有相同菜单代码的应用程序
我完全不知道为什么会这样。选项菜单工作正常,但现在不再工作了。 当我点击菜单按钮时,菜单打开,我点击它但什么也没有。当我执行 LogCat 时,它确实注册了 MenuItem ...我真的要拉扯我的头
我在获取在 Android 中运行的选项菜单时遇到了一些问题。我之前构建了应用程序,它们都运行良好,但现在菜单不弹出。 代码: @Override public boolean onCreateOpt
我有一个通过以下方式创建的菜单: @Override public boolean onCreateOptionsMenu(Menu menu) { menu.add("Email")
我想知道在 Android 中是否有任何方式以编程方式知道是否 公共(public) bool onCreateOptionsMenu(菜单菜单)已调用并返回。 我在一个项目中使用 actionshe
在我的 android Activity 中,我使用这个主题删除了操作栏 但我的问题是“onCreateOptionsMenu”没有显示,我试过这个方法来创建请看 private void ge
我想在每次调用时刷新选项菜单, 我有一个功能,当用户在选项菜单中单击选项(添加/删除收藏夹)时,它会检查它是否是收藏夹并执行该功能, 问题:创建菜单后,它不会在用户第二次按下选项按钮时刷新 onCre
我是一名优秀的程序员,十分优秀!