Diff
checker
텍스트
텍스트
이미지
문서
Excel
폴더
Legal
Enterprise
데스크톱
요금제
로그인
데스크톱 앱 다운로드
텍스트 비교
두 텍스트 파일의 차이점을 찾아보세요
도구
기록
실시간 편집
변경 없는 행 숨기기
줄바꿈 비활성화
레이아웃
나란히 보기
합쳐 보기
비교 단위
스마트
단어
글자
구문 강조
언어 선택
제외
텍스트 변환
첫 변경으로
수정
Diffchecker Desktop
가장 안전하게 Diffchecker를 사용하는 방법. 데스크톱 앱을 사용하면 비교 데이터가 외부로 전송되지 않습니다!
데스크톱 앱 받기
Subdivision Step Sampler diff 5.8 / 5.7
생성일
19시간 전
비교 결과 만료 없음
초기화
내보내기
공유
설명
0 삭제
행
총
삭제
글자
총
삭제
이 기능을 계속 사용하려면 업그레이드해 주세요
Diff
checker
Pro
요금제 보기
87 행
복사
3 추가
행
총
추가
글자
총
추가
이 기능을 계속 사용하려면 업그레이드해 주세요
Diff
checker
Pro
요금제 보기
87 행
복사
virtual void Step(FSamplerResult& OutResult) override
virtual void Step(FSamplerResult& OutResult) override
{
{
const int PreviousSegmentIndex = (CurrentSegmentIndex > 0 ? CurrentSegmentIndex : NumSegments) - 1;
const int PreviousSegmentIndex = (CurrentSegmentIndex > 0 ? CurrentSegmentIndex : NumSegments) - 1;
// To capture the last key point on the spline, we sample the point at the end of the previous segment.
// To capture the last key point on the spline, we sample the point at the end of the previous segment.
const bool bLastKeyPoint = CurrentSegmentIndex == LineData->GetNumSegments();
const bool bLastKeyPoint = CurrentSegmentIndex == LineData->GetNumSegments();
const int SegmentIndex = bLastKeyPoint ? PreviousSegmentIndex : CurrentSegmentIndex;
const int SegmentIndex = bLastKeyPoint ? PreviousSegmentIndex : CurrentSegmentIndex;
const FVector::FReal SegmentLength = LineData->GetSegmentLength(SegmentIndex);
const FVector::FReal SegmentLength = LineData->GetSegmentLength(SegmentIndex);
const FVector::FReal SegmentStep = SegmentLength / (SubdivisionsPerSegment + 1);
const FVector::FReal SegmentStep = SegmentLength / (SubdivisionsPerSegment + 1);
const FVector::FReal DistanceAlongSegment = bLastKeyPoint ? SegmentLength : SubpointIndex * SegmentStep;
const FVector::FReal DistanceAlongSegment = bLastKeyPoint ? SegmentLength : SubpointIndex * SegmentStep;
FBox& OutBox = OutResult.Box;
FBox& OutBox = OutResult.Box;
FTransform& OutTransform = OutResult.LocalTransform;
FTransform& OutTransform = OutResult.LocalTransform;
OutTransform = LineData->GetTransformAtDistance(SegmentIndex, DistanceAlongSegment, /*bWorldSpace=*/false, &OutBox);
OutTransform = LineData->GetTransformAtDistance(SegmentIndex, DistanceAlongSegment, /*bWorldSpace=*/false, &OutBox);
OutResult.SampleIndex = SampleIndex++;
OutResult.SampleIndex = SampleIndex++;
OutResult.SegmentIndex = LineData->IsClosed() ? CurrentSegmentIndex : SegmentIndex;
OutResult.SegmentIndex = LineData->IsClosed() ? CurrentSegmentIndex : SegmentIndex;
OutResult.SubsegmentIndex = SubpointIndex;
OutResult.SubsegmentIndex = SubpointIndex;
OutResult.InputKey = LineData->GetInputKeyAtDistance(SegmentIndex, DistanceAlongSegment);
OutResult.InputKey = LineData->GetInputKeyAtDistance(SegmentIndex, DistanceAlongSegment);
if (bComputeCurvature)
if (bComputeCurvature)
{
{
OutResult.Curvature = LineData->GetCurvatureAtDistance(SegmentIndex, DistanceAlongSegment);
OutResult.Curvature = LineData->GetCurvatureAtDistance(SegmentIndex, DistanceAlongSegment);
}
}
if (bComputeTangents)
if (bComputeTangents)
{
{
// Control points have actual Arrive and Leave tangents
// Control points have actual Arrive and Leave tangents
if (SubpointIndex == 0)
if (SubpointIndex == 0)
{
{
LineData->GetTangentsAtSegmentStart(CurrentSegmentIndex, OutResult.ArriveTangent, OutResult.LeaveTangent);
LineData->GetTangentsAtSegmentStart(CurrentSegmentIndex, OutResult.ArriveTangent, OutResult.LeaveTangent);
}
}
else
else
{
{
// For a non-control-point, we can get the normalized tangent at least.
// For a non-control-point, we can get the normalized tangent at least.
const FVector Forward = OutTransform.GetRotation().GetForwardVector();
const FVector Forward = OutTransform.GetRotation().GetForwardVector();
OutResult.ArriveTangent = Forward;
OutResult.ArriveTangent = Forward;
OutResult.LeaveTangent = Forward;
OutResult.LeaveTangent = Forward;
}
}
}
}
if (bComputeAlpha)
if (bComputeAlpha)
{
{
OutResult.Alpha = LineData->GetAlphaAtDistance(SegmentIndex, DistanceAlongSegment);
OutResult.Alpha = LineData->GetAlphaAtDistance(SegmentIndex, DistanceAlongSegment);
}
}
if (bComputeDistance)
if (bComputeDistance)
{
{
// When we step onto a new segment, add the length of the previous segment onto the distance to our current segment.
// When we step onto a new segment, add the length of the previous segment onto the distance to our current segment.
if (SegmentIndex > 0 && !bLastKeyPoint && SubpointIndex == 0)
if (SegmentIndex > 0 && !bLastKeyPoint && SubpointIndex == 0)
{
{
DistanceToCurrentSegment += LineData->GetSegmentLength(SegmentIndex - 1);
DistanceToCurrentSegment += LineData->GetSegmentLength(SegmentIndex - 1);
}
}
OutResult.Distance = DistanceToCurrentSegment + DistanceAlongSegment;
OutResult.Distance = DistanceToCurrentSegment + DistanceAlongSegment;
}
}
const double ScaleFactor = 0.5 * SegmentStep / (FMath::IsNearlyZero(OutTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : OutTransform.GetScale3D().X);
const double ScaleFactor = 0.5 * SegmentStep / (FMath::IsNearlyZero(OutTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : OutTransform.GetScale3D().X);
if (SubpointIndex == 0)
if (SubpointIndex == 0)
{
{
const FVector::FReal PreviousSegmentLength = LineData->GetSegmentLength(PreviousSegmentIndex);
const FVector::FReal PreviousSegmentLength = LineData->GetSegmentLength(PreviousSegmentIndex);
FTransform PreviousSegmentEndTransform = LineData->GetTransformAtDistance(PreviousSegmentIndex, PreviousSegmentLength, /*bWorldSpace=*/false);
FTransform PreviousSegmentEndTransform = LineData->GetTransformAtDistance(PreviousSegmentIndex, PreviousSegmentLength, /*bWorldSpace=*/false);
if ((PreviousSegmentEndTransform.GetLocation() - OutTransform.GetLocation()).Length() <= KINDA_SMALL_NUMBER)
if ((PreviousSegmentEndTransform.GetLocation() - OutTransform.GetLocation()).Length() <= KINDA_SMALL_NUMBER)
{
{
OutBox.Min.X *= 0.5 * PreviousSegmentLength / ((FMath::IsNearlyZero(PreviousSegmentEndTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : PreviousSegmentEndTransform.GetScale3D().X) * (SubdivisionsPerSegment + 1));
OutBox.Min.X *= 0.5 * PreviousSegmentLength / ((FMath::IsNearlyZero(PreviousSegmentEndTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : PreviousSegmentEndTransform.GetScale3D().X) * (SubdivisionsPerSegment + 1));
}
}
else
else
{
{
복사
복사됨
복사
복사됨
OutBox.Min.X *=
ScaleFactor;
OutBox.Min.X *=
0.5 * SegmentStep /
ScaleFactor;
}
}
}
}
else
else
{
{
복사
복사됨
복사
복사됨
OutBox.Min.X *=
ScaleFactor;
OutBox.Min.X *=
0.5 * SegmentStep /
ScaleFactor;
}
}
복사
복사됨
복사
복사됨
OutBox.Max.X *=
ScaleFactor;
OutBox.Max.X *=
0.5 * SegmentStep /
ScaleFactor;
++SubpointIndex;
++SubpointIndex;
if (SubpointIndex > SubdivisionsPerSegment || bLastKeyPoint)
if (SubpointIndex > SubdivisionsPerSegment || bLastKeyPoint)
{
{
SubpointIndex = 0;
SubpointIndex = 0;
++CurrentSegmentIndex;
++CurrentSegmentIndex;
}
}
}
}
저장된 비교 결과
원본
파일 열기
virtual void Step(FSamplerResult& OutResult) override { const int PreviousSegmentIndex = (CurrentSegmentIndex > 0 ? CurrentSegmentIndex : NumSegments) - 1; // To capture the last key point on the spline, we sample the point at the end of the previous segment. const bool bLastKeyPoint = CurrentSegmentIndex == LineData->GetNumSegments(); const int SegmentIndex = bLastKeyPoint ? PreviousSegmentIndex : CurrentSegmentIndex; const FVector::FReal SegmentLength = LineData->GetSegmentLength(SegmentIndex); const FVector::FReal SegmentStep = SegmentLength / (SubdivisionsPerSegment + 1); const FVector::FReal DistanceAlongSegment = bLastKeyPoint ? SegmentLength : SubpointIndex * SegmentStep; FBox& OutBox = OutResult.Box; FTransform& OutTransform = OutResult.LocalTransform; OutTransform = LineData->GetTransformAtDistance(SegmentIndex, DistanceAlongSegment, /*bWorldSpace=*/false, &OutBox); OutResult.SampleIndex = SampleIndex++; OutResult.SegmentIndex = LineData->IsClosed() ? CurrentSegmentIndex : SegmentIndex; OutResult.SubsegmentIndex = SubpointIndex; OutResult.InputKey = LineData->GetInputKeyAtDistance(SegmentIndex, DistanceAlongSegment); if (bComputeCurvature) { OutResult.Curvature = LineData->GetCurvatureAtDistance(SegmentIndex, DistanceAlongSegment); } if (bComputeTangents) { // Control points have actual Arrive and Leave tangents if (SubpointIndex == 0) { LineData->GetTangentsAtSegmentStart(CurrentSegmentIndex, OutResult.ArriveTangent, OutResult.LeaveTangent); } else { // For a non-control-point, we can get the normalized tangent at least. const FVector Forward = OutTransform.GetRotation().GetForwardVector(); OutResult.ArriveTangent = Forward; OutResult.LeaveTangent = Forward; } } if (bComputeAlpha) { OutResult.Alpha = LineData->GetAlphaAtDistance(SegmentIndex, DistanceAlongSegment); } if (bComputeDistance) { // When we step onto a new segment, add the length of the previous segment onto the distance to our current segment. if (SegmentIndex > 0 && !bLastKeyPoint && SubpointIndex == 0) { DistanceToCurrentSegment += LineData->GetSegmentLength(SegmentIndex - 1); } OutResult.Distance = DistanceToCurrentSegment + DistanceAlongSegment; } const double ScaleFactor = 0.5 * SegmentStep / (FMath::IsNearlyZero(OutTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : OutTransform.GetScale3D().X); if (SubpointIndex == 0) { const FVector::FReal PreviousSegmentLength = LineData->GetSegmentLength(PreviousSegmentIndex); FTransform PreviousSegmentEndTransform = LineData->GetTransformAtDistance(PreviousSegmentIndex, PreviousSegmentLength, /*bWorldSpace=*/false); if ((PreviousSegmentEndTransform.GetLocation() - OutTransform.GetLocation()).Length() <= KINDA_SMALL_NUMBER) { OutBox.Min.X *= 0.5 * PreviousSegmentLength / ((FMath::IsNearlyZero(PreviousSegmentEndTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : PreviousSegmentEndTransform.GetScale3D().X) * (SubdivisionsPerSegment + 1)); } else { OutBox.Min.X *= ScaleFactor; } } else { OutBox.Min.X *= ScaleFactor; } OutBox.Max.X *= ScaleFactor; ++SubpointIndex; if (SubpointIndex > SubdivisionsPerSegment || bLastKeyPoint) { SubpointIndex = 0; ++CurrentSegmentIndex; } }
수정본
파일 열기
virtual void Step(FSamplerResult& OutResult) override { const int PreviousSegmentIndex = (CurrentSegmentIndex > 0 ? CurrentSegmentIndex : NumSegments) - 1; // To capture the last key point on the spline, we sample the point at the end of the previous segment. const bool bLastKeyPoint = CurrentSegmentIndex == LineData->GetNumSegments(); const int SegmentIndex = bLastKeyPoint ? PreviousSegmentIndex : CurrentSegmentIndex; const FVector::FReal SegmentLength = LineData->GetSegmentLength(SegmentIndex); const FVector::FReal SegmentStep = SegmentLength / (SubdivisionsPerSegment + 1); const FVector::FReal DistanceAlongSegment = bLastKeyPoint ? SegmentLength : SubpointIndex * SegmentStep; FBox& OutBox = OutResult.Box; FTransform& OutTransform = OutResult.LocalTransform; OutTransform = LineData->GetTransformAtDistance(SegmentIndex, DistanceAlongSegment, /*bWorldSpace=*/false, &OutBox); OutResult.SampleIndex = SampleIndex++; OutResult.SegmentIndex = LineData->IsClosed() ? CurrentSegmentIndex : SegmentIndex; OutResult.SubsegmentIndex = SubpointIndex; OutResult.InputKey = LineData->GetInputKeyAtDistance(SegmentIndex, DistanceAlongSegment); if (bComputeCurvature) { OutResult.Curvature = LineData->GetCurvatureAtDistance(SegmentIndex, DistanceAlongSegment); } if (bComputeTangents) { // Control points have actual Arrive and Leave tangents if (SubpointIndex == 0) { LineData->GetTangentsAtSegmentStart(CurrentSegmentIndex, OutResult.ArriveTangent, OutResult.LeaveTangent); } else { // For a non-control-point, we can get the normalized tangent at least. const FVector Forward = OutTransform.GetRotation().GetForwardVector(); OutResult.ArriveTangent = Forward; OutResult.LeaveTangent = Forward; } } if (bComputeAlpha) { OutResult.Alpha = LineData->GetAlphaAtDistance(SegmentIndex, DistanceAlongSegment); } if (bComputeDistance) { // When we step onto a new segment, add the length of the previous segment onto the distance to our current segment. if (SegmentIndex > 0 && !bLastKeyPoint && SubpointIndex == 0) { DistanceToCurrentSegment += LineData->GetSegmentLength(SegmentIndex - 1); } OutResult.Distance = DistanceToCurrentSegment + DistanceAlongSegment; } const double ScaleFactor = 0.5 * SegmentStep / (FMath::IsNearlyZero(OutTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : OutTransform.GetScale3D().X); if (SubpointIndex == 0) { const FVector::FReal PreviousSegmentLength = LineData->GetSegmentLength(PreviousSegmentIndex); FTransform PreviousSegmentEndTransform = LineData->GetTransformAtDistance(PreviousSegmentIndex, PreviousSegmentLength, /*bWorldSpace=*/false); if ((PreviousSegmentEndTransform.GetLocation() - OutTransform.GetLocation()).Length() <= KINDA_SMALL_NUMBER) { OutBox.Min.X *= 0.5 * PreviousSegmentLength / ((FMath::IsNearlyZero(PreviousSegmentEndTransform.GetScale3D().X) ? UE_DOUBLE_SMALL_NUMBER : PreviousSegmentEndTransform.GetScale3D().X) * (SubdivisionsPerSegment + 1)); } else { OutBox.Min.X *= 0.5 * SegmentStep / ScaleFactor; } } else { OutBox.Min.X *= 0.5 * SegmentStep / ScaleFactor; } OutBox.Max.X *= 0.5 * SegmentStep / ScaleFactor; ++SubpointIndex; if (SubpointIndex > SubdivisionsPerSegment || bLastKeyPoint) { SubpointIndex = 0; ++CurrentSegmentIndex; } }
비교하기