Scala中变高变宽的实现:heighten和widen

开发 后端
本文节选自Martin Odersky,Lex Spoon和Bill Venners所著,Regular翻译的《Programming in Scala》的第十章。Scala是一种针对 JVM 将函数和面向对象技术组合在一起的编程语言。

我们现在需要***一个改良。展示在代码10.11中的Element的版本并不完全,因为他不允许客户把不同宽度的元素堆叠在一起,或者不同高度的元素靠在一起。比方说,下面的表达式将不能正常工作,因为组合元素的第二行比***行要长:

  1. new ArrayElement(Array("hello")) above  
  2. new ArrayElement(Array("world!"))  
与之相似的,下面的表达式也不能正常工作,因为***个ArrayElement高度为二,而第二个的高度只是一:

  1. new ArrayElement(Array("one""two")) beside  
  2. new ArrayElement(Array("one"))  

51CTO编辑推荐:Scala编程语言专题

代码10.13展示了一个私有帮助方法,widen,能够带个宽度做参数并返回那个宽度的Element。结果包含了这个Element的内容,居中,左侧和右侧留需带的空格以获得需要的宽度。代码10.13还展示了一个类似的方法,heighten,能在竖直方向执行同样的功能。widen方法被above调用以确保Element堆叠在一起有同样的宽度。类似的,heighten方法被beside调用以确保靠在一起的元素具有同样的高度。有了这些改变,布局库可以待用了。

  1. import Element.elem  
  2. abstract class Element {  
  3.  def contents: Array[String]  
  4.  def width: Int = contents(0).length  
  5.  def height: Int = contents.length  
  6.  def above(that: Element): Element = {  
  7.   val this1 = this widen that.width  
  8.   val that1 = that widen this.width  
  9.   elem(this1.contents ++ that1.contents)  
  10.  }  
  11.  def beside(that: Element): Element = {  
  12.   val this1 = this heighten that.height  
  13.   val that1 = that heighten this.height  
  14.   elem(  
  15.    for ((line1, line2) < - this1.contents zip that1.contents)  
  16.    yield line1 + line2  
  17.   )  
  18.  }  
  19.  def widen(w: Int): Element =  
  20.   if (w < = width) this 
  21.   else {  
  22.    val left = elem(' ', (w - width) / 2, height)  
  23.    var right = elem(' ', w – width - left.width, height)  
  24.    left beside this beside right  
  25.   }  
  26.  def heighten(h: Int): Element =  
  27.   if (h < = height) this 
  28.   else {  
  29.    val top = elem(' ', width, (h - height) / 2)  
  30.    var bot = elem(' ', width, h – height - top.height)  
  31.    top above this above bot  
  32.  }  
  33.  override def toString = contents mkString "\n" 
  34. }  

代码 10.13 有了widen和heighten方法的Element

【相关阅读】

  1. 学习Scala的定义工厂对象
  2. 如何实现Scala的above,beside和toString
  3. Scala学习:使用组合与继承
  4. 在Scala中定义final成员
  5. Scala程序中如何实现多态和动态绑定

责任编辑:book05 来源: Artima
相关推荐

2009-07-22 08:52:05

Scala动态绑定

2009-08-03 18:24:28

C# 4.0协变和逆变

2009-07-22 09:08:09

Scalaabove方法

2009-07-20 18:03:26

Scala程序Singleton对象

2009-07-21 14:03:00

Scalaif表达式while循环

2009-08-13 10:35:05

Scala数组排序

2009-06-16 17:54:38

Scala类语法语义

2009-09-22 10:15:42

PersistentQScala

2012-07-18 09:45:32

Java 8ScalaLambda

2009-09-22 09:59:40

QueueCollecScala

2009-07-22 07:45:00

Scala代码重复

2009-07-22 07:53:00

Scala扩展类

2009-07-08 15:35:18

Case类Scala

2009-07-22 09:43:30

Scala类型

2023-06-30 17:56:31

Scala元组

2009-05-27 11:30:20

C#Visual Stud协变

2023-06-12 15:33:52

Scalafor循环语句

2009-09-09 11:37:08

Scala的模式匹配

2009-09-28 11:25:17

PersistentQKestrelScala

2009-07-21 17:21:57

Scala定义函数
点赞
收藏

51CTO技术栈公众号