当前位置: 首页 > wzjs >正文

哪个网站做婚礼邀请函好个人名片模板

哪个网站做婚礼邀请函好,个人名片模板,衡量网站质量的标准,envato wordpress toolkit目录 原理 效果 步骤 源码 原理 先设置绘制线段的起点和终点,然后我们将起点和终点的高度升高,然后通过插值,在起点和终点之间添加多个点,再由这些点向地心发出射线,这样我们就可以获取到这些点在地表的投影点&…

目录

原理

效果

步骤

源码


原理

        先设置绘制线段的起点和终点,然后我们将起点和终点的高度升高,然后通过插值,在起点和终点之间添加多个点,再由这些点向地心发出射线,这样我们就可以获取到这些点在地表的投影点,最后将投影点连起来就是地表贴合线。

        注意:使用该方法时,需要保证地形加载完毕,因为只要地形加载后地表才会有碰撞信息,才能被射线检测到

效果

步骤

1. 在“xxx.Build.cs”中引入“CesiumRuntime”模块

 2. 新建一个Actor类,这里命名为“SurfaceLineActor”

在“SurfaceLineActor.h”中添加所需头文件

定义一个函数“CalculatePointsOnSurface”用于计算地表点,该函数需要传入起点终点的经纬度、细分点数、起终点向上偏移的距离

再定义一个函数用于绘制地表贴合线,该函数需要传入地表点数组、线的颜色、线的粗细共3个参数。

定义地心坐标、添加一个LineBatchComponent组件用于高效绘制线条、定义一个数组“Points”用于储存起终点之间的点

实现函数“CalculatePointsOnSurface”如下

TArray<FVector> ASurfaceLineActor::CalculatePointsOnSurface(FVector StartPointLLA, FVector EndPointLLA, int32 NumberOfSegments, double TraceUpOffset)
{//将起点和终点拔高一段距离以方便往地心打射线StartPointLLA = StartPointLLA + FVector(0, 0, TraceUpOffset);EndPointLLA = EndPointLLA + FVector(0, 0, TraceUpOffset);//获取GeoreferenceACesiumGeoreference* Georeference = ACesiumGeoreference::GetDefaultGeoreference(GetWorld());if (!Georeference){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: CesiumGeoreference not found. Cannot calculate surface points."));}//将起终点(经纬高)转换为起终点(UE世界坐标)FVector StartPoint = Georeference->TransformLongitudeLatitudeHeightPositionToUnreal(StartPointLLA);FVector EndPoint = Georeference->TransformLongitudeLatitudeHeightPositionToUnreal(EndPointLLA);Points.Empty();if (NumberOfSegments <= 0)  // 分段数不满足要求,返回起点和终点{// 如果段数无效,至少包含起点和终点Points.Add(StartPoint);if (StartPoint != EndPoint) // 避免重复添加同一点{Points.Add(EndPoint);}}else{//Points.Reserve(NumberOfSegments + 1); // 预分配空间提高效率for (int32 i = 0; i < NumberOfSegments; ++i){float T = static_cast<float>(i) / static_cast<float>(NumberOfSegments);FVector CurrentPoint = FMath::Lerp(StartPoint, EndPoint, T);  // 使用 FMath::Lerp 进行线性插值计算点的坐标Points.Add(CurrentPoint);}}// 用于存储射线检测到的地表点TArray<FVector> CalculatedSurfacePoints;//起点和终点构成的连线中每个点都朝地心发出射线for (int32 i = 0; i < Points.Num(); ++i){FHitResult HitResult;FCollisionQueryParams QueryParams;QueryParams.AddIgnoredActor(this);        // 射线检测忽视自身//QueryParams.AddIgnoredActors(ActorsToIgnore); // 忽视射线检测的ActorQueryParams.bTraceComplex = true;         // 使用复杂碰撞QueryParams.bReturnPhysicalMaterial = false; // 是否检测物理材料ECollisionChannel TraceChannel = ECC_Visibility;UWorld* World = GetWorld();bool bHit = World->LineTraceSingleByChannel(HitResult,      // 射线检测结果Points[i],      // 射线起点EarthOrigin,    // 射线终点(地心)TraceChannel,   // 射线碰撞通道QueryParams     // 射线碰撞其他参数);画射线检测(非必需)//DrawDebugLine(//    GetWorld(),//    Points[i],    //起点//    EarthOrigin,  //终点(地心)//    bHit ? FColor::Green : FColor::Red,  //颜色//    false,           // false表示它持续“LifeTime”,如果LifeTime为0,则持续一帧//    0.0,             // DebugLine生命周期时长//    0,               // DepthPriority (0 for SDPG_World)//    2.0f//);if (bHit){画射线碰撞点(非必需)//DrawDebugSphere(//    GetWorld(),//    HitResult.Location,//    30.0f, // Radius//    12,                // Segments//    FColor::Cyan,//    false,             // Persistent lines//    0.0f   // Lifetime//);FVector OutHitLocation = HitResult.ImpactPoint;CalculatedSurfacePoints.Add(OutHitLocation);}}return CalculatedSurfacePoints;
}

