返回顶部
首页 > 资讯 > 移动开发 >Android自定义控件RatingBar调整字体大小
  • 569
分享到

Android自定义控件RatingBar调整字体大小

字体大小字体Android 2022-06-06 01:06:17 569人浏览 独家记忆
摘要

项目需要,做一个可以调整字体大小的控件,能在滑动或点击时改变选中的位置,效果图如下: 这是一个类似于RatingBar的控件,然而配置RatingBar的样式难以实现这样的效

项目需要,做一个可以调整字体大小的控件,能在滑动或点击时改变选中的位置,效果图如下:

这是一个类似于RatingBar的控件,然而配置RatingBar的样式难以实现这样的效果,如选中的图案和上面的文字对齐。因此,有必要写一个自定义View来实现。

思路如下:

新建一个TextRatingBar继承View类 在onDraw()方法中绘制元素:文字、横线、短竖线和圆形标记 重写onMeasure()方法,控制整体大小和边界 在onTouchEvent()方法中处理ACTioN_DOWN和ACTION_MOVE事件,调用invalidate()方法引起View的重绘,以更新视图 定义一个用户选中某个字体的回调接口,以通知外部处理,比如去设置字体大小。

TextRatingBar类代码如下:


package cc.rome753.demo.view;
import Android.content.Context;
import android.graphics.canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;

public class TextRatingBar extends View{
 //paddingLeft
 private int mLeft;
 //paddingTop
 private int mTop;
 //当前rating
 private int mRating;
 //总raring数
 private int mCount;
 //rating文字
 private String[] texts = {"小","中","大","超大"};
 //相邻raring的距离
 private int mUnitSize;
 //bar到底部的距离
 private int mYOffset;
 //小竖条的一半长度
 private int mMarkSize;
 Paint paint = new Paint();
 public TextRatingBar(Context context) {
  this(context, null);
 }
 public TextRatingBar(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
 }
 public TextRatingBar(Context context, AttributeSet attrs, int defStyleAttr) {
  super(context, attrs, defStyleAttr);
  mCount = 4;
  mRating = 0;
  mMarkSize = 3;
 }
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  Log.i("test", getMeasuredWidth() + " " + getMeasuredHeight());
  mLeft = (getPaddingLeft()+getPaddingRight())/2;
  mTop = getPaddingTop();
  int barWidth = getMeasuredWidth() - 2 * mLeft;
  mUnitSize = barWidth/(mCount - 1);
  mYOffset = getMeasuredHeight() - getPaddingBottom();
 }
 @Override
 protected void onDraw(Canvas canvas) {
  paint.setStrokeWidth(2);
  paint.setColor(Color.RED);
  canvas.drawLine(mLeft,mYOffset,mLeft+mRating*mUnitSize,mYOffset,paint);
  for(int i=0;i<mCount;i++){
   paint.setColor(Color.RED);
   canvas.drawLine(mLeft+i*mUnitSize,mYOffset-mMarkSize,mLeft+i*mUnitSize,mYOffset+mMarkSize,paint);
   paint.setColor(mRating == i ? Color.RED : Color.BLACK);
   paint.setTextSize(30);
   paint.setTextAlign(Paint.Align.CENTER);
   canvas.drawText(texts[i],mLeft+i*mUnitSize,mTop,paint);
  }
  paint.setColor(Color.GRAY);
  canvas.drawLine(mLeft+mRating*mUnitSize,mYOffset,mLeft+(mCount-1)*mUnitSize,mYOffset,paint);
  canvas.drawCircle(mLeft+mRating*mUnitSize,mYOffset,10,paint);
 }
 @Override
 public boolean onTouchEvent(MotionEvent event) {
  if(event.getAction() == MotionEvent.ACTION_DOWN || event.getAction() == MotionEvent.ACTION_MOVE){
   float x = event.getX();
   for(int i=0;i<mCount;i++){
    float distance = mLeft+i*mUnitSize - x;
    if(Math.abs(distance) < 100){
     setRating(i);
     if(onRatingListener != null){
      onRatingListener.onRating(mRating);
     }
     break;
    }
   }
  }
  return true;
 }
 public void setRating(int rating) {
  mRating = rating;
  invalidate();
 }
 private OnRatingListener onRatingListener;
 public void setOnRatingListener(OnRatingListener onRatingListener) {
  this.onRatingListener = onRatingListener;
 }
 interface OnRatingListener{
  void onRating(int rating);
 }
}

几个要点:

onDraw()中的绘制要注意周围的预留空间,防止最左边的字体只显示一半,或滑动条下面没有一点空白的预留空间,导致用户不好划。因此在计算每一个绘制坐标时额外加上这些。 触摸事件是判断当前触摸点离哪个rating点最近,要加上左右临界值Math.abs(distance),用户点击或划动在distance范围内就算发生了onRating()事件。

没有用到自定义属性,使用时直接放到布局中,周围加上padding就行了。


 <cc.rome753.demo.view.TextRatingBar
  android:paddingTop="20dp"
  android:paddingLeft="40dp"
  android:paddingRight="40dp"
  android:paddingBottom="35dp"
  android:layout_width="match_parent"
  android:layout_height="70dp" />
您可能感兴趣的文章:Android RatingBar星星评分控件实例代码Android评分控件RatingBar使用实例解析Android App中使用RatingBar实现星级打分功能的教程Android自定义View之自定义评价打分控件RatingBar实现自定义星星大小和间距Android控件之RatingBar自定义星级评分样式Android UI控件RatingBar实现自定义星星评分效果Android星级评分条控件RatingBar使用详解android之RatingBar控件用法详解Android中SeekBar和RatingBar用法实例分析Android开发之自定义星星评分控件RatingBar用法示例


