Ответ 1
Попробуйте заменить
View v = inflater.inflate(R.layout.camera_fragment, parent);
С
View v = inflater.inflate(R.layout.camera_fragment, parent, false);
или
View v = inflater.inflate(R.layout.camera_fragment, null);
Я получаю эту ошибку. Я попробовал много решений, но я решил решить эту проблему. Помоги мне! Мне нужно добавить вид поверхности и кнопку в действие с помощью фрагментов.
CamActivity.java:
public class CamActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_cam);
FragmentManager fm = getSupportFragmentManager();
Fragment fragment = fm.findFragmentById(R.id.fragmentContainer);
if(fragment == null) {
fragment = new CamFragment();
fm.beginTransaction()
.add(R.id.fragmentContainer, fragment)
.commit();
}
}
}
CamFragment.java:
public class CamFragment extends Fragment {
private static final String TAG = "CamFragment";
private Camera mCamera;
private SurfaceView mSurfaceView;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup parent, Bundle savedInstanceState){
View v = inflater.inflate(R.layout.camera_fragment, parent);
Button capturePic = (Button)v.findViewById(R.id.img_capture);
capturePic.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
getActivity().finish();
}
});
mSurfaceView = (SurfaceView)v.findViewById(R.id.surfaceView1);
return v;
}
}
Ошибка:
04-18 13:24:12.735: E/AndroidRuntime(6321): FATAL EXCEPTION: main
04-18 13:24:12.735: E/AndroidRuntime(6321): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.pack.camdictionary/com.pack.camdictionary.CamActivity}: java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child parent first.
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1728)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1747)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread.access$1500(ActivityThread.java:155)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:993)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.os.Handler.dispatchMessage(Handler.java:130)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.os.Looper.loop(SourceFile:351)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread.main(ActivityThread.java:3814)
04-18 13:24:12.735: E/AndroidRuntime(6321): at java.lang.reflect.Method.invokeNative(Native Method)
04-18 13:24:12.735: E/AndroidRuntime(6321): at java.lang.reflect.Method.invoke(Method.java:538)
04-18 13:24:12.735: E/AndroidRuntime(6321): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
04-18 13:24:12.735: E/AndroidRuntime(6321): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:659)
04-18 13:24:12.735: E/AndroidRuntime(6321): at dalvik.system.NativeStart.main(Native Method)
04-18 13:24:12.735: E/AndroidRuntime(6321): Caused by: java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child parent first.
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.view.ViewGroup.addViewInner(ViewGroup.java:2007)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.view.ViewGroup.addView(ViewGroup.java:1902)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.view.ViewGroup.addView(ViewGroup.java:1859)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.view.ViewGroup.addView(ViewGroup.java:1839)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.NoSaveStateFrameLayout.wrap(NoSaveStateFrameLayout.java:40)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:931)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1166)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.Activity.performStart(Activity.java:3837)
04-18 13:24:12.735: E/AndroidRuntime(6321): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1701)
04-18 13:24:12.735: E/AndroidRuntime(6321): ... 11 more
Попробуйте заменить
View v = inflater.inflate(R.layout.camera_fragment, parent);
С
View v = inflater.inflate(R.layout.camera_fragment, parent, false);
или
View v = inflater.inflate(R.layout.camera_fragment, null);
На этот вопрос уже был дан ответ, но я все же хотел бы добавить причину добавления false в качестве третьего параметра.
Метод inflate() принимает три аргумента:
- Идентификатор ресурса макета, который вы хотите увеличить.
- ViewGroup, чтобы быть родителем раздутого макета. Передача контейнера важна для того, чтобы система применила параметры макета к корневому представлению раздутого макета, заданному родительским представлением, в котором он собирается.
- Логическое значение, указывающее, следует ли прикреплять раздутый макет к ViewGroup (второй параметр) во время надувания. (В этом случае это ложно, потому что система уже вставляет раздутый макет в контейнер - передача true создаст избыточную группу представлений в окончательном макете.)
Источник: http://developer.android.com/guide/components/fragments.html
Я использую API 26.0.2, и в моем случае произошел сбой из-за пользовательских анимаций, установленных для моих фрагментов. Закомментировал вызов для установки пользовательской анимации, исправил проблему.
fragmentTransaction.setCustomAnimations(android.R.anim.fade_in, android.R.anim.fade_out);
Я тоже встречал эту проблему, и это мое решение. это очень легко
View v;
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
if (v == null) {
v = inflater.inflate(R.layout.camera_fragment, container);
} else {
ViewGroup parent = (ViewGroup) v.getParent();
if (parent != null) {
parent.removeView(v);
}
}
return v;
}
Надеюсь быть полезным для вас
Укажите Id
для родительского и дочернего элементов, особенно для пользовательских представлений, в файле xml
может решить проблему.
Просто для справки. Кажется, это проблема в Android SDK.
У меня такая же ситуация, как у @Satheesh с версией SDK: 27.0.2, и попытка удалить setCustomAnimation, кажется, работает. Но для удаления setCustomAnimations требуется много изменений, я бы предпочел сохранить пользовательскую анимацию. Я обновил SDK до последней версии 27.1.1. И это работает для меня.
Может быть полезным
View customView1;
inflater= (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
customView1= inflater.inflate(R.layout.edit_custom_alert_window, null);
try {
if(customView2.getParent()!=null)
((ViewGroup)customView2.getParent()).removeView(customView2);
}catch (Exception e){
}
В моем случае я делал setTransition()
во время FragmentTransaction
. Ниже код работал для меня:
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?): View? {
if(this::rootView.isInitialized){
if(rootView.getParent() != null){
(rootView.getParent() as ViewGroup).endViewTransition(rootView)
}
return this.rootView
}
...
}
Это, вероятно, происходит, когда вы многократно переключаетесь между фрагментами, так как представление не получает времени для реального отсоединения от родителя из-за продолжающегося перехода.
попробуйте это.
((CamActivity)getActivity()).finish();