Android - 将RelativeLayout更改为Fragment

时间:2017-01-22 15:57:14

标签: android android-layout

我想"翻拍"我的应用。 我已经写了一个应用程序,它运行正常。但是,它使用Activity和Spinner在屏幕之间切换 - 这太不舒服而且很慢。 我在这里找到一个Fragment用法示例,用户可以舒适地使用并通过滑动快速切换屏幕: http://www.theappguruz.com/blog/android-tab-layout-with-swipeable-views

但我不能从我的应用程序中为它设置RelativeLayout,因为它使用Fragment。 有没有办法'#34; copy-paste"标记文件(* .xml)没有在应用程序中进行根本性更改?

我试图这样做(注释的代码行),但它不起作用。

FirstTab.java

import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout.LayoutParams;
import android.widget.TextView;

public class FirstTab extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        /*View view=inflater.inflate(R.layout.tab_first, container, false);
        Button imageView = (Button) getView().findViewById(R.id.btn_quit);
        return view;*/

        TextView tv = new TextView(getActivity());
        tv.setText("First Tab");
        tv.setGravity(Gravity.CENTER);
        tv.setTextColor(Color.WHITE);
        tv.setWidth(LayoutParams.MATCH_PARENT);
        tv.setHeight(LayoutParams.MATCH_PARENT);
        tv.setBackgroundColor(Color.RED);
        tv.setTextAppearance(getActivity(),android.R.style.TextAppearance_Large);
        return tv;
    }
}

first_tab.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_gravity="center"
    android:paddingBottom="5sp"
    android:paddingTop="5sp"
    android:paddingRight="5sp"
    android:paddingLeft="5sp"
    android:background="@color/colorPrimary">

    <Spinner
        android:entries="@array/activity_list"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/spinner"
        android:layout_alignRight="@+id/view1"
        android:layout_alignEnd="@+id/view1"
        android:layout_toRightOf="@+id/btn_quit"
        android:layout_toEndOf="@+id/btn_quit"
        android:layout_alignBottom="@+id/btn_quit"
        android:layout_alignParentTop="true" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Close\napp"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:id="@+id/btn_quit"
        android:onClick="quit"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true" />

    <View
        android:layout_width="fill_parent"
        android:layout_height="5dp"
        android:background="@android:color/holo_orange_light"
        android:id="@+id/view1"
        android:layout_below="@+id/btn_quit"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true" />

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/eng_text"
        android:paddingTop="10dp"
        android:paddingBottom="10dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:background="@android:color/white"
        android:hint="Enter text"
        android:minLines="1"
        android:layout_below="@+id/view1"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:inputType="textCapSentences|textAutoCorrect|textMultiLine"
        android:maxLines="7"/>

    <View
        android:layout_width="fill_parent"
        android:layout_height="5dp"
        android:background="@android:color/holo_orange_light"
        android:id="@+id/view"
        android:layout_below="@+id/eng_text"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true" />

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/morse_text"
        android:paddingTop="10dp"
        android:paddingBottom="10dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:background="@android:color/white"
        android:hint="Get a code"
        android:minLines="1"
        android:layout_below="@+id/view"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:inputType="textCapSentences|textAutoCorrect|textMultiLine"
        android:maxLines="8" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Translate"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:id="@+id/trans_btn"
        android:layout_above="@+id/btn_sound"
        android:layout_centerHorizontal="true"
        android:layout_alignParentRight="true"
        android:onClick="translate"/>

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:gravity="left|bottom"
        android:text="Play\ncode:"
        android:id="@+id/play_label"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/trans_btn"
        android:layout_toLeftOf="@+id/btn_sound"
        android:layout_toStartOf="@+id/btn_sound" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn_sound"
        android:layout_alignParentBottom="true"
        android:layout_toLeftOf="@+id/btn_flash"
        android:layout_toStartOf="@+id/btn_flash"
        android:padding="2dp"
        android:onClick="play_sound"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn_flash"
        android:layout_alignParentBottom="true"
        android:layout_alignRight="@+id/view"
        android:layout_alignEnd="@+id/view"
        android:padding="2dp"
        android:onClick="play_flash"/>

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:text="Current input\nlanguage:"
        android:id="@+id/cur_lang"
        android:layout_alignTop="@+id/trans_btn"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn_flag"
        android:layout_alignTop="@+id/cur_lang"
        android:layout_toRightOf="@+id/cur_lang"
        android:layout_toEndOf="@+id/cur_lang"
        android:enabled="false"/>

</RelativeLayout>

First two screenshoots - what I have; Third - what I want to do

1 个答案:

答案 0 :(得分:1)

您希望使用视图寻呼机

将整个三个活动转换为适合单个页面
  1. 使用根标记创建一个新的活动android.supprot.v4.ViewPager

  2. 设置适配器和所有其他内容

  3. 在第一个标签中使用以下代码

    public View onCreateView(LayoutInflater inflater,ViewGroup容器,                              Bundle savedInstanceState){         View view = inflater.inflate(R.layout.tab_first,container,false);

        Button button = (Button)view.findViewById(R.id.btn_quit);
        button.setText("Working quit");
        return view; 
    

    }

  4. 使用view访问first_tab的任何元素