質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

0回答

2073閲覧

XIBで作成したViewをUIScrollViewで利用する

_CHO

総合スコア16

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2017/07/09 13:24

CardView.xibというXIBファイルを作成し、そこでカードを表示する再利用可能なデザインパーツを作成しました。
このカードデザインを複数枚使って、UIScrollViewに並べてスクロール表示できるようにしたいと考えています。
UIScrollViewとしては、以下リンクのような使い方を考えています。

UIScrollViewで横スクロールのページングを実装する

このリンクの画像を、自作したカードデザインUIに置き換えるような感じです。
違う点としては、このリンク先では固定の画像データを事前に読み込んでいますが、今回のカードに表示するデータはサーバーから引っ張ってくるため、動的に枚数が変わることになります。

どのように作ればよいでしょうか?
アドバイスを頂けますと幸いです。

XIBファイルの作成と、UIScrollViewのStoryboardへの配置は行ったのですが、CardViewをUIScrollViewのaddViewしようとしても上手くできませんでした。

現状としては、以下のような感じです。
ScrollViewを含んだUIと紐付いたViewControllerがCardViewインスタンスを作成すると同時に、CardView.swiftがloadNibNamedでCardViewのパーツを読み出しているのですが、ここでクラッシュしてしまいます。

swift

1//ViewController.swift 2//(中略) 3let cardView = CardView(frame: CGRect(x: 0, y: 0, width: Int(self.view.frame.width), height: self.cardHight))

swift

1//CardView.swift 2class CardView: UIView { 3 override init(frame: CGRect) { 4 super.init(frame: frame) 5 let view = Bundle(for: type(of: self)).loadNibNamed("CardView", owner: self, options: nil)?.first as! UIView // ここでクラッシュ 6 } 7}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問