android自定义textview,Android自定义TextView实现文字倾斜效果

前言

由于Android自带的TextView控件没有提供倾斜的(我暂时没有找到),我们可以自定义控件来实现,下面首先来看我们实现的效果图。

15059103551.gif?20161029103349

TextView文字倾斜

其实实现很简单,下面我们来看实现步骤:

1、新建一个类 LeanTextView继承TextView

public class LeanTextView extends TextView {

public int getmDegrees() {

return mDegrees;

}

public void setmDegrees(int mDegrees) {

this.mDegrees = mDegrees;

invalidate();

}

private int mDegrees;

public LeanTextView(Context context) {

super(context,null);

}

public LeanTextView(Context context,AttributeSet attrs) {

super(context,attrs,android.R.attr.textViewStyle);

this.setGravity(Gravity.CENTER);

TypedArray a = context.obtainStyledAttributes(attrs,R.styleable.LeanTextView);

mDegrees = a.getDimensionPixelSize(R.styleable.LeanTextView_degree,0);

a.recycle();

}

@Override

protected void onMeasure(int widthMeasureSpec,int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec,heightMeasureSpec);

setMeasuredDimension(getMeasuredWidth(),getMeasuredWidth());

}

@Override

protected void onDraw(Canvas canvas) {

canvas.save();

canvas.translate(getCompoundPaddingLeft(),getExtendedPaddingTop());

canvas.rotate(mDegrees,this.getWidth() / 2f,this.getHeight() / 2f);

super.onDraw(canvas);

canvas.restore();

}

}

2、在values文件中新建styleable.xml

3、页面布局,引用自定义控件

android:id="@+id/lean"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:padding="10dp"

android:text="爱开发" />

这里我们用TextView记录倾斜的角度,用SeekBar动态改变角度

android:id="@+id/lean"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:padding="10dp"

android:text="爱开发" />

android:id="@+id/degrees"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:padding="10dp"

android:gravity="center"/>

android:id="@+id/sb_lean"

android:layout_width="match_parent"

android:layout_marginTop="20dp"

android:layout_height="wrap_content"

android:max="100"

android:progress="30" />

java代码

mText= (LeanTextView) findViewById (R.id.lean);

degrees= (TextView) findViewById (R.id.degrees);

SeekBar sbLean = (SeekBar) findViewById(R.id.sb_lean);

sbLean.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {

@Override

public void onProgressChanged(SeekBar seekBar,int progress,boolean fromUser) {

mText.setmDegrees(progress);

degrees.setText("倾斜度:"+progress);

}

@Override

public void onStartTrackingTouch(SeekBar seekBar) {

}

@Override

public void onStopTrackingTouch(SeekBar seekBar) {

}

});

这样关于TextView 文字倾斜的自定义控件就算基本完成了,是不是很简单。

项目结构图:

15059103552.jpg?20161029103530

TextView文字倾斜项目结构图

总结

以上就是这篇文章的全部内容了,希望本文的内容对各位Android开发者们能有所帮助,如果有疑问大家可以留言交流。

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Android自定义TextView中显示全部内容,可以使用以下两种方法: 1. 使用setEllipsize()方法 通过设置setEllipsize()方法,可以在TextView的末尾添加省略号,从而指示文本被截断。你可以使用以下代码来实现: ``` yourTextView.setEllipsize(TextUtils.TruncateAt.END); yourTextView.setSingleLine(true); ``` 上述代码将设置TextView只显示一行并在末尾添加省略号。 2. 自定义TextView 你可以从TextView类继承一个新类,并覆盖onMeasure()方法以测量控件的高度和宽度。 你可以使用以下代码实现: ``` public class CustomTextView extends TextView { public CustomTextView(Context context) { super(context); } public CustomTextView(Context context, AttributeSet attrs) { super(context, attrs); } public CustomTextView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); //获取TextView的内容 CharSequence text = getText(); if (text != null) { //测量TextView的高度 int width = getMeasuredWidth(); int height = getMeasuredHeight(); int lineCount = getLineCount(); int lineHeight = getLineHeight(); int totalHeight = lineCount * lineHeight; if (totalHeight > height) { setMeasuredDimension(width, totalHeight); } } } } ``` 上述代码将测量TextView的高度,如果文本的高度超出了TextView的高度,则调整TextView的高度以适应文本。然后你可以使用此自定义TextView来显示你的文本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值