gpt4 book ai didi

android - 方向改变后的奇怪行为

转载 作者:行者123 更新时间:2023-11-29 13:58:04 26 4
gpt4 key购买 nike

我希望有人能提供帮助。

我有点难以解释 activtiy,它是一个经典的 View 寻呼机,但在操作栏中有一个按钮,可以使 View 向右移动并显示菜单(最初隐藏在屏幕之外)。这是一个类似 facebook 的菜单。我有 2 个布局(菜单和寻呼机),我使用自定义 ScrollView 来获得我寻找的行为。

当我改变方向时,我希望每次都能显示菜单。所以我创建了一个不同的布局,并在 onCreate 方法上测试了方向。

我有几次尝试:如果 list 中没有 configChange,应用程序会崩溃并出现“IllegalStateException:Activity has been destroyed”指向行“mPager.setAdapter(mAdapter);”。

配置更改后,应用程序在旋转时确实会出错,它不会将布局更改为 layout-land 中的布局..

随着配置更改和 onCreate 在“onConfigurationChanged”上的内容,从纵向到横向都很好,但反过来就出错了( View 很大,因为它应该很高,而它应该很大)。 .

我希望你们中的一个人不会感到困惑。

如果你愿意,我可以发布代码,但是有很多代码,我不知道哪一部分对你有帮助(尽管问我)。

谢谢!

when i pass from portrait to landscape with the 2de try

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main_pager_layout);

inflater = LayoutInflater.from(this);
me = this;

View v = findViewById(R.id.landscape);
if (v == null) {
isLand = false;

scrollView = (MyHorizontalScrollView) inflater.inflate(
R.layout.horz_scroll_layout, null);

setContentView(scrollView);

menu = inflater.inflate(R.layout.main_pager_menu_layout, null);
app = inflater.inflate(R.layout.main_pager_layout, null);

final View[] children = new View[] { menu, app };
int scrollToViewIdx = 1;
TextView tv = (TextView) app.findViewById(R.id.sizerTV);
scrollView.initViews(children, scrollToViewIdx,
new SizeCallbackForMenu(tv));

} else {
isLand = true;
menu = findViewById(R.id.main_pager_land_menu);
app = findViewById(R.id.main_pager_land_app);
// scrollView = new MyHorizontalScrollView(null);
}
// Menu INIT
new MenuBehaviour(me, menu, inflater);
// AppBarInit
initializeAppBar();

// DAO
controlDAO = new Controller(me);
new Thread(new Runnable() {
@Override
public void run() {
arrayEvent = controlDAO.ebdd.getAllEvent();
if (arrayEvent != null) {
runOnUiThread(onUiThread);
} else {
runOnUiThread(new Runnable() {
public void run() {
Toast.makeText(
me,
me.getResources().getString(
R.string.error_no_database_yet),
Toast.LENGTH_LONG);
}
});

}
}
}).start();

// WS
final AQuery aq = new AQuery(me);
aq.ajax(uriTest, JSONObject.class, new AjaxCallback<JSONObject>() {

@Override
public void callback(String url, JSONObject json, AjaxStatus status) {
if (json != null) {
// Toast.makeText(aq.getContext(), status.getCode() + ":" +
// json.toString(), Toast.LENGTH_LONG).show();
try {
JSONArray array = json.getJSONObject("events")
.getJSONArray("event");

controlDAO.ebdd.open();
// On met le nouveau flux dans la BDD
controlDAO.updateBDD(array);
// On récupere les event de la BDD (au cas ou on gererai
// les maj)
arrayEvent = controlDAO.ebdd.getAllEvent();
controlDAO.ebdd.close();
runOnUiThread(onUiThread);

} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} else {
Toast.makeText(
aq.getContext(),
"Error:"
+ status.getCode()
+ ", connectez vous pour acceder aux mis a jours",
Toast.LENGTH_LONG).show();
}
}
});

}

