web-dev-qa-db-ja.com

swift)のUIImageViewに* .gifファイルを表示できません

UIImageViewに表示したい* .gifファイルがあります。私はライブラリを試しました FLAnimatedImage 、以下のコード。結果は単なる静止画像です。

class LoginVC: UIViewController, UITextFieldDelegate {

    @IBOutlet weak var img_popup: FLAnimatedImageView!

    var img_popupraw: FLAnimatedImage = FLAnimatedImage(animatedGIFData: NSData(contentsOfFile: "ShitTalk_LoadingAnimation.gif"))

    override func viewDidLoad() {
        img_popup.animatedImage = img_popupraw
    }
}

アニメーションGIFをgifファイルから直接表示する別の方法を開きます。私はSwiftを使用しています。

6
user1406716

SwiftGif を使用することを強くお勧めします。

プロジェクトにGif.Swiftをインポートし、次の手順を実行します。

// Returns an animated UIImage
let jeremyGif = UIImage.gifWithName("jeremy")

// Use the UIImage in your UIImageView
let imageView = UIImageView(image: jeremyGif)
11
Barat Semet

私の場合、アプリ内のすべての画像を管理するためにSDWebImageを使用しています。包括的はsd_animatedGIFNamed func

インストールpod 'SDWebImage'

1
jose920405
//
//  ViewController.Swift
//  Loader
//
//  Created by Pawan Kumar on 28/09/17.
//  Copyright © 2017 Pawan Kumar. All rights reserved.
//

import UIKit
import FLAnimatedImage

class ViewController: UIViewController {

    @IBOutlet weak var animatedImageView: FLAnimatedImageView!
//  @IBOutlet weak var checkImageView: FLAnimatedImageView!
    override func viewDidLoad() {
        super.viewDidLoad()


        let url  = Bundle.main.path(forResource: "Loader", ofType: "gif")
        print(url!)

        let data=NSData(contentsOfFile: url!)
        //print(data)
        let fff=FLAnimatedImage(gifData: data as Data?)
        let imageView=FLAnimatedImageView()
        imageView.animatedImage=fff
//
//        imageView.frame=CGRect(x: animatedImageView.frame.minX, y: animatedImageView.frame.minY, width: animatedImageView.frame.width, height: animatedImageView.frame.height)


         imageView.frame=CGRect(x: animatedImageView.frame.minX, y: animatedImageView.frame.minY, width: animatedImageView.frame.width, height: animatedImageView.frame.height)

        print(imageView.currentFrameIndex)
        imageView.clipsToBounds=true
        self.view.addSubview(imageView)

        // Do any additional setup after loading the view, typically from a nib.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }




}

上記のコードに示すように、ViewControllerを作成します。注:-ストーリーボードで画像ビューを作成するときに、画像ビューのクラスをFLanimatedImageViewとして設定します。

それが動作します。

ここでLoader.gifはGIF画像です。

0
pawan_kumar