Fragment中嵌套ViewPager导致内部fragment不初始化的问题

具体场景是这样:
我在 MainActivity 中使用 fragmentTransaction.commitAllowingStateLoss() 添加了 AFragment,
AFragment 中使用 ViewPager 实现 BFragment 和 CFragment的滑动.
添加 AFragemnt 后我并不跳转到这个 fragment, 所以 AFragment 没有显示, 但是 AFragment 中的 ViewPager 已经创建好了, 也 setAdapter/setCurrentItem 了, 但这时候 BFragment 和 CFragment 就没有初始化.

请问这是怎么回事, 有办法解决么?

4个回答

是这种效果吗图片说明

j550341130
叽哩叽哩鸡 回复木易匕禾页: 考虑到性能问题, 不打算一下把所有tab创建出来, 只单独创建额外的一个, 所以不能用viewpager
2 年多之前 回复
qq_33220645
木易匕禾页 fragment_A和fragment_B其实都创建了
2 年多之前 回复
qq_33220645
木易匕禾页 回复叽哩叽哩鸡: 你这种就需要外层也使用viewpager了,因为viewpager默认是预加载前一个和后一个页面的,你可以参考demo中加载到fragment_two的时候,fragmenta和fragment其实都创建了。
2 年多之前 回复
j550341130
叽哩叽哩鸡 感谢还写了个demo. 大体就是这样的情景, 我希望我在fragment_one的时候, fragment_two加载成功, 并且其内部的A_Fragment也执行完毕, 比如弹出一个Toast, 或者在下面tab上加个小红点之类的. 但是我这A_Fragemnt的onCreateView都没有走
2 年多之前 回复

你这MainActivity中是只有AFragment一个fragment吗?如果只有一个AFragment说明这个Afragment已经添加进来了,BFragment和CFragment是需要通过getChildFragmentManager然后开启事务,然后添加进来的,最后commit

qq_33220645
木易匕禾页 回复叽哩叽哩鸡: http://pan.baidu.com/s/1dF71ruL 如果是我发给你图片的效果你可以下载看下,不是这种效果那就不清楚了。。
2 年多之前 回复
j550341130
叽哩叽哩鸡 A加载时viewpager.setAdapter, viewpager内的B和C的onCreateView就执行不到
2 年多之前 回复
j550341130
叽哩叽哩鸡 不是只有A一个, MainActivity目前显示的还不是A, 是另外一个.B和C是在A的viewpager里面的, 没有commit. A加载成功后
2 年多之前 回复

这问题我以前遇到过,试一试transaction.commitNowAllowingStateLoss();

j550341130
叽哩叽哩鸡 v4 版本的问题, 我更新后有这个方法了, 可是还是不行
2 年多之前 回复
j550341130
叽哩叽哩鸡 只有这个方法 commitAllowingStateLoss, 没有 commitNowAllowingStateLoss
2 年多之前 回复
j550341130
叽哩叽哩鸡 好像靠谱, 我去试试
2 年多之前 回复

v4 版本的问题, 我更新后有这个方法了, 可是还是不行

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Fragment中嵌套ViewPager,ViewPager中有好几个Fragment实现滑动

Fragment中嵌套ViewPager,ViewPager中有好几个Fragment实现滑动,其中一个Fragment中有照相功能。在Activity中的拍照实现很简单,但是在Fragment中实现拍照,尤其是多层嵌套下的Fragment中更不好实现。 我这个是FragmentActivity中使用TabHostFragment实现底部菜单,包含Afragment、Bfragment、Cfragment、Dfragment. Afragment中中嵌套ViewPager,ViewPager中有好几个Fragment实现滑动,fragment1、fragment2、fragment3、、、、,其中fragment1 中有一个按钮调用摄像头拍照,最后把照片放到ImageView中。 fragment1中的onActivityResult()方法根本就不走,而走了FragmentActivity中的onActivityResult()。 怎么实现我想要的效果呢,请大家帮我一下,给点建议也好。。。

Fragment 嵌套viewpager 然后viewpager里面嵌套的是fragment

我用Fragment 嵌套viewpager 然后viewpager里面嵌套的是fragment 用的FragmentStatePagerAdapter 在打开程序的时候进去没问题 但是当我从其他界面跳转到这个fragment是 我的getChildFragmentManger()为空

