feat(image): DownsampledKFImage 추가 및 캐릭터/배너에 공통 적용
- KFImage 공통 옵션(다운샘플링, scaleFactor, backgroundDecode, cancelOnDisappear, retry) 캡슐화한 DownsampledKFImage 추가 - 채팅-캐릭터 탭 Character/Recent/배너 뷰에서 인라인 KFImage 제거 → 공통 뷰 적용 - 수평 리스트 HStack → LazyHStack으로 교체해 프리로딩/메모리 개선 Why: 대형 원본 디코딩으로 인한 메모리 스파이크 완화 및 일관된 이미지 로딩 정책 적용. 유지보수성 및 성능 향상.
This commit is contained in:
		
							
								
								
									
										45
									
								
								SodaLive/Sources/CustomView/DownsampledKFImage.swift
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								SodaLive/Sources/CustomView/DownsampledKFImage.swift
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,45 @@
 | 
			
		||||
//
 | 
			
		||||
//  DownsampledKFImage.swift
 | 
			
		||||
//  SodaLive
 | 
			
		||||
//
 | 
			
		||||
//  Created by klaus on 10/23/25.
 | 
			
		||||
//
 | 
			
		||||
 | 
			
		||||
import SwiftUI
 | 
			
		||||
import Kingfisher
 | 
			
		||||
 | 
			
		||||
struct DownsampledKFImage: View {
 | 
			
		||||
    let url: URL?
 | 
			
		||||
    let size: CGSize
 | 
			
		||||
    let cacheOriginal: Bool = false
 | 
			
		||||
    
 | 
			
		||||
    var body: some View {
 | 
			
		||||
        KFImage(url)
 | 
			
		||||
            .placeholder { Color.gray.opacity(0.2) }
 | 
			
		||||
            .retry(maxCount: 2, interval: .seconds(1))
 | 
			
		||||
            .cancelOnDisappear(true)
 | 
			
		||||
            .downsampled(to: size, cacheOriginal: cacheOriginal)
 | 
			
		||||
            .resizable()
 | 
			
		||||
            .scaledToFill()
 | 
			
		||||
            .frame(width: size.width, height: size.height)
 | 
			
		||||
            .clipped()
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
extension KFImage {
 | 
			
		||||
    func downsampled(
 | 
			
		||||
        to targetSize: CGSize,
 | 
			
		||||
        scale: CGFloat = UIScreen.main.scale,
 | 
			
		||||
        cacheOriginal: Bool = false
 | 
			
		||||
    ) -> KFImage {
 | 
			
		||||
        let pixel = CGSize(
 | 
			
		||||
            width: targetSize.width * scale,
 | 
			
		||||
            height: targetSize.height * scale
 | 
			
		||||
        )
 | 
			
		||||
        return self
 | 
			
		||||
            .setProcessor(DownsamplingImageProcessor(size: pixel))
 | 
			
		||||
            .scaleFactor(scale)
 | 
			
		||||
            .backgroundDecode()
 | 
			
		||||
            .cacheOriginalImage(cacheOriginal)
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user