3. 测试一下“CalculatePointsOnSurface”函数是否生效,这里设置起点为成都市市中心终点为都江堰

运行后可以看到地表点位置基本准确

4. 接下来只需要通过LineBatchComponent组件将地表点连线即可

函数“DrawSurfaceLine”实现如下

void ASurfaceLineActor::DrawSurfaceLine(TArray<FVector> SurfacePoints, FLinearColor LineColor, float LineThickness)
{if (!LineBatchComponent){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: LineBatchComponent is null."));return;}LineBatchComponent->Flush(); // 清除之前的线if (SurfacePoints.Num() >= 2){for (int32 i = 0; i < SurfacePoints.Num() - 1; ++i){if (SurfacePoints[i].ContainsNaN() || SurfacePoints[i + 1].ContainsNaN()){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: Encountered NaN point at segment %d, skipping draw."), i);continue;}LineBatchComponent->DrawLine(SurfacePoints[i],SurfacePoints[i + 1],LineColor,SDPG_World, // 场景深度优先级组-根据渲染顺序需要进行调整LineThickness,0.0f        // 线的生命周期时长:0表示无限生命);}}
}

再通过蓝图在获取地表点数组后传入函数 “DrawSurfaceLine”

此时效果如下: 

 5. 选取山地进行测试,插值数量设置为200,此时运行效果如下

源码

 “SurfaceLineActor.h”

// Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h"
#include "GameFramework/Actor.h"
#include "Components/LineBatchComponent.h"
#include "CesiumGeoreference.h"
#include "SurfaceLineActor.generated.h"UCLASS()
class GLOBEPAWNTEST_API ASurfaceLineActor : public AActor
{GENERATED_BODY()public:	// Sets default values for this actor's propertiesASurfaceLineActor();// 计算地表点UFUNCTION(BlueprintCallable, Category = "Line Properties")TArray<FVector> CalculatePointsOnSurface(FVector StartPointLLA = FVector(0, 0, 0),FVector EndPointLLA = FVector(0, 0, 0),int32 NumberOfSegments = 50,     // 线段细分数 (越高质量越好,但性能开销越大)double TraceUpOffset = 100000.0  // 射线检测时向上偏移的距离(确保起点在潜在地形之上)  默认100km);// 调用此函数来绘制或更新地表贴合线UFUNCTION(BlueprintCallable, Category = "Line Properties")void DrawSurfaceLine(TArray<FVector> SurfacePoints,FLinearColor LineColor = FLinearColor::Red, // 线的颜色float LineThickness = 10.0f    // 线的粗细);//地心坐标UPROPERTY(EditAnywhere, BlueprintReadWrite)FVector EarthOrigin = FVector(0, 0, -637810000.0);protected:// Called when the game starts or when spawnedvirtual void BeginPlay() override;UPROPERTY(VisibleAnywhere, BlueprintReadOnly)ULineBatchComponent* LineBatchComponent;public:	// Called every framevirtual void Tick(float DeltaTime) override;private:TArray<FVector> Points;  //用于存储起点和终点连线之间的点
};

 “SurfaceLineActor.cpp”

