- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个 ResponsiveUIActivity
,它扩展了 SlidingFragmentActivity
。我的应用程序在 android 5.0 版本以下完美运行。但是当我第一次切换滑动菜单时,我的用户界面没有刷新并且不可点击。例如,在第一次切换后,我无法滚动 ListView
或在 EditText
上写东西。如果我切换滑动菜单,UI 会刷新,我可以看到更改。我该如何解决这个问题?
ResponsiveUIActivity.java
public class ResponsiveUIActivity extends SlidingFragmentActivity {
private Fragment mContent;
public static ResponsiveUIActivity rootActivity;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setTitle(R.string.responsive_ui);
setContentView(R.layout.responsive_content_frame);
this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
rootActivity = this;
// startNotificationService();
// check if the content frame contains the menu frame
if (findViewById(R.id.menu_frame) == null) {
setBehindContentView(R.layout.menu_frame);
getSlidingMenu().setSlidingEnabled(true);
getSlidingMenu().setTouchModeAbove(SlidingMenu.TOUCHMODE_MARGIN);
// show home as up so we can toggle
getActionBar().setDisplayHomeAsUpEnabled(false);
getActionBar().setDisplayShowHomeEnabled(false);
} else {
// add a dummy view
View v = new View(this);
setBehindContentView(v);
getSlidingMenu().setSlidingEnabled(false);
getSlidingMenu().setTouchModeAbove(SlidingMenu.TOUCHMODE_NONE);
}
// set the Above View Fragment
if (savedInstanceState != null)
mContent = getSupportFragmentManager().getFragment(
savedInstanceState, "mContent");
if (mContent == null)
mContent = new NewsFragment();
// customize the SlidingMenu
SlidingMenu sm = getSlidingMenu();
sm.setBehindOffsetRes(R.dimen.slidingmenu_offset);
sm.setShadowWidthRes(R.dimen.shadow_width);
sm.setShadowDrawable(R.drawable.shadow);
sm.setBehindScrollScale(0.25f);
sm.setFadeDegree(0.25f);
sm.setOnOpenedListener(new SlidingMenu.OnOpenedListener() {
@Override
public void onOpened() {
Log.d("ToggleMenu", "onOpened");
}
});
sm.setOnCloseListener(new SlidingMenu.OnCloseListener() {
@Override
public void onClose() {
Log.d("ToggleMenu", "onClose");
}
});
getSupportFragmentManager().beginTransaction()
.replace(R.id.content_frame, mContent).commit();
// set the Behind View Fragment
getSupportFragmentManager()
.beginTransaction()
.replace(R.id.menu_frame,
new MenuFragment((ResponsiveUIActivity) rootActivity))
.commit();
// hide app icon from actionBar
getActionBar().setIcon(android.R.color.transparent);
getActionBar().setTitle("");
/*
* // show the explanation dialog if (savedInstanceState == null) new
* AlertDialog.Builder(this) .setTitle(R.string.what_is_this)
* .setMessage(R.string.responsive_explanation) .show();
*/
}
private void startNotificationService() {
// TODO Auto-generated method stub
// Intent intent = new Intent(rootActivity, NotificationService.class);
// startService(intent);
}
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
toggle();
}
return super.onOptionsItemSelected((android.view.MenuItem) item);
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
getSupportFragmentManager().putFragment(outState, "mContent", mContent);
}
public void switchContent(final Fragment fragment) {
mContent = fragment;
getSupportFragmentManager().beginTransaction()
.replace(R.id.content_frame, fragment).commit();
Handler h = new Handler();
h.postDelayed(new Runnable() {
public void run() {
getSlidingMenu().showContent();
}
}, 50);
}
@Override
public void onBackPressed() {
Log.v("SignUp", "onbackPressed !!!!!!");
toggle();
}
public void finishActivity() {
super.onBackPressed();
}
}
菜单 fragment .java
@SuppressLint("ValidFragment")
public class MenuFragment extends Fragment {
LinearLayout newsClick, profileClick, adsClick, companyClick, wsClick,
contactsClick, contactClick, backClick, settingsClick;
ResponsiveUIActivity rootActivity;
public MenuFragment(ResponsiveUIActivity rootActivity) {
// TODO Auto-generated constructor stub
this.rootActivity = rootActivity;
}
public MenuFragment() {
super();
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View v;
if (PublicSharedPreferences.getDefaults(Constants.language,
getActivity()).equals("T")) {
v = inflater.inflate(R.layout.list_tr, null);
} else {
v = inflater.inflate(R.layout.list, null);
}
addMenuButtons(v);
return v;
}
private void addMenuButtons(View v) {
newsClick = (LinearLayout) v.findViewById(R.id.newsClick);
newsClick.setOnClickListener(onclick);
profileClick = (LinearLayout) v.findViewById(R.id.profileClick);
profileClick.setOnClickListener(onclick);
adsClick = (LinearLayout) v.findViewById(R.id.adsClick);
adsClick.setOnClickListener(onclick);
companyClick = (LinearLayout) v.findViewById(R.id.companyClick);
companyClick.setOnClickListener(onclick);
wsClick = (LinearLayout) v.findViewById(R.id.wsClick);
wsClick.setOnClickListener(onclick);
contactsClick = (LinearLayout) v.findViewById(R.id.contactsClick);
contactsClick.setOnClickListener(onclick);
contactClick = (LinearLayout) v.findViewById(R.id.contactClick);
contactClick.setOnClickListener(onclick);
backClick = (LinearLayout) v.findViewById(R.id.backClick);
backClick.setOnClickListener(onclick);
settingsClick = (LinearLayout) v.findViewById(R.id.settingsClick);
settingsClick.setOnClickListener(onclick);
}
OnClickListener onclick = new OnClickListener() {
Fragment newContent = null;
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.newsClick:
newContent = new NewsFragment();
break;
case R.id.profileClick:
newContent = new ProfileFragment();
break;
case R.id.adsClick:
newContent = new RecruitmentAdsFragment();
break;
case R.id.companyClick:
newContent = new CompanyProfileFragment();
break;
case R.id.wsClick:
newContent = new WsFragment();
break;
case R.id.contactsClick:
newContent = new ContactsFragment();
break;
case R.id.contactClick:
newContent = new ContactFragment();
break;
case R.id.backClick:
PublicSharedPreferences.removeDefaults(Constants.token,
getActivity().getApplicationContext());
PublicSharedPreferences.removeDefaults(Constants.TURKISH_ID,
getActivity().getApplicationContext());
if (PublicSharedPreferences.getDefaults(
Constants.TAG_NATIONALITY, getActivity()
.getApplicationContext()) != null) {
PublicSharedPreferences.removeDefaults(
Constants.TAG_NATIONALITY, getActivity()
.getApplicationContext());
}
if (PublicSharedPreferences.getDefaults(
Constants.TAG_EXPERIENCE, getActivity()
.getApplicationContext()) != null) {
PublicSharedPreferences.removeDefaults(
Constants.TAG_EXPERIENCE, getActivity()
.getApplicationContext());
}
if (PublicSharedPreferences.getDefaults(
Constants.TAG_DATE_OF_BIRTH, getActivity()
.getApplicationContext()) != null) {
PublicSharedPreferences.removeDefaults(
Constants.TAG_DATE_OF_BIRTH, getActivity()
.getApplicationContext());
}
rootActivity.finishActivity();
Intent preLoginIntent = new Intent(getActivity(),
PreLoginActivity.class);
preLoginIntent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
startActivity(preLoginIntent);
getActivity().overridePendingTransition(
R.anim.animated_activity_slide_left_in,
R.anim.animated_activity_slide_right_out);
break;
case R.id.settingsClick:
Log.v("Tekfen", "Settings");
newContent = new SettingsFragment();
break;
default:
break;
}
if (newContent != null)
switchFragment(newContent);
}
};
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
}
// the meat of switching the above fragment private void
public void switchFragment(Fragment fragment) {
if (getActivity() == null)
return;
if (getActivity() instanceof ResponsiveUIActivity) {
ResponsiveUIActivity ra = (ResponsiveUIActivity) getActivity();
ra.switchContent(fragment);
}
}
}
样式.xml
<?xml version="1.0" encoding="utf-8"?>
<style name="ExampleTheme" parent="Theme.Sherlock.Light.DarkActionBar">
<item name="homeAsUpIndicator">@drawable/new_indicator</item>
<item name="android:homeAsUpIndicator">@drawable/new_indicator</item>
</style>
<style name="AppTheme" parent="@style/Theme.Sherlock">
<item name="actionBarStyle">@style/AppTheme.ActionBar</item>
<item name="android:actionBarStyle">@style/AppTheme.ActionBar</item>
<item name="homeAsUpIndicator">@drawable/new_indicator</item>
<item name="android:homeAsUpIndicator">@drawable/new_indicator</item>
<item name="android:actionBarItemBackground">@android:color/transparent</item>
<item name="actionBarItemBackground">@android:color/transparent</item>
<item name="android:actionBarSize">100dp</item>
<item name="android:windowActionBarOverlay">true</item>
<item name="android:activatedBackgroundIndicator">@drawable/activated_background</item>
<item name="activatedBackgroundIndicator">@drawable/activated_background</item>
</style>
<style name="AppTheme.ActionBar" parent="@style/Widget.Sherlock.ActionBar">
<item name="android:background">@android:color/transparent</item>
<item name="background">@android:color/transparent</item>
</style>
<style name="ProgressHUD" parent="@android:style/Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowContentOverlay">@null</item>
<item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
<item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowNoTitle">true</item>
</style>
<style name="list_view_divider">
<item name="android:divider">#F0F0F0</item>
<item name="android:dividerHeight">1dp</item>
</style>
最佳答案
我遇到了同样的问题,但我已经设法解决了这个问题。实际问题在于硬件加速方面的缺陷,因此如果您将 AndroidManifest 放入您的应用程序hardwareAccelerated="true"您的问题将得到解决。
关于android - 在 Android 5.0 Lollipop 上首次切换滑动菜单后 UI 未刷新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28563240/
我使用工具栏是为了在我的应用程序中进行 Material 设计。一切正常,但除了更改菜单项文本颜色时,我完全无法接受该解决方案。我还张贴了我在申请中使用的文本和代码的屏幕截图,供您引用。我尝试了几种替
看起来 FloatingActionButton 在 Android 4.0 和 Lollipop 上无法正常工作。正如您在下图中看到的那样,在 Android Lollipo 上,阴影缺失,而在 A
SDK 升级到 Android 5 后,我无法使用 Intel 硬件加速执行管理器: $ android-sdk-macosx/tools/emulator -avd AVD_for_LowMemor
SDK升级到Android 5后,无法使用Intel Hardware Accelerated Execution Manager: $ android-sdk-macosx/tools/emulat
我有不同 draw9patch png 作为背景的按钮。目前按钮由 selector 控制,看起来像这样: 对于 Android Lollipop,他们有一个用于触摸效果的
我尝试在 Pre-Lollipop 设备上运行我的应用程序。但是这段代码向我显示了 Pre-Lolliop 和 Lollipop 设备的相同错误。 如果我将“android:”添加到样式中(如样式 2
我实现了一个自定义的 SurfaceView 来绘制相机预览,并在其上完成了所有捕获和手动对焦操作。它在 Pre-Lolipop 设备上运行良好,但问题是它在 Lollipop 设备上崩溃。 发生的最
风格 @color/my_primary_color @color/my_primary_dark_color @color/accent 布局
我想在 Lollipop 设备中显示较旧的时间选择器(如 Lollipop 设备之前的时间选择器)。可以 这是可能的。 最佳答案 您可以通过将 timePickerMode 属性设置为“spinner
嗨,所以我有点困惑,想知道是否有人能指出我正确的方向。 在 Lollipop 和 pre-lollipop 上使用 Google Play 商店 您会在 Lollipop 上看到可选择的 View 具
如果我们希望使用 Material Design 的应用同时支持 Lollipop 和 Lollipop 之前的设备,以下哪种方法是正确的? 单独使用 Android 支持库:仅对整个应用程序使用支持
我正在使用 appcompat/support-v7 中引入的新工具栏小部件。我想根据用户是否向上/向下滚动页面来隐藏/显示工具栏,就像在新的 Google Playstore 应用程序或 NewsS
我的数据库中有一个 .mhtml 文件作为字节数组。我写了下面的代码,它在 Lollipop 之前的设备上运行良好。但它不适用于 Lollipop 和棉花糖。 代码:- String p
根据标题,我能够在下面的 Lollipop 中成功读取/写入数据,但在 Lollipop 中多次读取/写入失败。 这就是我读/写数据的方式: boolean isRead= getmBluetooth
我刚刚在 Android Studio 上安装了 Android 5,并在模拟器上进行了第一次运行。我发现“API Demos”应用程序非常有趣,我想找到代码。我说的是这个应用程序: 有人知道我在哪里
我正在关注 this tutorial在 Android Material Design 中使用颜色(我的 ActionBar 和 StatusBar)。我确实按照教程进行操作,但没有反射(refle
在我的应用程序中,用户可以通过它调用任何号码,我正在启动蓝牙 audioManager.setBluetoothScoOn(true); audioManager.startBluetoothSco(
我正在我的 android 应用程序中实现 Google map API v2。该应用程序在所有设备上都可以正常工作,但在 Lollipop 设备上却不行。应用程序在 Lollipop 中崩溃。我确实
我正在开发一个项目,其中有一个日期选择器。我正在尝试为其设置最大日期和最短日期。最短日期是今天之后 1 天,最大日期是今天之后 11 天。但问题是在 Lollipop 设备中,最后一个最大日期显示为可
我正在使用嵌入式无线系统,它以定义的时间间隔生成数据包。目的是检测设备/系统何时重新启动。为此,我读到 Lollipop 序列编号是最适合此目的的编号方案。 “在此编号方案中,序列号从负值开始,增加直
我是一名优秀的程序员,十分优秀!