安卓小白问问fragment中嵌套viewpager

需求是:自己写好了fragment,想在fragment当中嵌套一个自动播放图片的 viewpage 找了很多相似的代码,但是还是不行,,,其实就是想效果和淘宝首页一样 他的广告自动的播放,还有下面那个点 其次想找一个师父,带着一起上路,一起学习进步! 大神在的话,给个源码吧,一起进步!谢谢 邮箱:1437810161@qq.com

Fragment嵌套Fragment

最外层是Tab+Fragment;第一个Fragment里面用ViewPager+Fragment;选择了有ViewPager的Tab,就不能选择其他的Tab了。什么情况

如何在fragment中套viewpager

我在viewpager中的fragment套viewpager报runtimeexception,求解决,最好有代码

android中ViewPager+Fragment 中有fragment嵌套fragment

需求是 用ViewPager + Fragment(有3个Fragment) 实现页面滚动切换, 3个Fragment中其中有一个fragment中又嵌套了3个子fragment,最后滑动时, 界面出现了错位,要怎么解决

fragment嵌套viewpager的问题

[fragment嵌套viewpager的问题](http://bbs.csdn.net/topics/391849456 "fragment嵌套viewpager的问题")

scrollview嵌套viewpager viewpager无法自适应高度

scrollview嵌套viewpager (左右滑动的) viewpager自适应高度失效了。。。怎么解决scrollview里面viewpager的高度自适应问题

scrollview嵌套viewpager的问题

布局 是 最外面是scrollview 然后里面是一张图片 图片下面是viewpager viewpager 里面是三个fragment 每个fragment都有一个listview 现在问题是每次滑动切换 viewpager scrollview会自动滑下来 把图片隐藏掉 显示viewpager内的fragment的 内容 求大神讲下问题出在哪里

ScrollView嵌套ViewPager,ViewPager中再嵌套ListView怎么实现

ScrollView嵌套ViewPager,ViewPager中再嵌套ListView怎么实现

Android Fragment+viewpager 初始化加载很慢

在一个Fragment中,使用了ViewPager加载了9个Fragment 这个9个Fragment中的布局有很多控件,导致viewPager.setAdapter()时很慢, 到最后一个Fragment加载完成大概有400ms的时间,有什么办法解决吗? 我设置了cha_che_viewPager.setOffscreenPageLimit(9); 如果不设置,加载时间快,但滑动时明显卡顿

ViewPager 嵌套 fragment 中无法显示fragment中的listview内容

我在viewpager中用fragment作为加载页,然后在fragment中嵌入了一个listview,单独测试时fragment能载入listview内容,但是在viewpager中加载fragment时,无法显示listview内容,fragment其他组件能显示 viewpager 代码: import java.util.ArrayList; import java.util.List; import com.nineteen.myandroid.R; import android.app.Activity; import android.os.Bundle; import android.support.v4.app.FragmentActivity; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.text.Layout; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; public class AppUninstall extends FragmentActivity { ViewPager viewPager; // 内容页 List<View> views = new ArrayList<View>(); // 标题页 List<String> titles = new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.app_uninstall); viewPager = (ViewPager) findViewById(R.id.viewpager); LayoutInflater inflater = LayoutInflater.from(this); View view = inflater.inflate(R.id.appun_person, null); views.add(view); titles.add("个人应用"); view = inflater.inflate(R.layout.test_relatvelayout, null); views.add(view); titles.add("系统预装"); view = inflater.inflate(R.layout.test_button, null); views.add(view); titles.add("猜你不喜欢"); viewPager.setAdapter(new MyPagerAdapter(views, titles)); } class MyPagerAdapter extends PagerAdapter { List<View> views; List<String> titles; public MyPagerAdapter(List<View> views, List<String> titles) { this.views = views; this.titles = titles; } @Override public int getCount() { return views.size(); } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } // 获取到标题 public CharSequence getPageTitle(int position) { return titles.get(position); } @Override public Object instantiateItem(ViewGroup container, int position) { container.addView(views.get(position)); return views.get(position); } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(views.get(position)); } } } viewpage XML: <android.support.v4.view.ViewPager android:id="@+id/appun_viewpager" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center" > <android.support.v4.view.PagerTabStrip android:id="@+id/pager_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="top" /> </android.support.v4.view.ViewPager> fragment代码: import java.util.ArrayList; import java.util.HashMap; import java.util.List; import com.nineteen.myandroid.R; import android.os.Bundle; import android.support.v4.app.FragmentActivity; import android.widget.ListView; import android.widget.SimpleAdapter; public class PersonApp extends FragmentActivity { List<HashMap<String, Object>> list = new ArrayList<HashMap<String, Object>>(); ListView listView; int[] icon = { R.drawable.a005, R.drawable.a006, R.drawable.a007, R.drawable.a008, R.drawable.a009, R.drawable.a010, R.drawable.a011, R.drawable.a012, R.drawable.a013, R.drawable.a014, R.drawable.a015, R.drawable.a016, R.drawable.a017, R.drawable.a018, R.drawable.a019 }; String[] name = { "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "14" }; float[] size = { 1.10f, 1.10f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 1.1f, 2.0f }; @Override protected void onCreate(Bundle arg0) { super.onCreate(arg0); setContentView(R.layout.app_uninstall_listview); listView = (ListView) findViewById(R.id.app_uninstall_listview); List<HashMap<String, Object>> list = new ArrayList<HashMap<String, Object>>(); for (int i = 0; i < icon.length; i++) { HashMap<String, Object> map = new HashMap<String, Object>(); map.put("icon", icon[i]); map.put("name", name[i]); map.put("size", size[i]); list.add(map); SimpleAdapter adapter = new SimpleAdapter(this, list, R.layout.app_uninstallitem, new String[] { "icon", "name", "size" }, new int[] { R.id.appun_imageview, R.id.appun_nameview, R.id.app_unitem_size }); listView.setAdapter(adapter); } } } fragment XML:<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="horizontal" android:padding="2dp" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:text="手机内存" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="80dp" android:text="已用" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1.31" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="GB" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:layout_marginRight="5dp" android:text="," /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="剩余" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1.15" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="GB" /> </LinearLayout> <ProgressBar style="@android:style/Widget.ProgressBar.Horizontal" android:layout_width="match_parent" android:layout_height="5dp" android:max="100" android:progress="52" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="horizontal" android:padding="2dp" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:text="SD卡" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="104dp" android:text="已用" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1.31" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="GB" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:layout_marginRight="5dp" android:text="," /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="剩余" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1.15" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="GB" /> </LinearLayout> <ProgressBar style="@android:style/Widget.ProgressBar.Horizontal" android:layout_width="match_parent" android:layout_height="5dp" android:max="100" android:progress="52" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:padding="3dp" android:text="最近使用" /> <ListView android:id="@+id/app_uninstall_listview" android:layout_width="match_parent" android:layout_height="match_parent" > </ListView> </LinearLayout> </LinearLayout>

父Fragment 嵌套多个 Fragment与viewpager中, 子fragment中内容无法显示

如题, FragmentA 里面有个ViewPager , ViewPager里是FragB fragc.... ,Adapter 也使用了getChildFragmentManager() 但是FragmentB/C...的内容不显示 有哪位朋友碰到过这样的问题吗?望指教。

ScrollView嵌套ViewPager嵌套RecycleView item显示不全

如图所示:![图片说明](https://img-ask.csdn.net/upload/201704/24/1492995631_318407.png) 我在ScrollView里面嵌套了可以左右滑动的Viewpager,viewpager里面是上下滑动的 RecycleView,目前发现的问题是我给RecycleVIew设置的加载头显示不出来,最后一行也是显示不完全。感觉是滑动冲突的原因,但是网上没有系统的解决问题办法。请大家给点切实可行的解决办法吧 下面附上我的xml: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/rl_map_all" android:layout_width="match_parent" android:layout_height="match_parent"> <!--底部图层--> <android.support.v4.widget.DrawerLayout android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!--底部图层--> <include layout="@layout/fragment_map" /> <!--右侧侧滑栏--> <include layout="@layout/map_slide_right" /> </android.support.v4.widget.DrawerLayout> <com.yinglan.scrolllayout.ScrollLayout android:id="@+id/scroll_down_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#00550033" android:visibility="gone" app:allowHorizontalScroll="true" app:exitOffset="0dp" app:isSupportExit="true" app:maxOffset="300dp" app:minOffset="50dp" app:mode="open"> <!--多条记录悬浮--> <com.yinglan.scrolllayout.content.ContentScrollView android:layout_width="match_parent" android:layout_height="match_parent" android:fillViewport="true"> <RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="match_parent" android:layout_height="@dimen/dimen1800" android:clickable="true" android:focusable="true" android:focusableInTouchMode="true" android:orientation="vertical"> <com.example.administrator.im_demo.ui.view.navigationbar.indicators.MagicIndicator android:id="@+id/magic_indicator" android:layout_width="match_parent" android:layout_height="@dimen/dimen120" android:background="@color/tab_title" /> <android.support.v4.view.ViewPager android:id="@+id/viewpager_search_result" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> <TextView android:id="@+id/tv_next" android:layout_width="match_parent" android:layout_height="@dimen/dimen110" android:background="@color/white" android:clickable="true" android:gravity="center" android:text="总共XX条记录" android:textColor="@color/white" android:textSize="@dimen/dimen32" android:visibility="gone" /> </RelativeLayout> </com.yinglan.scrolllayout.content.ContentScrollView> </com.yinglan.scrolllayout.ScrollLayout> <android.support.v7.widget.Toolbar android:id="@+id/toolbar_mapall" android:layout_width="match_parent" android:layout_height="50dp" android:background="?attr/colorPrimary" android:minHeight="?attr/actionBarSize" android:titleTextColor="@android:color/white" app:popupTheme="@style/ThemeOverlay.AppCompat.Light" app:theme="@style/ThemeOverlay.AppCompat.ActionBar" android:visibility="gone"/> </RelativeLayout> ``` ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="@color/white"> <com.wan7451.wanadapter.mylibrary.WanRecycleView android:id="@+id/recycleview_float_company" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> ``` ``` 下面是几个引用的view: /* * * * sufly0001@gmail.com Modify the code to enhance the ease of use. * * * * Copyright (C) 2015 Ted xiong-wei@hotmail.com * * Licensed under the Apache License, Version 2.0 (the "License"); * * you may not use this file except in compliance with the License. * * You may obtain a copy of the License at * * * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an "AS IS" BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * * */ package com.yinglan.scrolllayout.content; import android.content.Context; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.ViewParent; import android.widget.ScrollView; import com.yinglan.scrolllayout.ScrollLayout; public class ContentScrollView extends ScrollView { public interface OnScrollChangedListener { void onScrollChanged(int l, int t, int oldl, int oldt); } private OnScrollChangedListener listener; public ContentScrollView(Context context) { super(context); } public ContentScrollView(Context context, AttributeSet attrs) { super(context, attrs); } public ContentScrollView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public void setOnScrollChangeListener(OnScrollChangedListener listener) { this.listener = listener; } @Override protected void onScrollChanged(int l, int t, int oldl, int oldt) { super.onScrollChanged(l, t, oldl, oldt); listener.onScrollChanged(l, t, oldl, oldt); } @Override protected void onAttachedToWindow() { super.onAttachedToWindow(); ViewParent parent = this.getParent(); while (parent != null) { if (parent instanceof ScrollLayout) { ((ScrollLayout) parent).setAssociatedScrollView(this); break; } parent = parent.getParent(); } } @Override public boolean onTouchEvent(MotionEvent ev) { ViewParent parent = this.getParent(); if (parent instanceof ScrollLayout) { if (((ScrollLayout) parent).getCurrentStatus() == ScrollLayout.Status.OPENED) return false; } return super.onTouchEvent(ev); } } ``` ``` package com.wan7451.wanadapter.mylibrary; import android.content.Context; import android.support.v7.widget.RecyclerView; import android.util.AttributeSet; import com.handmark.pulltorefresh.library.PullToRefreshBase; /** * Created by Hello on 2015/6/30. */ public class WanRecycleView extends PullToRefreshBase<RecyclerView> { public WanRecycleView(Context context) { super(context); } public WanRecycleView(Context context, AttributeSet attrs) { super(context, attrs); } public WanRecycleView(Context context, Mode mode) { super(context, mode); } public WanRecycleView(Context context, Mode mode, AnimationStyle animStyle) { super(context, mode, animStyle); } @Override public Orientation getPullToRefreshScrollDirection() { return Orientation.VERTICAL; } @Override protected RecyclerView createRefreshableView(Context context, AttributeSet attrs) { RecyclerView view = new RecyclerView(context, attrs); view.setId(R.id.recycleView); return view; } @Override protected boolean isReadyForPullEnd() { int lastVisiblePosition = getRefreshableView().getChildAdapterPosition(getRefreshableView().getChildAt(getRefreshableView().getChildCount() -1)); if (lastVisiblePosition >= getRefreshableView().getAdapter().getItemCount()-1) { return getRefreshableView().getChildAt(getRefreshableView().getChildCount() - 1).getBottom() <= getRefreshableView().getBottom(); } return false; } @Override protected boolean isReadyForPullStart() { if (getRefreshableView().getChildCount() <= 0) return true; int firstVisiblePosition = getRefreshableView().getChildAdapterPosition(getRefreshableView().getChildAt(0)); if (firstVisiblePosition == 0) return getRefreshableView().getChildAt(0).getTop() == getRefreshableView().getPaddingTop(); else return false; } } ``` ```

轮播viewpager+fragment

我用viewpager做了一个轮播效果的图,实现循环是用的handler,线程休眠三秒切换fragment,我将它们全部放在一个fragment当中,包括适配器adapter也放在里面了,当我切换到另一个fragment后再切换回来,这个滚动效果就变得不受控制了,时快时慢,还有好几张广告同时闪过的情况,求解释。。

android中Viewpager中嵌套子viewpager问题

![图片说明](https://img-ask.csdn.net/upload/201508/12/1439371457_222657.png) 如上图所示,应用首页一个Viewpager和一个RadioButton组成,而在viewpager中添加四个Fragement,通过滑动或者点击RadioButton可以进行Fragement间的切换,在第一个Fragement中添加了一个3s轮播Viewpager切换图片。现在主要有两个问题希望大家可以帮助到我,谢谢! 问题一:应用刚刚打开默认是打开第一个Fragement,这个时候该fragment中的轮播图正常播放,不过切换到其他Fragement再切换回来时,轮播图的切换时间就开始不规律的变短。 问题二:滑动切换第一个Fragement中的轮播图Viewpager时,到了最后一个继续向左滑动,响应滑动时间的最外层的Viewpager,请问如果更改代码使它切换到第一张轮播图上,而不让外层Viewpager响应? 希望大神帮我答疑解惑,或者给我一个有这种需求的demo,谢谢!

Fragment+Viewpager,第二次不显示

ViewPager嵌套Fragment,第一次加载Fragment显示内容,切换页面就不显示了,为什么

DialogFragment中使用viewpager+fragment时出现问题

fragment does not have a view ``` package com.yidi.livelibrary.widget.dialog; import android.app.Dialog; import android.content.DialogInterface; import android.os.Bundle; import android.support.annotation.Nullable; import android.support.v4.app.DialogFragment; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentActivity; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import android.support.v4.view.ViewPager; import android.view.Gravity; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.view.Window; import android.view.WindowManager; import android.widget.TextView; import com.hn.library.utils.AppLogger; import com.yidi.livelibrary.R; import com.yidi.livelibrary.ui.fragment.HnContributionFragment; import java.util.ArrayList; import java.util.List; /** * Menu Dialog */ public class HnContributionDialog extends DialogFragment implements View.OnClickListener { private FragmentActivity mActivity; private TextView tvLeft; private TextView tvMiddle; private TextView tvRight; private ViewPager viewPager; private String anchor_user_id; private ArrayList<Fragment> mFragments = new ArrayList<>(); public static HnContributionDialog newInstance(String anchor_user_id) { Bundle bundle = new Bundle(); bundle.putString("anchor_user_id",anchor_user_id); HnContributionDialog sDialog = new HnContributionDialog(); sDialog.setArguments(bundle); return sDialog; } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mActivity = getActivity(); Bundle bundle = getArguments(); if (bundle != null) { anchor_user_id = bundle.getString("anchor_user_id"); AppLogger.e(anchor_user_id); } } @Override public Dialog onCreateDialog(Bundle savedInstanceState) { View view = View.inflate(mActivity, R.layout.live_left_dialog, null); Dialog dialog = null; dialog = new Dialog(mActivity, R.style.LeftDialog); dialog.setContentView(view); dialog.setCanceledOnTouchOutside(true); Window alertWindow = dialog.getWindow(); WindowManager.LayoutParams params = alertWindow.getAttributes(); alertWindow.setGravity(Gravity.LEFT); params.height = (mActivity.getWindowManager().getDefaultDisplay().getHeight()); params.width = mActivity.getWindowManager().getDefaultDisplay().getWidth(); alertWindow.setAttributes(params); dialog.getWindow().setDimAmount(0f); //初始化组件 initView(view); return dialog; } @Override public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); } /** * 初始化视图 * * @param view */ private void initView(View view) { tvLeft = (TextView) view.findViewById(R.id.tvLeft); tvMiddle = (TextView) view.findViewById(R.id.tvMiddle); tvRight = (TextView) view.findViewById(R.id.tvRight); viewPager = (ViewPager) view.findViewById(R.id.vp); view.findViewById(R.id.vOut).setOnClickListener(this); tvLeft.setSelected(true); tvLeft.setOnClickListener(this); tvMiddle.setOnClickListener(this); tvRight.setOnClickListener(this); viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { switch (position) { case 0: tvLeft.setSelected(true); tvMiddle.setSelected(false); tvRight.setSelected(false); break; case 1: tvLeft.setSelected(false); tvMiddle.setSelected(true); tvRight.setSelected(false); break; case 2: tvLeft.setSelected(false); tvMiddle.setSelected(false); tvRight.setSelected(true); break; default: break; } } @Override public void onPageScrollStateChanged(int state) { } }); mFragments.add(HnContributionFragment.newInstance("day",anchor_user_id)); mFragments.add(HnContributionFragment.newInstance("week",anchor_user_id)); mFragments.add(HnContributionFragment.newInstance("all",anchor_user_id)); PagerAdapter adapter = new PagerAdapter(getFragmentManager(), mFragments); viewPager.setAdapter(adapter); } public void setViewPager(){ } class PagerAdapter extends FragmentPagerAdapter { private List<Fragment> mFragments; public PagerAdapter(FragmentManager fm, List<Fragment> mFragments) { super(fm); this.mFragments = mFragments; } @Override public int getCount() { return mFragments.size(); } @Override public CharSequence getPageTitle(int position) { return null; } @Override public Fragment getItem(int position) { Fragment fragment = mFragments.get(position); return fragment; } } @Override public void onClick(View v) { int id = v.getId(); if (id == R.id.tvLeft) { tvLeft.setSelected(true); tvMiddle.setSelected(false); tvRight.setSelected(false); } else if (id == R.id.tvMiddle) { tvLeft.setSelected(false); tvMiddle.setSelected(true); tvRight.setSelected(false); } else if (id == R.id.tvRight) { tvLeft.setSelected(false); tvMiddle.setSelected(false); tvRight.setSelected(true); } else if (id == R.id.vOut) { dismiss(); } } @Override public void onDestroy() { super.onDestroy(); } @Override public void onDismiss(DialogInterface dialog) { super.onDismiss(dialog); mActivity = null; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // TODO: inflate a fragment view View rootView = super.onCreateView(inflater, container, savedInstanceState); return rootView; } @Override public void onDestroyView() { super.onDestroyView(); } } ```

Fragment+ViewPager滑动里面Fragment出现空白

我是在一个Activity(也是从Fragment里跳出来的)里 用 ViewPager +Fragment, FragmentPagerAdapter里有三个 Fragment。我在滑动ViewPager的时候,第一次 滑动各个Fragment都会显示,第二次滑动的时候,只剩下第二个第三个Fragment出现空白,第一个一直 好好的。请问大侠们,这是为什么呢

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

实现简单的文件系统

实验内容: 通过对具体的文件存储空间的管理、文件的物理结构、目录结构和文件操作的实现,加深对文件系统内部功能和实现过程的理解。 要求: 1.在内存中开辟一个虚拟磁盘空间作为文件存储器,在其上实现一个简

MIPS单周期CPU-组成原理实验-华中科技大学

使用logisim布线完成的MIPS单周期CPU,可支持28条指令。跑马灯的代码已经装入了寄存器,可以直接开启时钟运行。

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

基于QT和OpenCV的五子棋实现源码

一个简单的五子棋应用,基于QT和OpenCV的实现源码,通过相邻棋子判断是否获胜,不包含人工智能算法,适合新手入门

Git 实用技巧

这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

C/C++跨平台研发从基础到高阶实战系列套餐

一 专题从基础的C语言核心到c++ 和stl完成基础强化; 二 再到数据结构,设计模式完成专业计算机技能强化; 三 通过跨平台网络编程,linux编程,qt界面编程,mfc编程,windows编程,c++与lua联合编程来完成应用强化 四 最后通过基于ffmpeg的音视频播放器,直播推流,屏幕录像,

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

linux“开发工具三剑客”速成攻略

工欲善其事,必先利其器。Vim+Git+Makefile是Linux环境下嵌入式开发常用的工具。本专题主要面向初次接触Linux的新手,熟练掌握工作中常用的工具,在以后的学习和工作中提高效率。

JAVA初级工程师面试36问(完结)

第三十一问: 说一下线程中sleep()和wait()区别? 1 . sleep()是让正在执行的线程主动让出CPU,当时间到了,在回到自己的线程让程序运行。但是它并没有释放同步资源锁只是让出。 2.wait()是让当前线程暂时退让出同步资源锁,让其他线程来获取到这个同步资源在调用notify()方法,才会让其解除wait状态,再次参与抢资源。 3. sleep()方法可以在任何地方使用,而wait()只能在同步方法或同步块使用。 ...

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

智鼎(附答案).zip

并不是完整题库,但是有智鼎在线2019年9、10、11三个月的试题,有十七套以上题目,普通的网申行测题足以对付,可以在做题时自己总结一些规律,都不是很难

Visual Assist X 破解补丁

vs a's'sixt插件 支持vs2008-vs2019 亲测可以破解,希望可以帮助到大家

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

JavaWEB商城项目(包括数据库)

功能描述:包括用户的登录注册,以及个人资料的修改.商品的分类展示,详情,加入购物车,生成订单,到银行支付等!另外还有收货地址的和我的收藏等常用操作.环境(JDK 1.7 ,mysql 5.5,Ecli

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

一学即懂的计算机视觉(第一季)

图像处理和计算机视觉的课程大家已经看过很多,但总有“听不透”,“用不了”的感觉。课程致力于创建人人都能听的懂的计算机视觉,通过生动、细腻的讲解配合实战演练,让学生真正学懂、用会。 【超实用课程内容】 课程内容分为三篇,包括视觉系统构成,图像处理基础,特征提取与描述,运动跟踪,位姿估计,三维重构等内容。课程理论与实战结合,注重教学内容的可视化和工程实践,为人工智能视觉研发及算法工程师等相关高薪职位就业打下坚实基础。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/26281 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,但是大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/26281,点击右下方课程资料、代码、课件等打包下载

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

2019 Python开发者日-培训

本次活动将秉承“只讲技术,拒绝空谈”的理念,邀请十余位身处一线的Python技术专家,重点围绕Web开发、自动化运维、数据分析、人工智能等技术模块,分享真实生产环境中使用Python应对IT挑战的真知灼见。此外,针对不同层次的开发者,大会还安排了深度培训实操环节,为开发者们带来更多深度实战的机会。

快速入门Android开发 视频 教程 android studio

这是一门快速入门Android开发课程,顾名思义是让大家能快速入门Android开发。 学完能让你学会如下知识点: Android的发展历程 搭建Java开发环境 搭建Android开发环境 Android Studio基础使用方法 Android Studio创建项目 项目运行到模拟器 项目运行到真实手机 Android中常用控件 排查开发中的错误 Android中请求网络 常用Android开发命令 快速入门Gradle构建系统 项目实战:看美图 常用Android Studio使用技巧 项目签名打包 如何上架市场

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

相关热词 c# 不能序列化继承类 c# char* 调用 c# 开发dll模板 c#添加控件到工具箱 c#控制台组合数 编程计算猴子吃桃问题c# c# wpf 背景透明 随机抽取号码软件c# c# 开发环境 c# 属性和字段
立即提问