Clicking On The Fragment Invokes Activity Behind It
Solution 1:
I solved a similar problem by adding android:clickable="true"
in the element that was behaving as if it was "transparent". Making it clickable made sure the click events were handled by it instead of passed to the views bellow.
Solution 2:
So, I had exactly the same issue, I still don't know the reason why, but make sure your adding the android:clickable="true" to the roovView of your 2nd fragment's layout.
something like this:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ffffff"
android:clickable="true"
android:orientation="vertical">
.....any content for your item (2nd fragment).....
</LinearLayout>
Solution 3:
I believe the issue is that the replace
method doesn't replace the ListView
. It only replaces other fragments that are within the container. In this specific case there are none. Thus, you're essentially adding your fragment on top of the ListView
because the RelativeLayout
allows views to be on top of one another. When you click on the fragment, you're not fully handling it, so it goes through to the base view which is the ListView
.
A simple, quick, and dirty solution would be to retrieve the ListView
object and either remove it from the container yourself or set it's visibility to GONE
. A better solution would be to use ListFragment which should show the expected results.
Solution 4:
Set the clickable property to true so that the click event gets consumed only on the foreground fragment.
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:clickable="true" />
Solution 5:
Set android:clickable="true" in FrameLayout tag of your foreground Fragment
it works for me.
Post a Comment for "Clicking On The Fragment Invokes Activity Behind It"