What is the TextView
Displays text to users and optionally allows them to edit the text. TextView is a complete text editor, but the base class is not allowed to edit; Its subclass EditText allows text editing.
Let’s take a look at TextView inheritance in the previous figure:
As you can see from the figure above, TxtView inherits from View. It is also the parent class of Button, EditText and many other component classes. Let’s see what these subclasses do.
- Button: A user interface element that the user can click or click to perform an action.
- CheckedTextView:TextView supports the Checkable interface and display extension.
- Chronometer: Class that implements a simple timer.
- DigitalClock:API17 is deprecated and replaced with an available TextClock.
- EditText: User interface element used to enter and modify text.
- TextClock: Displays the current date and/or time as a format string.
Look at his son is so awesome, let alone dad, today we will look at this dad class component: TextView.
Use the TextView
1. Create and set attributes in the XML
Let’s look at the picture above and talk. The text display in the image above is varied, but it only contains some of the features of TextView. It is interesting to see the variety of displays.
Let’s look at the code practices:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="@dimen/dimen_20"
android:orientation="vertical">
<! In Design, you can create a simple TextView by dragging it from the left control display onto the layout file. -->
<TextView
android:id="@+id/textView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="TextView" />
<! -- Change color, size -->
<! -- set @color/color_ff0000 -->
<! -- set size @dimen/text_size_18
<! @string/str_setting_color_size: app/values/strings-->
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/str_setting_color_size"
android:layout_marginTop="@dimen/dimen_10"
android:textColor="@color/color_ff0000"
android:textSize="@dimen/text_size_20" />
<! -- Add images and use shadows -->
<!--添加图片:drawableTop、drawableBottom、drawableLeft(drawableStart)、drawableRight(drawableEnd)-->
<! -- Use shadowColor :shadowColor, shadowDx, shadowDy, shadowRadius -->
<! -- Picture @mipmap/ic_launcher location: app/mipmap/ any directory can be found -->
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawableLeft="@mipmap/ic_launcher"
android:layout_marginTop="@dimen/dimen_10"
android:gravity="center_vertical"
android:shadowColor="@color/color_FF773D"
android:shadowDx="30"
android:shadowDy="- 20"
android:shadowRadius="2"
android:text="Add pictures and use shadows on the right"
android:textColor="@color/color_188FFF"
android:textSize="@dimen/text_size_20" />
<! -- Add links to phone calls and emails -->
<! --autoLink automatically adds hyperlinks to E-mail addresses, phone numbers, and text content -->
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:autoLink="email|phone"
android:gravity="center_vertical"
android:layout_marginTop="@dimen/dimen_10"
android:text="Please click the email :SCC5201314@qq.com\n please click the phone number :0215201314"
android:textColor="@color/color_188FFF"
android:textSize="@dimen/text_size_14" />
<! -- Too much content -->
<! Android :singleline="true"-->
<! --ellipsize, display... (first, middle, last), limit the number of rows
<! --lineSpacingMultiplier, spacing -->
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ellipsize="end"
android:gravity="center_vertical"
android:lineSpacingMultiplier="1.2"
android:layout_marginTop="@dimen/dimen_10"
android:maxLength="2"
android:text="TxtView inherits from View and is the parent of the Button and EditText UI component classes. Its function is to display the text-element on the user interface. TextView is functionally a text editor, but Android turns off its editable feature. If you want an editable text box, you use its subclass, Editext, which allows you to edit the contents of the text box. The big difference between TextView and Editext is that TextView doesn't allow you to edit the text, Editext does. Let's write a few examples to look at TextView in detail.
android:textColor="@color/color_188FFF"
android:textSize="@dimen/text_size_14" />
<! --> < p style = "text-align: center;
<! --padding inside margin (the distance from the available edge) -->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/color_ff0000"
android:layout_marginTop="@dimen/dimen_10"
android:padding="10dp"
android:text="Text with a red background."
android:textColor="@color/white" />
<! -- Text with a border -->
<! --layout_margin (distance from TextView to other controls) -->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dimen_10"
android:background="@drawable/bg_tv_frame_red"
android:padding="10dp"
android:text="Text with red border." />
<! -- Shaded text background with a border -->
<! -- code to achieve text gradient -->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dimen_10"
android:background="@drawable/bg_tv_frame_gradient"
android:padding="10dp"
android:textColor="@color/white"
android:text="Text with border and background gradient" />
</LinearLayout>
Copy the code
Android :background=”@drawable/bg_tv_frame_red”
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<! - The four RADIUS rounded corners can be set uniformly. You can also set a single radius rounded corner. Example: topLeftRadius -- >
<corners android:radius="2dp"/>
<! Width, color-->
<stroke android:width="4px" android:color="@color/color_ff0000" />
</shape>
Copy the code
Android :background=”@drawable/bg_tv_frame_gradient” android:background=”@drawable/bg_tv_frame_gradient”
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<! - The four RADIUS rounded corners can be set uniformly. You can also set a single radius rounded corner. Example: topLeftRadius -- >
<corners android:radius="8dp"/>
<! Width, color-->
<stroke android:width="1dp" android:color="@color/color_ff0000" />
<! -- Set the color of the gradient from start to end -->
<gradient
android:startColor="@color/color_188FFF"
android:centerColor="@color/color_FF773D"
android:endColor="@color/color_ff0000"
android:type="linear"
/>
</shape>
Copy the code
2. Create in XML and set attributes in code
- Layout file
<? xml version="1.0" encoding="utf-8"? > <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="@dimen/dimen_20"
android:orientation="vertical">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Here's how to do it in code."
android:textSize="@dimen/text_size_18"
android:layout_marginTop="@dimen/dimen_20"
android:layout_marginBottom="@dimen/dimen_10"
android:textColor="@color/black"
android:textStyle="bold" />
<TextView
android:id="@+id/tv_flag"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textColor="@color/color_188FFF"
android:layout_marginTop="@dimen/dimen_10"
android:text="Underline text"
android:textSize="@dimen/text_size_18" />
<TextView
android:id="@+id/tv_gradient"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dimen_10"
android:textColor="@color/white"
android:text="Isn't the gradient of text amazing?"
android:textSize="@dimen/text_size_18" />
<TextView
android:id="@+id/tv_bg"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dimen_10"
android:padding="10dp"
android:text="Set the background color"
android:textColor="@color/white"
android:textSize="@dimen/text_size_18" />
<TextView
android:id="@+id/tv_size"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dimen_10"
android:textColor="@color/color_ff0000"
android:text="Unusual size of text" />
<TextView
android:id="@+id/tv_onclick"
android:layout_width="match_parent"
android:layout_marginTop="@dimen/dimen_10"
android:layout_height="wrap_content"
android:textSize="@dimen/dimen_20"
android:text="Clickable and clickable" />
</LinearLayout>
Copy the code
- The results
- Do it in code
// Underline and clarify
tv_flag.getPaint().setFlags(Paint.UNDERLINE_TEXT_FLAG | Paint.ANTI_ALIAS_FLAG);
tv_flag.getPaint().setAntiAlias(true);/ / anti-aliasing
int[] colors = {0xff188fff.0xffff773D.0xffff0000};// An array of colors
LinearGradient mLinearGradient = new LinearGradient(0.0.0,
tv_gradient.getPaint().getTextSize(), colors, null, Shader.TileMode.CLAMP);
tv_gradient.getPaint().setShader(mLinearGradient);
tv_gradient.invalidate();
int fillColor = Color.parseColor("#ff0000");// Fill the inside with color
GradientDrawable gd = new GradientDrawable();/ / create the drawable
gd.setColor(fillColor);// Set the background color
gd.setCornerRadius(10);// Set the rounded corners
tv_bg.setBackground(gd);// Set the background
Spannable wordtoSpan = new SpannableString(tv_size.getText().toString());
//setSpan: parameter 1, set the text size; Parameter 2, the starting text position; Parameter 3, which ends by changing the text position does not include this position
wordtoSpan.setSpan(new AbsoluteSizeSpan(DensityUtil.dip2px(this.18)), 0.2, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
wordtoSpan.setSpan(new AbsoluteSizeSpan(DensityUtil.dip2px(this.24)), 2.5, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
wordtoSpan.setSpan(new AbsoluteSizeSpan(DensityUtil.dip2px(this.10)), 5, tv_size.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
tv_size.setText(wordtoSpan);
//TextView does have click events after all, its father Veiew
tv_onclick.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MLog.e("Here's the click event.");
Toast.makeText(TextViewActivity.this."Here's the click event.",Toast.LENGTH_SHORT).show(); }}); tv_onclick.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
MLog.e("Long press event here.");
Toast.makeText(TextViewActivity.this."Long press event here.",Toast.LENGTH_SHORT).show();
True indicates that the event has been consumed
return true; }});Copy the code
-
Analysis of operation results
- Most of the TextView properties that can be used in XML can also be implemented in code, depending on how you like to use them.
- Since TextView inherits from View, you can use the methods of View. Such as view.onClickListener () and view.onlongClickListener () and explore.
3. Create and set properties in the code
- First look at the renderings:
- Here is the code to implement it:
// ll_act_TV layout file root layout ID
LinearLayout ll_act_tv = findViewById(R.id.ll_act_tv);
TextView textView = new TextView(this);// Create the control
textView.setText("That's stupid code.");// Set the contents of the control
textView.setTextColor(Color.RED);// Set the control color
textView.setTextSize(DensityUtil.dip2px(this.20));// Set the font size of the control
ll_act_tv.addView(textView);
Copy the code
TextView today to talk about here, and then there are its subclasses, subclasses are also more powerful can not be done by one article. Did you learn it? Gnome male -“