zoukankan      html  css  js  c++  java
  • 处理方块之间的连接线


        LinkInfo是一个非常简单的工具类,它用于封装两个方块之间的连接信息—其实就是封装一个ListList里保存了连接线需要经过的点。

    在实现LinkInfo对象之前,先来分析两个方块可以相连的情形。连连看游戏的规则约定:两个方块之间最多只能用3条线段相连,也就是说最多只能有2个“拐点”,加上两个方块的中心,方块的连接信息最多只需要4个连接点。图18.5显示了允许出现的连接情况。

    考虑到LinkInfo最多需要封装4个连接点,最少需要封装2个连接点,因此程序定义如下LinkInfo类。

    程序清单:codes\18\Link\src\org\crazyit\link\object\LinkInfo.java

    public class LinkInfo

    {

         // 创建一个集合用于保存连接点

         private List<Point> points = new ArrayList<Point>();

         // 提供第一个构造器, 表示两个Point可以直接相连, 没有转折点

         public LinkInfo(Point p1, Point p2)

         {

              // 加到集合中去

              points.add(p1);

              points.add(p2);

         }

         // 提供第二个构造器, 表示三个Point可以相连, p2p1p3之间的转折点

         public LinkInfo(Point p1, Point p2, Point p3)

         {

              points.add(p1);

              points.add(p2);

              points.add(p3);

         }

         // 提供第三个构造器, 表示四个Point可以相连, p2, p3p1p4的转折点

         public LinkInfo(Point p1, Point p2, Point p3, Point p4)

         {

              points.add(p1);

              points.add(p2);

              points.add(p3);

              points.add(p4);

         }

         // 返回连接集合

         public List<Point> getLinkPoints()

         {

              return points;

         }

    }

    LinkInfo中所用的Point代表一个点,程序直接使用了android.graphics.Point类,每个Point封装了该点的XY坐标。

     

    本文节选自《疯狂Android讲义(CD光盘1)》一书。

    图书详细信息:http://www.cnblogs.com/broadview/archive/2011/07/15/2107603.html

  • 相关阅读:
    大内密探HMM(转)
    广义线性模型(logistic和softmax)
    百度首席科学家 Andrew Ng谈深度学习的挑战和未来(转载)
    推荐系统中的SVD
    Leveldb源码解析之Bloom Filter
    redis源码解析之事件驱动
    I/O多路复用机制:epoll
    redis源码解析之内存管理
    Redis源码解析之ziplist
    redis源码解析之dict数据结构
  • 原文地址:https://www.cnblogs.com/broadview/p/2107628.html
Copyright © 2011-2022 走看看