--结束END--

本文标题: Android自定义控件RatingBar调整字体大小

本文链接: https://lsjlt.com/news/21907.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android自定义控件RatingBar调整字体大小
    项目需要,做一个可以调整字体大小的控件,能在滑动或点击时改变选中的位置,效果图如下: 这是一个类似于RatingBar的控件,然而配置RatingBar的样式难以实现这样的效...
    99+
    2022-06-06
    字体大小 字体 Android
  • Android自定义控件RatingBar调整字体大小的方法
    这篇文章主要讲解了Android自定义控件RatingBar调整字体大小的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。项目需要,做一个可以调整字体大小的控件,能在滑动或点击时改变选中的位置,效果图如下:这...
    99+
    2023-05-31
    android ratingbar roi
  • Android 自定义TextView实现文本内容自动调整字体大小
    最近做通讯录小屏机 联系人姓名显示--长度超过边界字体变小 public class AutoFitTextView extends TextView { priv...
    99+
    2022-06-06
    字体大小 自动 字体 Android
  • Android自定义View之自定义评价打分控件RatingBar实现自定义星星大小和间距
    在Android开发中,我们经常会用到对商家或者商品的评价,运用星星进行打分。然而在Android系统中自带的打分控件,RatingBar特别不好用,间距和大小无法改变。所以,...
    99+
    2022-06-06
    view Android
  • 【Android自定义控件】自适应文字大小的TextView
    Android8.0以上可以在TextView中添加autoSizeTextType实现 Android8.0以下要想达到根据TextView大...
    99+
    2022-06-06
    自适应 Android
  • Android控件之RatingBar自定义星级评分样式
    一、RatingBar简单介绍 RatingBar是基于SeekBar(拖动条)和ProgressBar(状态条)的扩展,用星形来显示等级评定,在使用默认RatingBar时,...
    99+
    2022-06-06
    Android
  • Android UI控件RatingBar实现自定义星星评分效果
    本文实例为大家分享了Android RatingBar星星评分效果的具体代码,供大家参考,具体内容如下 继承关系 AppCompatRatingBar 效果图 xml ...
    99+
    2022-06-06
    自定义 Android
  • Android自定义控件打造闪闪发光字体
    介绍 在小米的开机动画和一些欢迎界面中, 我们经常看到这种闪闪发光的流光字体。看起来很炫酷,其实实现原理相当简单,我们只需要写自定义控件继承TextView,然后使用渲染器Gr...
    99+
    2022-06-06
    字体 Android
  • Android Studio中如何调整代码字体大小
    Android Studio中如何调整代码字体大小 Android Studio是一款广泛使用的集成开发环境(IDE),用于开发Android应用程序。在进行代码编写时,对于不同的开发者来说,合适的代...
    99+
    2023-10-26
    android studio android ide Android
  • 如何调整idea字体大小
    本篇文章给大家分享的是有关如何调整idea字体大小,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在我们的电脑上打开IntelliJ IDEA,可以看到默认代码字体非常小,如下图...
    99+
    2023-06-15
  • python如何调整字体大小
    在Python中,可以使用matplotlib库来调整图表中的字体大小。具体步骤如下:1. 导入matplotlib库:```pyt...
    99+
    2023-09-15
    python
  • win10字体大小如何调整
    这篇文章主要介绍了win10字体大小如何调整的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇win10字体大小如何调整文章都会有所收获,下面我们一起来看看吧。第一步:点击左下角windows图标——设置 第二步...
    99+
    2023-07-01
  • html如何调整字体大小
    HTML中可以通过使用CSS来调整字体大小。可以使用以下方法来调整字体大小:1. 使用内联样式:在HTML标签的style属性中设置...
    99+
    2023-08-08
    html
  • axuer如何调整字体大小
    今天小编给大家分享一下axuer如何调整字体大小的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。axuer调整字体大小的方法首...
    99+
    2023-07-04
  • Win10怎么调整字体大小
    在Win10系统中,可以通过以下步骤调整字体大小:1. 打开“设置”应用程序。可以通过在任务栏中点击“开始”按钮,然后点击“设置”图...
    99+
    2023-08-22
    Win10
  • pycharm如何调整字体大小
    pycharm调整字体大小的步骤:1、打开pycharm,依次点击File—Settings,然后点击Editor,打开Font弹框,最后设置size的大小即可;2、点击File—Settings,然后点击Keymap,搜索框里输入incr...
    99+
    2023-12-09
    pycharm
  • 怎么调整pycharm字体大小
    如何调整 pycharm 字体大小?点击 "文件" 菜单 - 选择 "设置"。导航到 "外观和行为" - 选择 "字体"。调整 "字体大小" 字段中的值并单击 "确定"。 如何调整 P...
    99+
    2024-04-18
    python pycharm 代码可读性
  • pycharm怎么调整字体大小
    在 pycharm 中调整字体大小,请执行以下步骤:打开设置窗口并导航到“编辑器”>“字体”。在“字体大小”字段中调整大小。单击“应用”并重新加载 pycharm 以应用更改。您还...
    99+
    2024-04-17
    macos pycharm
  • pycharm怎么调整界面字体大小_pycharm调整界面字体大小的方法
    1、打开pycharm,点击右上角的file。 2、在下拉菜单中点击settings。 3、选择editor,点击右侧的font。 4、在size中输入对应的数字,即可改变字体大小...
    99+
    2024-05-10
    pycharm
  • Android自定义控件之自定义组合控件(三)
    前言: 前两篇介绍了自定义控件的基础原理Android自定义控件基本原理详解(一)、Android自定义控件之自定义属性(二)。今天重点介绍一下如何通过自定义组合控件来提高布...
    99+
    2022-06-06
    Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作