我有一个2标签的活动,一个包含信息屏幕的标签(下面代码中的id是'targetLayout'),带有一些TextViews,另一个标签包含一个MapView。使用布局,我正在尝试添加一个只显示在MapView选项卡屏幕上的按钮,但它显示在两者上。奇怪的是,如果我改变布局,使按钮只在信息选项卡上,那就有效。我不得不遗漏一些东西,但不清楚是什么。
这是导致按钮显示在两者上的布局:
<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TabWidget
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/targetLayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:id="@+id/textViewTargetPositionLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:text="Target Position"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewTargetPosition"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewTargetPositionLabel"
android:layout_centerHorizontal="true"
android:text="Waiting"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewTargetRangeLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewTargetPosition"
android:layout_marginTop="10dp"
android:text="Range(M):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetAzimuthLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetRangeLabel"
android:text="Azimuth(Deg):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetElevationLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetAzimuthLabel"
android:text="Elevation(Deg):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetTimeLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetElevationLabel"
android:text="Time lased:"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewGPSAccuracy"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetTimeLabel"
android:text="GPS Accuracy When Lased:"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewYourPositionLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewGPSAccuracy"
android:layout_centerHorizontal="true"
android:layout_marginTop="20dp"
android:text="Your Position"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewYourPosition"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewYourPositionLabel"
android:layout_centerHorizontal="true"
android:text="Waiting for GPS Fix"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewGPSStatus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewYourPosition"
android:layout_marginTop="14dp"
android:text="GPS Status: Initializing" />
<TextView
android:id="@+id/textViewGPSInfo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBaseline="@+id/textViewGPSStatus"
android:layout_alignBottom="@+id/textViewGPSStatus"
android:layout_alignParentRight="true" />
</RelativeLayout>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/mainlayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<com.google.android.maps.MapView
android:id="@+id/mapview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:apiKey="<my key is in here>"
android:clickable="true"
android:enabled="true" />
<Button
android:id="@+id/googlemaps_select_location"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:text="Select" />
</RelativeLayout>
</FrameLayout>
</LinearLayout>
</TabHost>
这是将按钮放在信息选项卡上的布局。唯一不同的是该按钮现在位于信息选项卡的RelativeLayout:
<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TabWidget
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/targetLayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:id="@+id/textViewTargetPositionLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:text="Target Position"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewTargetPosition"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewTargetPositionLabel"
android:layout_centerHorizontal="true"
android:text="Waiting"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewTargetRangeLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewTargetPosition"
android:layout_marginTop="10dp"
android:text="Range(M):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetAzimuthLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetRangeLabel"
android:text="Azimuth(Deg):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetElevationLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetAzimuthLabel"
android:text="Elevation(Deg):"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewTargetTimeLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetElevationLabel"
android:text="Time lased:"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewGPSAccuracy"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewTargetTimeLabel"
android:text="GPS Accuracy When Lased:"
android:textAppearance="?android:attr/textAppearanceSmall" />
<TextView
android:id="@+id/textViewYourPositionLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewGPSAccuracy"
android:layout_centerHorizontal="true"
android:layout_marginTop="20dp"
android:text="Your Position"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewYourPosition"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textViewYourPositionLabel"
android:layout_centerHorizontal="true"
android:text="Waiting for GPS Fix"
android:textAppearance="?android:attr/textAppearanceLarge" />
<TextView
android:id="@+id/textViewGPSStatus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/textViewYourPosition"
android:layout_marginTop="14dp"
android:text="GPS Status: Initializing" />
<TextView
android:id="@+id/textViewGPSInfo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBaseline="@+id/textViewGPSStatus"
android:layout_alignBottom="@+id/textViewGPSStatus"
android:layout_alignParentRight="true" />
<Button
android:id="@+id/googlemaps_select_location"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:text="Select" />
</RelativeLayout>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/mainlayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<com.google.android.maps.MapView
android:id="@+id/mapview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:apiKey="my key is in here"
android:clickable="true"
android:enabled="true" />
</RelativeLayout>
</FrameLayout>
</LinearLayout>
</TabHost>
答案 0 :(得分:0)
此代码是否在屏幕上显示您的标签?
答案 1 :(得分:0)
我总是在不同的文件中有单独的标签视图。
MainLayout.xml - 包含选项卡主机和框架布局。
Tab1.xml - 包含标签1的布局
Tab2.xml - 包含选项卡2的布局
在主活动的选项卡选择功能中,检查选择了哪个选项卡,并将该xml文件放入MainLaout.xml的框架布局中。检查android选项卡示例项目以获取详细信息。
答案 2 :(得分:0)
最后追踪了解决方案。在我的活动代码中,我使用MapView视图填充MapView选项卡,在原始问题的布局代码中使用id“mapview”。使用包含MapView视图的RelativeLayout(id'mainlayout')填充选项卡,使其正常工作。我根据我在网上找到的一个例子编写了原始代码,它工作正常,直到你开始尝试像我一样修饰它。