Can't get a view to change it's size









up vote
1
down vote

favorite












I have a UIImageView inside a ForecastCell Class (for a UICollectionView), anyhow, I can't get the UIImageView inside the cell to change it's size. This is what I tried:



private func setupWeatherIcon()
self.addSubview(mWeatherIcon)

//mWeatherIcon.frame.size.width = CGFloat(self.frame.width) / 2
//mWeatherIcon.frame.size.height = CGFloat(self.frame.height) / 2
mWeatherIcon.frame.size.width = 20
mWeatherIcon.frame.size.height = 20

mWeatherIcon.centerXAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerXAnchor).isActive = true
mWeatherIcon.centerYAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerYAnchor).isActive = true



This is mWeatherIcon:



var mWeatherIcon: UIImageView = 
let image = UIImageView(image: UIImage(named: "partly-cloudy"))

image.translatesAutoresizingMaskIntoConstraints = false
return image
()


No matter what width and height I set, It always stays the same width and height.










share|improve this question

























    up vote
    1
    down vote

    favorite












    I have a UIImageView inside a ForecastCell Class (for a UICollectionView), anyhow, I can't get the UIImageView inside the cell to change it's size. This is what I tried:



    private func setupWeatherIcon()
    self.addSubview(mWeatherIcon)

    //mWeatherIcon.frame.size.width = CGFloat(self.frame.width) / 2
    //mWeatherIcon.frame.size.height = CGFloat(self.frame.height) / 2
    mWeatherIcon.frame.size.width = 20
    mWeatherIcon.frame.size.height = 20

    mWeatherIcon.centerXAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerXAnchor).isActive = true
    mWeatherIcon.centerYAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerYAnchor).isActive = true



    This is mWeatherIcon:



    var mWeatherIcon: UIImageView = 
    let image = UIImageView(image: UIImage(named: "partly-cloudy"))

    image.translatesAutoresizingMaskIntoConstraints = false
    return image
    ()


    No matter what width and height I set, It always stays the same width and height.










    share|improve this question























      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      I have a UIImageView inside a ForecastCell Class (for a UICollectionView), anyhow, I can't get the UIImageView inside the cell to change it's size. This is what I tried:



      private func setupWeatherIcon()
      self.addSubview(mWeatherIcon)

      //mWeatherIcon.frame.size.width = CGFloat(self.frame.width) / 2
      //mWeatherIcon.frame.size.height = CGFloat(self.frame.height) / 2
      mWeatherIcon.frame.size.width = 20
      mWeatherIcon.frame.size.height = 20

      mWeatherIcon.centerXAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerXAnchor).isActive = true
      mWeatherIcon.centerYAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerYAnchor).isActive = true



      This is mWeatherIcon:



      var mWeatherIcon: UIImageView = 
      let image = UIImageView(image: UIImage(named: "partly-cloudy"))

      image.translatesAutoresizingMaskIntoConstraints = false
      return image
      ()


      No matter what width and height I set, It always stays the same width and height.










      share|improve this question













      I have a UIImageView inside a ForecastCell Class (for a UICollectionView), anyhow, I can't get the UIImageView inside the cell to change it's size. This is what I tried:



      private func setupWeatherIcon()
      self.addSubview(mWeatherIcon)

      //mWeatherIcon.frame.size.width = CGFloat(self.frame.width) / 2
      //mWeatherIcon.frame.size.height = CGFloat(self.frame.height) / 2
      mWeatherIcon.frame.size.width = 20
      mWeatherIcon.frame.size.height = 20

      mWeatherIcon.centerXAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerXAnchor).isActive = true
      mWeatherIcon.centerYAnchor.constraint(equalTo: self.safeAreaLayoutGuide.centerYAnchor).isActive = true



      This is mWeatherIcon:



      var mWeatherIcon: UIImageView = 
      let image = UIImageView(image: UIImage(named: "partly-cloudy"))

      image.translatesAutoresizingMaskIntoConstraints = false
      return image
      ()


      No matter what width and height I set, It always stays the same width and height.







      ios swift uicollectionview






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 10 at 15:52









      John Doah

      149417




      149417






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote













          You need width and height constraints



          self.contentView.addSubview(mWeatherIcon)

          NSLayoutConstraint.activate([
          mWeatherIcon.centerXAnchor.constraint(equalTo:contentView.centerXAnchor),
          mWeatherIcon.centerYAnchor.constraint(equalTo:contentView.centerYAnchor),
          mWeatherIcon.widthAnchor.constraint(equalTo:contentView.widthAnchor,multiplier:0.5),
          mWeatherIcon.heightAnchor.constraint(equalTo:contentView.heightAnchor,multiplier:0.5)
          ])


          Don't forget to implement this method



          func collectionView(_ collectionView: UICollectionView, 
          layout collectionViewLayout: UICollectionViewLayout,
          sizeForItemAt indexPath: IndexPath) -> CGSize





          share|improve this answer






















          • I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
            – John Doah
            Nov 10 at 16:51










          • @JohnDoah see edit...........
            – Sh_Khan
            Nov 10 at 16:58










          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













           

          draft saved


          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240644%2fcant-get-a-view-to-change-its-size%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          0
          down vote













          You need width and height constraints



          self.contentView.addSubview(mWeatherIcon)

          NSLayoutConstraint.activate([
          mWeatherIcon.centerXAnchor.constraint(equalTo:contentView.centerXAnchor),
          mWeatherIcon.centerYAnchor.constraint(equalTo:contentView.centerYAnchor),
          mWeatherIcon.widthAnchor.constraint(equalTo:contentView.widthAnchor,multiplier:0.5),
          mWeatherIcon.heightAnchor.constraint(equalTo:contentView.heightAnchor,multiplier:0.5)
          ])


          Don't forget to implement this method



          func collectionView(_ collectionView: UICollectionView, 
          layout collectionViewLayout: UICollectionViewLayout,
          sizeForItemAt indexPath: IndexPath) -> CGSize





          share|improve this answer






















          • I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
            – John Doah
            Nov 10 at 16:51










          • @JohnDoah see edit...........
            – Sh_Khan
            Nov 10 at 16:58














          up vote
          0
          down vote













          You need width and height constraints



          self.contentView.addSubview(mWeatherIcon)

          NSLayoutConstraint.activate([
          mWeatherIcon.centerXAnchor.constraint(equalTo:contentView.centerXAnchor),
          mWeatherIcon.centerYAnchor.constraint(equalTo:contentView.centerYAnchor),
          mWeatherIcon.widthAnchor.constraint(equalTo:contentView.widthAnchor,multiplier:0.5),
          mWeatherIcon.heightAnchor.constraint(equalTo:contentView.heightAnchor,multiplier:0.5)
          ])


          Don't forget to implement this method



          func collectionView(_ collectionView: UICollectionView, 
          layout collectionViewLayout: UICollectionViewLayout,
          sizeForItemAt indexPath: IndexPath) -> CGSize





          share|improve this answer






















          • I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
            – John Doah
            Nov 10 at 16:51










          • @JohnDoah see edit...........
            – Sh_Khan
            Nov 10 at 16:58












          up vote
          0
          down vote










          up vote
          0
          down vote









          You need width and height constraints



          self.contentView.addSubview(mWeatherIcon)

          NSLayoutConstraint.activate([
          mWeatherIcon.centerXAnchor.constraint(equalTo:contentView.centerXAnchor),
          mWeatherIcon.centerYAnchor.constraint(equalTo:contentView.centerYAnchor),
          mWeatherIcon.widthAnchor.constraint(equalTo:contentView.widthAnchor,multiplier:0.5),
          mWeatherIcon.heightAnchor.constraint(equalTo:contentView.heightAnchor,multiplier:0.5)
          ])


          Don't forget to implement this method



          func collectionView(_ collectionView: UICollectionView, 
          layout collectionViewLayout: UICollectionViewLayout,
          sizeForItemAt indexPath: IndexPath) -> CGSize





          share|improve this answer














          You need width and height constraints



          self.contentView.addSubview(mWeatherIcon)

          NSLayoutConstraint.activate([
          mWeatherIcon.centerXAnchor.constraint(equalTo:contentView.centerXAnchor),
          mWeatherIcon.centerYAnchor.constraint(equalTo:contentView.centerYAnchor),
          mWeatherIcon.widthAnchor.constraint(equalTo:contentView.widthAnchor,multiplier:0.5),
          mWeatherIcon.heightAnchor.constraint(equalTo:contentView.heightAnchor,multiplier:0.5)
          ])


          Don't forget to implement this method



          func collectionView(_ collectionView: UICollectionView, 
          layout collectionViewLayout: UICollectionViewLayout,
          sizeForItemAt indexPath: IndexPath) -> CGSize






          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Nov 10 at 16:57

























          answered Nov 10 at 16:15









          Sh_Khan

          33.8k41124




          33.8k41124











          • I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
            – John Doah
            Nov 10 at 16:51










          • @JohnDoah see edit...........
            – Sh_Khan
            Nov 10 at 16:58
















          • I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
            – John Doah
            Nov 10 at 16:51










          • @JohnDoah see edit...........
            – Sh_Khan
            Nov 10 at 16:58















          I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
          – John Doah
          Nov 10 at 16:51




          I don't want it to be really 20 20, just an example. I tried giving it self.widthanchor and divide it by 2 but it didn't even build, I tried casting but still nothing. How can I get the self.widthanchor to be the width of the image?
          – John Doah
          Nov 10 at 16:51












          @JohnDoah see edit...........
          – Sh_Khan
          Nov 10 at 16:58




          @JohnDoah see edit...........
          – Sh_Khan
          Nov 10 at 16:58

















           

          draft saved


          draft discarded















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53240644%2fcant-get-a-view-to-change-its-size%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Top Tejano songwriter Luis Silva dead of heart attack at 64

          政党

          天津地下鉄3号線