// Fill out your copyright notice in the Description page of Project Settings.#include "SurfaceLineActor.h"
#include "CesiumRuntime/Public/CesiumGeoreference.h"// Sets default values
ASurfaceLineActor::ASurfaceLineActor()
{// Set this actor to call Tick() every frame.  You can turn this off to improve performance if you don't need it.PrimaryActorTick.bCanEverTick = true;PrimaryActorTick.bStartWithTickEnabled = true;LineBatchComponent = CreateDefaultSubobject<ULineBatchComponent>(TEXT("LineBatcher"));// 可以将 LineBatchComponent 设为根组件,或者附加到其他组件上RootComponent = LineBatchComponent;LineBatchComponent->bCalculateAccurateBounds = false; // Optimization for dynamic lines}// Called when the game starts or when spawned
void ASurfaceLineActor::BeginPlay()
{Super::BeginPlay();}// Called every frame
void ASurfaceLineActor::Tick(float DeltaTime)
{Super::Tick(DeltaTime);}void ASurfaceLineActor::DrawSurfaceLine(TArray<FVector> SurfacePoints, FLinearColor LineColor, float LineThickness)
{if (!LineBatchComponent){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: LineBatchComponent is null."));return;}LineBatchComponent->Flush(); // 清除之前的线if (SurfacePoints.Num() >= 2){for (int32 i = 0; i < SurfacePoints.Num() - 1; ++i){if (SurfacePoints[i].ContainsNaN() || SurfacePoints[i + 1].ContainsNaN()){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: Encountered NaN point at segment %d, skipping draw."), i);continue;}LineBatchComponent->DrawLine(SurfacePoints[i],SurfacePoints[i + 1],LineColor,SDPG_World, // 场景深度优先级组-根据渲染顺序需要进行调整LineThickness,0.0f        // 线的生命周期时长:0表示无限生命);}}
}TArray<FVector> ASurfaceLineActor::CalculatePointsOnSurface(FVector StartPointLLA, FVector EndPointLLA, int32 NumberOfSegments, double TraceUpOffset)
{//将起点和终点拔高一段距离以方便往地心打射线StartPointLLA = StartPointLLA + FVector(0, 0, TraceUpOffset);EndPointLLA = EndPointLLA + FVector(0, 0, TraceUpOffset);//获取GeoreferenceACesiumGeoreference* Georeference = ACesiumGeoreference::GetDefaultGeoreference(GetWorld());if (!Georeference){UE_LOG(LogTemp, Warning, TEXT("SurfaceLineActor: CesiumGeoreference not found. Cannot calculate surface points."));}//将起终点(经纬高)转换为起终点(UE世界坐标)FVector StartPoint = Georeference->TransformLongitudeLatitudeHeightPositionToUnreal(StartPointLLA);FVector EndPoint = Georeference->TransformLongitudeLatitudeHeightPositionToUnreal(EndPointLLA);Points.Empty();if (NumberOfSegments <= 0)  // 分段数不满足要求,返回起点和终点{// 如果段数无效,至少包含起点和终点Points.Add(StartPoint);if (StartPoint != EndPoint) // 避免重复添加同一点{Points.Add(EndPoint);}}else{//Points.Reserve(NumberOfSegments + 1); // 预分配空间提高效率for (int32 i = 0; i < NumberOfSegments; ++i){float T = static_cast<float>(i) / static_cast<float>(NumberOfSegments);FVector CurrentPoint = FMath::Lerp(StartPoint, EndPoint, T);  // 使用 FMath::Lerp 进行线性插值计算点的坐标Points.Add(CurrentPoint);}Points.Add(EndPoint);  //需要加上终点}// 用于存储射线检测到的地表点TArray<FVector> CalculatedSurfacePoints;//起点和终点构成的连线中每个点都朝地心发出射线for (int32 i = 0; i < Points.Num(); ++i){FHitResult HitResult;FCollisionQueryParams QueryParams;QueryParams.AddIgnoredActor(this);        // 射线检测忽视自身//QueryParams.AddIgnoredActors(ActorsToIgnore); // 忽视射线检测的ActorQueryParams.bTraceComplex = true;         // 使用复杂碰撞QueryParams.bReturnPhysicalMaterial = false; // 是否检测物理材料ECollisionChannel TraceChannel = ECC_Visibility;UWorld* World = GetWorld();bool bHit = World->LineTraceSingleByChannel(HitResult,      // 射线检测结果Points[i],      // 射线起点EarthOrigin,    // 射线终点(地心)TraceChannel,   // 射线碰撞通道QueryParams     // 射线碰撞其他参数);画射线检测(非必需)//DrawDebugLine(//    GetWorld(),//    Points[i],    //起点//    EarthOrigin,  //终点(地心)//    bHit ? FColor::Green : FColor::Red,  //颜色//    false,           // false表示它持续“LifeTime”,如果LifeTime为0,则持续一帧//    0.0,             // DebugLine生命周期时长//    0,               // DepthPriority (0 for SDPG_World)//    2.0f//);if (bHit){画射线碰撞点(非必需)//DrawDebugSphere(//    GetWorld(),//    HitResult.Location,//    30.0f, // Radius//    12,                // Segments//    FColor::Cyan,//    false,             // Persistent lines//    0.0f   // Lifetime//);FVector OutHitLocation = HitResult.ImpactPoint;CalculatedSurfacePoints.Add(OutHitLocation);}}return CalculatedSurfacePoints;
}

