KIKI... 2022-11-24 17:20 采纳率: 83.3%
浏览 3
已结题

关于#c##的问题:我想知道怎么才能返回resultP的值,然后这个值是有resultP.x和resultP.y的现在运行是返回空值

我想知道怎么才能返回resultP的值,然后这个值是有resultP.x和resultP.y的
现在运行是返回空值

namespace ConsoleApp2
{
    class Point
    {
        public double x;
        public double y;
    }
}
namespace ConsoleApp2
{
    class QFJH:AbstractCalculation
    {
        public override Point Crosscal(Point pa, Point pb, double a, double b)
        {
            Point resultP= new Point();
            resultP.x = (pa.x * (1 / Math.Tan(b)) + pb.x * Math.Tan(a) - pa.y + pb.y) / ((1 / Math.Tan(a) + (1 / Math.Tan(b))));
            resultP.y = (pa.y * (1 / Math.Tan(b)) + pb.y * Math.Tan(a) + pa.x - pb.x) / ((1 / Math.Tan(a) + (1 / Math.Tan(b))));
            
            return resultP;
        }
    }
}

调用代码

           Point paa= new Point();
            paa.x = 1.0;
            paa.y = 1.0;
            Point pbb=new Point();
            pbb.x = 5.5;
            pbb.y = 6.6;
            double aa = 45;
            double bb = 63;
            Point resultPP = new Point();
            //角度前方交会计算
            AbstractCalculation ac = new QFJH();
            resultPP=ac.Crosscal(paa,pbb,aa,bb);

  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2022-11-24 18:16
    关注

    没问题啊,完整代码是什么

    using System;
    namespace ConsoleApp2
    {
        class Point
        {
            public double x;
            public double y;
        }
        class AbstractCalculation
        {
            public virtual Point Crosscal(Point pa, Point pb, double a, double b)
            {
                throw new Exception("TODO");
            }
        }
        class QFJH : AbstractCalculation
        {
            public override Point Crosscal(Point pa, Point pb, double a, double b)
            {
                Point resultP = new Point();
                resultP.x = (pa.x * (1 / Math.Tan(b)) + pb.x * Math.Tan(a) - pa.y + pb.y) / ((1 / Math.Tan(a) + (1 / Math.Tan(b))));
                resultP.y = (pa.y * (1 / Math.Tan(b)) + pb.y * Math.Tan(a) + pa.x - pb.x) / ((1 / Math.Tan(a) + (1 / Math.Tan(b))));
    
                return resultP;
            }
        }
        class Program
        {
            static void Main(string[] args)
            {
                Point paa = new Point();
                paa.x = 1.0;
                paa.y = 1.0;
                Point pbb = new Point();
                pbb.x = 5.5;
                pbb.y = 6.6;
                double aa = 45;
                double bb = 63;
                Point resultPP = new Point();
                //角度前方交会计算
                AbstractCalculation ac = new QFJH();
                resultPP = ac.Crosscal(paa, pbb, aa, bb);
    
                Console.WriteLine($"x:{resultPP.x} x:{resultPP.y}");
                Console.ReadKey();
            }
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月2日
  • 已采纳回答 11月24日
  • 修改了问题 11月24日
  • 创建了问题 11月24日

悬赏问题

  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 正弦信号发生器串并联电路电阻无法保持同步怎么办
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 个人网站被恶意大量访问,怎么办
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM
  • ¥15 划分vlan后不通了
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)