2020征文-TV「续3.1.1 文本组件」不需要背景图,自定义绘制会更好

开发 前端
本小节我们对ShapeElement类做具体介绍,在后面的组件中将不在详细介绍,可以根据本节内容自定义不同样式的组件。对于ShapeElement类中的另外两个绘制几何图形的方法,我将在后面的小节中单独介绍。

 [[356867]]

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/#zz

上节我们对Text组件有了详细的认知,我们可以通过设置Text组件的各类属性来让Text组件美观起来,但是我们仅仅能设置背景、字体大小、字体大小自适应、内容折行、外边距、内边距等。很多时候我们想给字体设置边框、圆角、阴影等等特殊的效果,但是在属性中没有特定的属性可以完成这件事。当然我们可以给Text组件设置背景图片,这样也可以达到我们的预期效果,但是如果整个APP中图片比较多会增加我们安装包的体积,还会在各种手机的适配上出现不可预知的问题。

官方团队提供了一个可以绘制带有颜色、渐变、边框,用于视图背景的,及设置各种形状的类—ShapeElement。

ShapeElement类源码

ShapeElement类是Element的子类,Element类有多个扩展类,这里就不详细说明了,后面我们在需要的时候再扩展讲解。目前Java API中提供了多个常量值,两个构造函数,以及多个绘图方法。

我们先来了解一下能够设置哪些形状?

