矩阵缩放和投影

缩放在目前代码只有3D的,2D自己想想(╯▽╰)吧

投影矩阵公式: 3D

wps65B.tmp

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication6
{
    class Matrix3x3 
    {
        public double m11, m12, m13;
        public double m21, m22, m23;
        public double m31, m32, m33;


        #region 缩放
        public static Matrix3x3 setUpScale(float Kx, float Ky, float Kz)
        {
            Matrix3x3 m = new Matrix3x3();
            m.m11 = Kx; m.m12 = 0; m.m13 = 0;
            m.m11 = 0; m.m12 = Ky; m.m13 = 0;
            m.m11 = 0; m.m12 = 0; m.m13 = Kz;
            return m;
        }

        public static Matrix3x3 setUpScale(Vector3 v)
        {
            Matrix3x3 m = new Matrix3x3();
            m.m11 = v.x; m.m12 = 0; m.m13 = 0;
            m.m11 = 0; m.m12 = v.y; m.m13 = 0;
            m.m11 = 0; m.m12 = 0; m.m13 = v.z;
            return m;
        }
        #endregion

        #region 正交投影

        /// <summary>
        /// 投影到xy,xz,yz其中一个平面
        /// </summary>
        /// <param name="axis">1=xy,2=xz,3=yz</param>
        public void setUpProject(int axis) 
        {
            switch (axis)
            {
                case 1:
                    //xy平面
                       m11 = 1; m12 = 0; m13 =0;
                    m21 = 0; m22 = 1; m23 =0;
                    m31 = 0; m32 = 0; m33 =0;
                    break;
                case 2:
                    //xz平面
                        m11 = 1; m12 = 0; m13 =0;
                    m21 = 0; m22 = 0; m23 =0;
                    m31 = 0; m32 = 0; m33 =1;
                    break;
                case 3:
                    //yz平面
                       m11 = 0; m12 = 0; m13 =0;
                    m21 = 0; m22 = 1; m23 =0;
                    m31 = 0; m32 = 0; m33 =1;
                    break;
            }
        }

        //投影到任意一个平面
        public void setUpProject(Vector3 v) 
        {
            m11 = 1 - v.x * v.x;
            m22 = 1 - v.y * v.y;
            m33 = 1 - v.z * v.z;

            m12 = m21 = -v.x * v.y;
            m13 = m31 = -v.x * v.z;
            m23 = m32 = -v.y * v.z;
        }
        #endregion
    }

    class Vector3 
    {
        public double x, y, z;

        public Vector3(double x, double y, double z) 
        {
            this.x = x;
            this.y = y;
            this.z = z;
        }

        public override string ToString()
        {
            return string.Format("{0} {1} {2}", x, y, z);
        }
    }
                                                                
}

转载于:https://www.cnblogs.com/plateFace/p/4458527.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值