如何设置Android.widget.TextView的可见性选项

4
我遇到了这个问题,与FC有关。
private TextView msg, NameOut, DateOut;
msg = (TextView) findViewById(R.id.txtviewOut) ;

问题出在这里...(down the line)

msg.setVisibility(View.INVISIBLE);//set visibility to false on create

当应用程序启动时,如何将此TextView(msg)的可见性设置为false?

在#1回答编辑之后更新

好的,这是所有的代码:

fragment_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MainActivity$PlaceholderFragment">

    <EditText
        android:id="@+id/textenter"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        android:layout_below="@+id/lbledt1"
        android:layout_alignParentLeft="true" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Enter Name"
        android:id="@+id/lbledt1"
        android:layout_marginTop="26dp"
        android:layout_centerHorizontal="true" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Enter your date of birth (e.g. xx July 19xx)"
        android:id="@+id/textView"
        android:layout_below="@+id/textenter"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="57dp" />

    <EditText
        android:id="@+id/editText"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        android:layout_below="@+id/textView"
        android:layout_alignParentLeft="true" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Press this button"
        android:id="@+id/button"
        android:layout_centerVertical="true"
        android:layout_centerHorizontal="true" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="You have been awesome since"
        android:id="@+id/txtviewOut"
        android:layout_marginTop="86dp"
        android:textIsSelectable="false"
        android:layout_below="@+id/button"
        android:layout_centerHorizontal="true" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:id="@+id/txtoutName"
        android:textIsSelectable="false"
        android:layout_alignBottom="@+id/txtviewOut"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="41dp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:id="@+id/txtOutDate"
        android:layout_marginTop="28dp"
        android:textIsSelectable="false"
        android:layout_below="@+id/txtviewOut"
        android:layout_centerHorizontal="true" />

MainActivity.java:



 package com.example.helloandroidstudio;

    import android.support.v7.app.ActionBarActivity;
    import android.support.v7.app.ActionBar;
    import android.support.v4.app.Fragment;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.ViewGroup;
    import android.os.Build;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.TextView;

    public class MainActivity extends ActionBarActivity {

        private Button btnClick;
        private EditText Name, Date;
        private TextView msg, NameOut, DateOut;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            btnClick = (Button) findViewById(R.id.button) ;
            Name = (EditText) findViewById(R.id.textenter) ;
            Date = (EditText) findViewById(R.id.editText) ;
            msg = (TextView) findViewById(R.id.txtviewOut) ;
            NameOut = (TextView) findViewById(R.id.txtoutName) ;
            DateOut = (TextView) findViewById(R.id.txtOutDate) ;

    //        msg.setVisibility(View.GONE);//set visibility to false on create
            if (savedInstanceState == null) {
                getSupportFragmentManager().beginTransaction()
                        .add(R.id.container, new PlaceholderFragment())
                        .commit();
            }
        }

        public void onClick(View v)
        {
            if (v == btnClick)
            {
                if (Name.equals("") == false && Date.equals("") == false)
                {
                    NameOut = Name;
                    DateOut = Date;
                    msg.setVisibility(View.VISIBLE);
                }
                else
                {
                    msg.setText("Please complete both fields");
                    msg.setVisibility(View.VISIBLE);
                }
            }

        }


        @Override
        public boolean onCreateOptionsMenu(Menu menu) {

            // Inflate the menu; this adds items to the action bar if it is present.
            getMenuInflater().inflate(R.menu.main, menu);
            return true;
        }

        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            // Handle action bar item clicks here. The action bar will
            // automatically handle clicks on the Home/Up button, so long
            // as you specify a parent activity in AndroidManifest.xml.
            switch (item.getItemId()) {
                case R.id.action_settings:
                    return true;
            }
            return super.onOptionsItemSelected(item);
        }

        /**
         * A placeholder fragment containing a simple view.
         */
        public static class PlaceholderFragment extends Fragment {

            public PlaceholderFragment() {
            }

            @Override
            public View onCreateView(LayoutInflater inflater, ViewGroup container,
                    Bundle savedInstanceState) {
                View rootView = inflater.inflate(R.layout.fragment_main, container, false);
                return rootView;
            }
        }

    }

我试过使用setInvisibility(View.GONE),但仍然出现了FC。

我检查了id值,有一个aid值被分配并且我确实对对象进行了类型转换...

请记住,我以前做过C#,但这是我第一个Java/Android应用程序,请谅解我。


它应该可以工作,或者你可以使用其他的resId来查找另一个视图,放置Layout xml代码。你可以将可见性更改为INVISIBLE或GONE来隐藏TextView。 - Houcine
请发布 LogCat 错误。 - Sergey Shustikov
如果 (Name.equals("") == false && Date.equals("") == false) 改为 if (Name.getText().equals("") == false && Date.getText().equals("") == false)。 - Sergey Shustikov
4个回答

13

我有一些疑问,不太清楚你想要实现什么,但我会尽力澄清一些概念。

如果您想完全隐藏视图,请使用Visibility.Gone;如果您只想隐藏它但保留其位置,请使用Visibility.Invisible。

msg.setVisibility(View.INVISIBLE); // for hiding but keeping the place of your view 

msg.setVisibility(View.GONE);// for  hiding it completely , view will not take any place 

4

在你的布局中将其设置为默认值。

<TextView
    android:id="@+id/txtviewOut"
    ...
    android:visibility="invisible" />

更新:

如果您希望始终以不可见状态开始,那么这是一种方法。请注意,“不可见”表示它未显示,但在呈现时仍将占用空白空间。如果您希望它被折叠(不占用任何空间,不显示),则在代码中使用View.GONE或在布局中使用android:visibility="gone"

如果调用setVisibility导致FC,则很可能会发生空指针异常(请通过LogCat进行检查以确保)。如果是这种情况,则可能是因为您尚未调用findViewById或者您的布局不包含该ID的视图。

更新 #2:

首先,您应该始终查看LogCat并获取抛出的确切异常以及抛出异常的确切行。我敢打赌它发生在以下行上:

                NameOut = Name;
                DateOut = Date;

你正在尝试将类型为TextView的变量设置为类型为EditText的值。我认为你想要做的是将TextView的文本设置为EditText中的文本值。可以按照以下方式实现:
NameOut.setText(Name.getText().toString());
DateOut.setText(Date.getText().toString());

程序后面,我该如何使它再次可见? - user2699451
如果在执行此代码时出现强制关闭,请对其进行空值检查。唯一可能导致崩溃的原因是在布局中未找到它或者您尚未解决它。请将msg设置为View.VISIBLE。 - Rich
好的,我已经发布了所有的代码,你认为是什么原因导致了错误? - user2699451

0

你已经实现了一个

onClick(View v) 

方法没有与布局中的按钮连接起来。

在您的布局xml文件中设置属性android:onClick="onClick"

现在,您的按钮点击没有被注册,方法也没有被执行。


0

在 Kotlin 中实现此操作:

<Text android:visibility="gone"/>

如果您希望始终将其设置为不可见,则可以使用此方法。请注意,“不可见”表示它不会被显示,但在呈现时仍会占用空白空间。如果您希望它被折叠(不占用任何空间,也不显示),则在代码中使用View.GONE
对于可见性:
text.Visibility = View.Visible

已删除:

text.Visibility = View.Gone

(因为Gone不使用main_activity.xml中的空间。 只有在设置为可见时才会占用空间。)


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接