ShapeElement类提供了设置矩形、椭圆形、直线、圆弧和路径(以直线段、二次曲线和三次曲线的几何组合表示多轮廓路径)。本节仅对前三个几何图形做介绍,后两个后面小节会详细介绍。

  1. /** 
  2.   * 继承自Element,提供了带有颜色渐变的可绘制实例,通常用于视图背景 
  3.   */ 
  4. public class ShapeElement extends Element { 
  5.     // 可绘制的几何图形 
  6.     // 绘制形状为矩形 
  7.     public static final int RECTANGLE = 0; 
  8.     // 绘制形状为椭圆 
  9.     public static final int OVAL = 1; 
  10.     // 绘制形状为直线 
  11.     public static final int LINE = 2; 
  12.      
  13.     //默认构造器,在代码中设定几何图形和背景的话,使用这个构造函数 
  14.     public ShapeElement() {} 
  15.     //引用资源文件中设定的几何图形和背景的话,使用这个构造函数 
  16.     //xmlId为资源文件的内存地址 
  17.     public ShapeElement(Context context, int xmlId) {} 
  18.      
  19.     //设置要显示的集合图形,参数为上面的静态常量 
  20.     public void setShape(int shape) {} 
  21.     //设置背景颜色 
  22.     public void setRgbColor(RgbColor color) {} 
  23.     //设置渐变效果填充的颜色值,参数为颜色数组,对直线无效 
  24.     public void setRgbColors(RgbColor[] colors) {} 
  25.     //设置边框的宽度和颜色 
  26.     public void setStroke(int width, RgbColor color) {} 
  27.     //设置圆角半径,这个方法仅对矩形有效 
  28.     public void setCornerRadius(float radius) {} 
  29.     //设置每个角的半径,这个方法仅对矩形有效 
  30.     //表示四个角的半径数组。如果数组的长度不等于8,则该设置无效。 
  31.     // 每对半径表示一个角的x轴半径和y轴半径。 
  32.     public void setCornerRadiiArray(float[] radii) {} 
  33.     //指定组件的渐变效果方向 
  34.     public void setOrientation(ShapeElement.Orientation orientation) {} 
  35.     public void setGradientOrientation(ShapeElement.Orientation orientation) {} 
  36.     //设置虚线的间隔和相位 
  37.     //数组项是成对的:这些值的偶数和奇数索引分别指定要绘制的象素个数和空白象素个数。 
  38.     public void setDashPathEffectValues(float[] intervals, float phase) {} 

 ShapeElement实例应用

上面我们将常用的源码做了简单分析,接下来我们将以实操为主,能够熟练掌握ShapeElement的应用。

我们先来看看上面的UI界面,上面有三种自定义文本显示,矩形、椭圆形、直线。而OHOS还提供了圆弧和基于路径的多形状图。在矩形中,我们分别实现了默认的矩形背景,四角相同的圆角矩形背景,四角不同的圆角矩形背景,实线边框的矩形背景,虚线边框的矩形背景,椭圆背景,圆形背景,及直线背景。

首先我们先了解一下,我们为何使用这种类型的背景。

1、给app瘦身,可以替代纯色和渐变色的组件背景

2、编写一个矩形、圆、椭圆,便于维护,只需要改动少量代码即可实现效果

3、节省内存

这些设置背景的图形和背景色在ShapeElement类中,ShapeElement类是Element类的子类,该类用于实现带有渐变效果的图形化视图背景。其提供了矩形、椭圆形、直线、圆弧和基于路径的多形状图,本节我们先来对矩形、椭圆形和直线做示例介绍,后两种我们在后续开专门的小节做详细介绍。

矩形

矩形是常见的视图背景,我们可以设置默认的矩形、带圆角的矩形、带边框的矩形。

  1. //矩形背景 
  2. DirectionalLayout rectangle_layout = initChildDirectionalLayout(this); 
  3.  
  4. //这个组件显示的效果是"带背景的矩形" 
  5. Text rectangle_background_text = initText(this, "带背景的矩形"); 
  6. //设置背景色 
  7. ShapeElement rectangle_background_text_element = initChildShapeElement(this); 
  8. rectangle_background_text_element.setShape(ShapeElement.RECTANGLE); 
  9. rectangle_background_text.setBackground(rectangle_background_text_element); 
  10. rectangle_layout.addComponent(rectangle_background_text); 
  11.  
  12. //这个组件显示的效果是"带背景和圆角的矩形" 
  13. Text rectangle_background_radius_text = initText(this, "带背景和圆角的矩形"); 
  14. //设置背景色和圆角 
  15. ShapeElement rectangle_background_radius_text_element = initChildShapeElement(this); 
  16. rectangle_background_radius_text_element.setShape(ShapeElement.RECTANGLE); 
  17. rectangle_background_radius_text_element.setCornerRadius(20); 
  18. rectangle_background_radius_text_element.setDashPathEffectValues(new float[]{20f, 25f, 30f, 35f}, 2); 
  19. rectangle_background_radius_text.setBackground(rectangle_background_radius_text_element); 
  20. rectangle_layout.addComponent(rectangle_background_radius_text); 
  21.  
  22. //这个组件显示的效果是"带背景和四角不同圆角的矩形" 
  23. Text rectangle_background_different_radius_text = initText(this, "带背景和不同圆角的矩形"); 
  24. //设置背景色和每个角的圆角 
  25. ShapeElement rectangle_background_different_radius_text_element = initChildShapeElement(this); 
  26. rectangle_background_different_radius_text_element.setShape(ShapeElement.RECTANGLE); 
  27. rectangle_background_different_radius_text_element.setCornerRadiiArray(new float[]{20, 40, 30, 60, 20, 20, 100, 120}); 
  28. rectangle_background_different_radius_text.setBackground(rectangle_background_different_radius_text_element); 
  29. rectangle_layout.addComponent(rectangle_background_different_radius_text); 
  30.  
  31.  
  32. //这个组件显示的效果是"渐变背景"矩形 
  33. Text gradient_background_text = initText(this, "带渐变效果的矩形背景"); 
  34. //设置背景色和渐变(从下端角到上端角) 
  35. ShapeElement gradient_background_text_element = initChildShapeElement(this); 
  36. gradient_background_text_element.setShape(ShapeElement.RECTANGLE); 
  37. RgbColor[] rgbColors = new RgbColor[]{new RgbColor(34, 197, 255), new RgbColor(255, 197, 34)}; 
  38. gradient_background_text_element.setRgbColors(rgbColors); 
  39. gradient_background_text_element.setGradientOrientation(ShapeElement.Orientation.BOTTOM_END_TO_TOP_START); 
  40. gradient_background_text.setBackground(gradient_background_text_element); 
  41. rectangle_layout.addComponent(gradient_background_text); 
  42.  
  43. //这个组件的效果是"实线边框的背景"矩形 
  44. Text stroke_background_text = initText(this, "实线边框的背景"); 
  45. //设置背景色和路径 
  46. ShapeElement stroke_background_text_element = initChildShapeElement(this); 
  47. stroke_background_text_element.setShape(ShapeElement.RECTANGLE); 
  48. stroke_background_text_element.setStroke(5, new RgbColor(255, 197, 34)); 
  49. stroke_background_text.setBackground(stroke_background_text_element); 
  50. rectangle_layout.addComponent(stroke_background_text); 
  51.  
  52. //这个组件的效果是"虚线边框的背景"矩形 
  53. Text stroke_dash_background_text = initText(this, "虚线边框的背景"); 
  54. //设置背景色和路径 
  55. ShapeElement stroke_dash_background_text_element = initChildShapeElement(this); 
  56. stroke_dash_background_text_element.setShape(ShapeElement.RECTANGLE); 
  57. stroke_dash_background_text_element.setStroke(5, new RgbColor(255, 197, 34)); 
  58. stroke_dash_background_text_element.setDashPathEffectValues(new float[]{10, 21, 32, 43, 54, 65}, 1); 
  59. stroke_dash_background_text.setBackground(stroke_dash_background_text_element); 
  60. rectangle_layout.addComponent(stroke_dash_background_text); 

 

OHOS也提供了加载XML资源文件的方法,在graphic文件夹下可以创建xml类型的可绘制资源,如SVG可缩放矢量图形文件、基本的几何图形(如矩形、圆形、线等)shape资源,下面是shape资源XML格式:

  1. <?xml version="1.0" encoding="UTF-8" ?> 
  2. <shape xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  3.        ohos:shape="rectangle"
  4.     <solid 
  5.         ohos:color="#FFFFFF"/> 
  6. </shape> 

 其中ohos:shape是指定几何图形,rectangle为矩形样式。shape的属性有solid(背景色)、corners表示圆角、gradient表示渐变、stroke表示边框。

  1. <?xml version="1.0" encoding="UTF-8" ?> 
  2. <shape xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  3.        ohos:shape="rectangle"
  4.     <solid 
  5.         ohos:color="#FF6A5C"/> 
  6.  
  7.     <corners 
  8.         ohos:radius="20"/> 
  9. <!-- 由于缺少相关文档,还未摸索出渐变的设置方式 --> 
  10. <!--    <gradient/>--> 
  11.  
  12.     <stroke 
  13.         ohos:width="2" 
  14.         ohos:color="#000000"/> 
  15. </shape> 

  

椭圆形

椭圆一般我们不常用,但是圆形我们是常用的,比如默认头像,我们使用纯色背景来实现。

  1. //椭圆形背景 
  2.  
  3. DirectionalLayout oval_layout = initChildDirectionalLayout(this); 
  4.  
  5. //这个组件显示的效果是"带背景的椭圆" 
  6.  
  7. Text oval_background_text = initText(this, "带背景的椭圆"); 
  8.  
  9. //设置背景和椭圆 
  10.  
  11. ShapeElement oval_background_text_element = initChildShapeElement(this); 
  12.  
  13. oval_background_text_element.setShape(OVAL); 
  14.  
  15. oval_background_text.setBackground(oval_background_text_element); 
  16.  
  17. oval_layout.addComponent(oval_background_text); 
  18.  
  19. //这个组件显示的效果是"带背景的圆" 
  20.  
  21. Text circular_background_text = initText(this, "带背景的圆"); 
  22.  
  23. circular_background_text.setWidth(300); 
  24.  
  25. circular_background_text.setHeight(300); 
  26.  
  27. circular_background_text.setTextAlignment(CENTER); 
  28.  
  29. //设置背景和圆(组件的宽高一样的时候是圆) 
  30.  
  31. ShapeElement circular_background_text_element = initChildShapeElement(this); 
  32.  
  33. circular_background_text_element.setShape(OVAL); 
  34.  
  35. circular_background_text.setBackground(circular_background_text_element); 
  36.  
  37. oval_layout.addComponent(circular_background_text); 
  38.  
  39. layout.addComponent(oval_layout); 

 

直线

直线我们只需要了解即可,这个实际项目中没有多大意义。

  1. //直线 
  2.  
  3. DirectionalLayout line_layout = initChildDirectionalLayout(this); 
  4.  
  5. Text line_background_text = initText(this, "直线"); 
  6.  
  7. ShapeElement line_background_text_element = initChildShapeElement(this); 
  8.  
  9. line_background_text_element.setShape(LINE); 
  10.  
  11. line_background_text.setBackground(line_background_text_element); 
  12.  
  13. line_layout.addComponent(line_background_text); 
  14.  
  15. layout.addComponent(line_layout); 

 

本小节我们对ShapeElement类有了一些具体的了解,在后面的组件中将不在详细介绍,可以根据本节内容自定义不同样式的组件。对于ShapeElement类中的另外两个绘制几何图形的方法,我将在后面的小节中单独介绍。

XML文件方式设置我在文中简单的做了介绍,如果直接在布局XML中引用graphic文件下的资源,可以设置组件的ohos:background_element属性。

  1. ohos:background_element="$graphic:rectangle_background_radius_text" 

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/#zz

 

责任编辑:jianghua 来源: 鸿蒙社区
相关推荐

2020-12-04 12:42:59

组件鸿蒙Text

2020-12-23 11:45:27

鸿蒙HarmonyOSTextField组件

2015-07-22 10:57:36

watchOS图表自定义

2020-12-09 11:53:24

鸿蒙开发HelloWord

2017-03-13 13:54:40

戴尔

2012-08-23 09:50:07

测试测试人员软件测试

2009-11-23 12:45:22

2022-04-24 15:17:56

鸿蒙操作系统

2023-02-20 15:20:43

启动页组件鸿蒙

2009-06-24 15:13:36

自定义JSF组件

2015-09-30 09:57:53

天分热情工程师

2015-08-20 10:56:19

算法界面开发

2013-12-02 09:43:29

字符串编程

2024-02-22 09:00:00

LogitMat数据集算法

2022-09-14 15:10:40

前端架构

2010-11-23 10:55:47

跳槽

2013-07-18 09:21:32

代码文档

2014-01-17 13:09:48

Linux碎片整理

2021-12-12 22:20:47

Docker开发容器

2022-02-15 07:26:34

web前端算法题
点赞
收藏

51CTO技术栈公众号