文章转载自:

http://Fv7XP3ap.Lynkz.cn
http://vlAJRy5b.Lynkz.cn
http://hT7hCuDg.Lynkz.cn
http://dFLAXBPR.Lynkz.cn
http://SoLtaFIA.Lynkz.cn
http://55wcfwsf.Lynkz.cn
http://R9TxFReX.Lynkz.cn
http://g3YGYpqf.Lynkz.cn
http://94kmAMfn.Lynkz.cn
http://AL8WVYIl.Lynkz.cn
http://Yn3owCfU.Lynkz.cn
http://t6tMnZdl.Lynkz.cn
http://ZM6r5R57.Lynkz.cn
http://mtrpAwq9.Lynkz.cn
http://u7j7YdLb.Lynkz.cn
http://hVjlYUrn.Lynkz.cn
http://pq0wjejJ.Lynkz.cn
http://aOQYuW3Z.Lynkz.cn
http://hKTtCFDD.Lynkz.cn
http://XQMK2zmS.Lynkz.cn
http://MuqFXzOV.Lynkz.cn
http://jmDoW2Br.Lynkz.cn
http://LD66wRci.Lynkz.cn
http://ttEaDjnU.Lynkz.cn
http://M8IPxwAR.Lynkz.cn
http://B310Wjkm.Lynkz.cn
http://FOcOJtP6.Lynkz.cn
http://eQV8w5Ym.Lynkz.cn
http://yPZo3PHR.Lynkz.cn
http://K0SetrlK.Lynkz.cn
http://www.dtcms.com/wzjs/670372.html

相关文章:

  • 自贡市规划建设局网站室内设计是什么
  • 网站建设什么专业开封seo公司
  • 上海网站搜索排名团购网站为什么做不走
  • 博州住房和城乡建设局网站杏坛网站建设
  • 上海自助建站 上海网站建设深圳企业公司网站建设平台
  • 那些网站专门做棋牌推广的燃气公司网站建设方案
  • 在centos做网站注册公司该怎么注册
  • 长沙建立网站网网站制作
  • 淄博阿雷网站建设游戏平台十大排名
  • 好看的企业网站模板小程序可视化开发工具
  • 有域名做网站廊坊企业网站服务
  • 提供网站制作价格权威发布的图片
  • 策划的网站网站建设方案 文库
  • 网站推广官方平台品牌设计得公司
  • 如何宣传网站旅游开发公司网站建设方案书
  • 网站开发所涉及的技术公司管理系统软件有哪些
  • 预付做网站订金怎么做账做自己的网站的一般步骤
  • aspnet做网站视频教程网站建设所需人力
  • 加强政务门户网站建设零基础网站建设教程
  • 网站建设安全技术网站优化建设上海
  • 江苏省住房和城乡建设部网站wordpress怎么在上面建几个分类
  • 工作室 网站经营性备案徐州市经济技术开发区建设局网站
  • 陕西网站建设设计wordpress中图片幻灯展示效果
  • dedecms 英文网站深圳龙岗做网站的
  • 如何建网站平台上海如何做网站
  • 做网站需要用什么系统网站做代理服务器
  • 天津大良网站建设平台兼职网站开发
  • 网站和域名花卉网站源码
  • 漫画网站建设上海互联网公司有哪些
  • 创建一个网站 站点根文件夹为php网站开发电子书