如何制作一个圆形的UIView
我想制作一个圆形的 UIView 或 UIImageView 。或者是一个圆圈,我可以使用滑块更改其大小,并使用选择器视图更改其颜色。
I want to make a UIView or UIImageView that is a circle. Or a circle that i can change the size of using a slider, and the color of with a pickerview.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
我至少可以向您展示绘制任意大小的圆圈的快捷方式。无需 OpenGL,无需 Core Graphics 绘图。
导入 QuartzCore 框架以访问 UIView 或 UIImageView 的 .cornerRadius 属性。
还可以手动将其添加到项目的 Frameworks 文件夹中。
将此方法添加到您的视图控制器或任何您需要的地方:
要使用它,只需向其传递一个 UIImageView 和一个直径。此示例假设您有一个名为“circ”的 UIImageView 作为子视图添加到您的视图中。它应该设置一个backgroundColor,以便您可以看到它。
这仅处理UIImageViews,但您可以将其推广到任何UIView。
注意:从 iOS 7 开始,clipToBounds 需要设置为 YES。
I can at least show you a shortcut for drawing circles of arbitrary size. No OpenGL, no Core Graphics drawing needed.
Import the QuartzCore framework to get access to the .cornerRadius property of your UIView or UIImageView.
Also manually add it to your project's Frameworks folder.
Add this method to your view controller or wherever you need it:
To use it, just pass it a UIImageView and a diameter. This example assumes you have a UIImageView named "circ" added as a subview to your view. It should have a backgroundColor set so you can see it.
This just handles UIImageViews but you can generalize it to any UIView.
NOTE: Since iOS 7, clipToBounds need to YES.
如果有人正在寻找与下面相同的 Swift,答案是(Xcode7.2):
(要使其工作,高度和宽度必须相等。)
If somebody is looking for Swift equivalent than below is the answer (Xcode7.2):
(For this to work height and width must be equal.)
正如一些评论中提到的,@IBDesignable 现在使这变得更加容易,因此您可以使用 Interface Builder 来配置圆形 UIImageView。
首先创建一个名为
RoundedImageView.swift
的类并将以下代码粘贴到其中:在 InterfaceBuilder 中选择 UIImageView 并将该类从 UIImageView 更改为自定义 RoundedImageView:
设置
剪辑将 Bounds
设置为 true(否则图片将超出圆圈):它现在应该在 InterfaceBuilder 中将自身舍入,这非常漂亮。确保将宽度和高度设置为相同的值,否则它的形状会像齐柏林飞艇!
As mentioned in some comments, @IBDesignable makes this much easier now, so you can use Interface Builder to configure your rounded UIImageView.
First create a class named
RoundedImageView.swift
and paste this code to it:Select the UIImageView in InterfaceBuilder and change the class from UIImageView to the custom RoundedImageView:
Set
Clip to Bounds
to true (or the pic will extend beyond the circle):It should now round itself right there in InterfaceBuilder, which is pretty nifty. Be sure to set the width and height to the same values or it'll be shaped like a zeppelin!
无需图形调用。只需将角半径设置为宽度/2。这可以在任何视觉对象(即
UI
元素)上完成No need for graphics calls. Just set the corner radius to the width / 2. This can be done on any visual object ie
UI
element一个简洁、干净且优雅的解决方案是创建一个名为
RoundedUIView
的类,并在 Xcode 的 Identity Inspector 中选择它作为UIView
元素的自定义类,如所附屏幕截图所示。我需要在白色背景的各种屏幕上显示多个彩色图标,因为应用程序本身具有绿色主题。因此,我将
UIImgeView
放在RoundedUIView
之上,使它们看起来像这样:A neat, clean and elegant solution is to make a class called
RoundedUIView
and select it as yourUIView
element's custom class in Xcode's Identity Inspector like shown in the attached screenshot.I needed to display multiple coloured icons on various screens on white background since the app itself has green theme. So I put my
UIImgeView
on top ofRoundedUIView
to make them look like this:您需要创建一个透明的 UIView(背景颜色 alpha 为 0),然后在其 drawRect: 中使用 CoreGraphics 调用绘制圆。您还可以编辑视图的图层,并为其指定一个角半径。
You need to make a transparent UIView (background color alpha of 0), and then, in its drawRect:, draw your circle using CoreGraphics calls. You could also edit the view's layer, and give it a cornerRadius.