iOS rounded UITextField with shadow

后端 未结 6 1754
猫巷女王i
猫巷女王i 2021-02-08 01:24

I would like to add a shadow effect to my UITextField currently what I\'m achieving is this:
As you can see the shadow is not rounded in the corners. My code:



        
相关标签:
6条回答
  • 2021-02-08 01:31
    extension UITextField {
    
        func addShadowToTextField(color: UIColor = UIColor.gray, cornerRadius: CGFloat) {
    
        self.backgroundColor = UIColor.white
        self.layer.masksToBounds = false
        self.layer.shadowColor = color.cgColor
        self.layer.shadowOffset = CGSize(width: 0, height: 0)
        self.layer.shadowOpacity = 1.0
        self.backgroundColor = .white
        self.layer.cornerRadius = cornerRadius
       }
    }
    

    Add Extension and Usage:

        dateTxtFld.addShadowToTextField(cornerRadius: 3)
        dateTxtFld.addShadowToTextField(color: UIColor.blackColor, cornerRadius: 3)
    
    0 讨论(0)
  • 2021-02-08 01:35

    Ok, I found the problem. Turns out that I was using rectangle border:

    The correct one should be:

    And the code is:

    mNickname.layer.masksToBounds = false
    mNickname.layer.shadowRadius = 3.0
    mNickname.layer.shadowColor = UIColor.blackColor().CGColor
    mNickname.layer.shadowOffset = CGSizeMake(1.0, 1.0)
    mNickname.layer.shadowOpacity = 1.0
    

    Result:

    0 讨论(0)
  • 2021-02-08 01:41

    Try to change shadowOpacity to 0.5 Also, could you send full customisation of this textField?

    0 讨论(0)
  • 2021-02-08 01:41

    do you tried this mNickname.layer.masksToBounds = true;

    0 讨论(0)
  • 2021-02-08 01:45

    try this, code is in objective C, but same for swift

    self.textField.layer.shadowColor = [[UIColor blackColor] CGColor];
        self.textField.layer.shadowOffset = CGSizeMake(0.0, 1.0);
        self.textField.layer.shadowOpacity = 1;
        self.textField.layer.shadowRadius = 0.0;
    
    0 讨论(0)
  • 2021-02-08 01:51

    You can use this extension

    extension ViewController {
        func setShadow(_ view: UIView) {
            view.layer.masksToBounds = false;
            view.layer.shadowRadius  = 3.0;
            view.layer.shadowColor   = UIColor.black.cgColor;
            view.layer.shadowOffset  = CGSize(width: 2.0, height: 4.0);
            view.layer.shadowOpacity = 1.0;
        }
    }
    
    0 讨论(0)
提交回复
热议问题