Runnable onUiThread = new Runnable() {

@Override
public void run() {
arrtype = new ArrayList<String>();

arrtype.add("tout les evenements");
arrtype.add("sport");
arrtype.add("concert");
arrtype.add("spectacle");
arrtype.add("visite");
controlDAO.ebdd.close();
// On sépare les évenements en fonction de leurs type et on rempli
// arrayOfEventByType
arrayOfEventByType = new ArrayList<ArrayList<Event>>();
// ajout d'une arraylist pour tout les evenements
arrayOfEventByType.add(new ArrayList<Event>()); // tout les
// evenements
arrayOfEventByType.add(new ArrayList<Event>()); // sport
arrayOfEventByType.add(new ArrayList<Event>()); // concert
arrayOfEventByType.add(new ArrayList<Event>()); // spectacle
arrayOfEventByType.add(new ArrayList<Event>()); // visite
for (int i = 0; i < arrayEvent.size(); i++) {
if (!arrtype.contains(arrayEvent.get(i).type.toLowerCase())) {
arrayOfEventByType.add(new ArrayList<Event>());
arrtype.add(arrayEvent.get(i).type.toLowerCase());
}

Log.i("renaud", "arrtype.size() = " + arrtype.size());
Log.i("renaud", "arrayOfEventByType.size() = "
+ arrayOfEventByType.size());

arrayOfEventByType.get(
arrtype.indexOf(arrayEvent.get(i).type.toLowerCase()))
.add(arrayEvent.get(i));
arrayOfEventByType.get(0).add(arrayEvent.get(i));
}
// Test
Log.i("renaud",
"arrayOfEventByType.size() : " + arrayOfEventByType.size());
for (int i = 0; i < arrayOfEventByType.size(); i++) {
Log.i("renaud", "arrayOfEventByType.get(" + i + ").length() : "
+ arrayOfEventByType.get(i).size());
}

for (int i = 0; i < arrayOfEventByType.size(); i++) {
if (arrayOfEventByType.get(i).isEmpty()) {
arrayOfEventByType.remove(i);
arrtype.remove(i);
i--;
}
}
// ArrayList<Event> tous = arrayOfEventByType.remove(0);
// Collections.sort(arrayOfEventByType, new EventSort());
// arrayOfEventByType.add(0, tous);
// // On crée un nombre de panneau en fonction des types

mAdapter = new MyAdapter(getSupportFragmentManager(),
arrayOfEventByType, arrtype);
mPager = (ViewPager) findViewById(R.id.pager);
try {
mPager.setAdapter(mAdapter);

// +pour rajouter un titre etc..
mPager.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {

// Omniture
if (arg0 == 0) {
StadeDeFranceActivity.s.pageName = "Main Pager all event";
} else if (!arrayOfEventByType.isEmpty()
&& arrayOfEventByType.get(arg0) != null
&& !arrayOfEventByType.get(arg0).isEmpty()
&& arrayOfEventByType.get(arg0).get(0) != null
&& arrayOfEventByType.get(arg0).get(0).type != null) {

StadeDeFranceActivity.s.pageName = "Main Pager number "
+ arg0
+ " category:"
+ arrayOfEventByType.get(arg0).get(0).type;
} else {
StadeDeFranceActivity.s.pageName = "Main Pager number "
+ arg0;
}
// StadeDeFranceActivity.s.track();

Log.i("renaud", "page " + arg0);

};

@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}

@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
});
} catch (Exception e) {
e.printStackTrace();
}

}
};

public static class MyAdapter extends FragmentPagerAdapter {

private ArrayList<ArrayList<Event>> arrayOfEventByType;
private ArrayList<String> arrayOfname;

public MyAdapter(FragmentManager fm,
ArrayList<ArrayList<Event>> arrayOfEventByType,
ArrayList<String> arrayOfname) {
super(fm);
this.arrayOfEventByType = arrayOfEventByType;
this.arrayOfname = arrayOfname;
}

@Override
public int getCount() {
return arrayOfEventByType.size();
}

@Override
public Fragment getItem(int position) {

return MainPagerFragment.newInstance(
arrayOfEventByType.get(position), arrtype.get(position));

}

// private ArrayList<Event> concatArray(
// ArrayList<ArrayList<Event>> arrayOfEventByType2) {
// ArrayList<Event> concatArray = new ArrayList<Event>();
//
// for (int i = 0; i < arrayOfEventByType2.size(); i++) {
// concatArray.addAll(arrayOfEventByType2.get(i));
// }
//
// return concatArray;
// }

}

static class SizeCallbackForMenu implements SizeCallback {
int btnWidth;
View btnSlide;

public SizeCallbackForMenu(View btnSlide) {
super();
this.btnSlide = btnSlide;
}

@Override
public void onGlobalLayout() {
btnWidth = btnSlide.getMeasuredWidth();
System.out.println("btnWidth=" + btnWidth);
}

@Override
public void getViewSize(int idx, int w, int h, int[] dims) {
dims[0] = w;
dims[1] = h;
final int menuIdx = 0;
if (idx == menuIdx) {
dims[0] = w - btnWidth;
}
}
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
return true;
}

@Override
public boolean onPrepareOptionsMenu(Menu menu2) {

if (!isLand) {
int menuWidth = menu.getMeasuredWidth();

// Ensure menu is visible
menu.setVisibility(View.VISIBLE);

if (!menuDisplayed) {
// Scroll to 0 to reveal menu
int left = 0;
scrollView.smoothScrollTo(left, 0);
} else {
// Scroll to menuWidth so menu isn't on screen.
int left = menuWidth;
scrollView.smoothScrollTo(left, 0);
}
menuDisplayed = !menuDisplayed;
}
return true;

}

public class EventSort implements Comparator<ArrayList<Event>> {
ArrayList<String> cattab;

public EventSort() {
cattab = new ArrayList<String>();
cattab.add("sport");
cattab.add("rugby");
cattab.add("concert");
cattab.add("spectacle");
cattab.add("visite");
}

@Override
public int compare(ArrayList<Event> lhs, ArrayList<Event> rhs) {

if (lhs.isEmpty()) {
if (rhs.isEmpty()) {
return 0;
} else {
return 1;
}
} else if (rhs.isEmpty()) {
return -1;
} else {
String typelhs = lhs.get(0).type;
String typerhs = rhs.get(0).type;
if (cattab.indexOf(typelhs) < cattab.indexOf(typerhs)) {
return 1;
} else if (cattab.indexOf(typelhs) > cattab.indexOf(typerhs)) {
return -1;
} else {
return 0;
}
}

}

}

那是 list 中没有配置更改的代码,为了我的应用程序不会崩溃,我捕获了错误

最佳答案

当屏幕方向发生变化时,Android 将销毁您的 Activity 并重新创建它。因此,如果您的适配器持有对 Activity 的引用(例如 fragment 管理器),则会导致错误。

关于android - 方向改变后的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11033452/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com