- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Snapchat 是如何把这个导航栏做成渐变背景和圆角的。谢谢!
我没有足够大的声誉来发布图片,但它是向人们展示你的 snapchat 的 View ,一直到左边。
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
// Sets background to a blank/empty image
UINavigationBar.appearance().setBackgroundImage(UIImage(), for: .default)
// Sets shadow (line below the bar) to a blank image
UINavigationBar.appearance().shadowImage = UIImage()
// Sets translucent background's color
UINavigationBar.appearance().backgroundColor = .clear
// Set translucent
UINavigationBar.appearance().isTranslucent = true
return true
}
在我的 UITableViewControllerClass 中:
override func viewDidLoad() {
super.viewDidLoad()
tableView?.layer.cornerRadius = 15
//Declare a gradient
let gradient: CAGradientLayer = CAGradientLayer()
//Set the two colors of your gradient
gradient.colors = [UIColor.purple.cgColor, UIColor.red.cgColor]
//Set it's location
gradient.locations = [0.0 , 1.0]
gradient.startPoint = CGPoint(x: 0.0, y: 0.0)
gradient.endPoint = CGPoint(x: 1.0, y: 1.0)
gradient.frame = CGRect(x: 0.0, y: 0.0, width: (self.navigationController?.navigationBar.frame.size.width)!, height: (self.navigationController?.navigationBar.frame.size.height)!)
self.navigationController?.navigationBar.layer.insertSublayer(gradient, at: 0)
}
最佳答案
据我了解,您希望将渐变作为背景和表格 View 的圆角。
这是我的 ViewController 的代码。
class ViewController: UIViewController {
@IBOutlet var backroundView: UIView!
@IBOutlet weak var viewContainingTableView: UIView!
@IBOutlet weak var topView: UIView!
@IBOutlet weak var navigationBar: UINavigationBar!
override func viewDidLoad() {
super.viewDidLoad()
//Change the corner radius to your liking
viewContainingTableView.layer.cornerRadius = 25
//Make the backround of your 'navigation controller' transparent
topView.backgroundColor = UIColor.white.withAlphaComponent(0.0)
//Declare a gradient
let gradient: CAGradientLayer = CAGradientLayer()
//Set the two colors of your gradient
gradient.colors = [UIColor.purple.cgColor, UIColor.red.cgColor]
//Set it's location
gradient.locations = [0.0 , 1.0]
gradient.startPoint = CGPoint(x: 0.0, y: 0.0)
gradient.endPoint = CGPoint(x: 1.0, y: 1.0)
gradient.frame = CGRect(x: 0.0, y: 0.0, width: self.view.frame.size.width, height: self.view.frame.size.height)
self.backroundView.layer.insertSublayer(gradient, at: 0)
//self.view.layer.insertSublayer(gradient, at: 0)
}
}
将 App Delegate 中的 didFinishLaunchingWithOptions 方法更改为以下内容:
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
// Sets background to a blank/empty image
UINavigationBar.appearance().setBackgroundImage(UIImage(), for: .default)
// Sets shadow (line below the bar) to a blank image
UINavigationBar.appearance().shadowImage = UIImage()
// Sets translucent background's color
UINavigationBar.appearance().backgroundColor = .clear
// Set translucent
UINavigationBar.appearance().isTranslucent = true
return true
}
这是我的 View 层次结构:
这是它给出的:
要在没有 Storyboard 的情况下执行此操作,请将您的 ViewController 代码更改为以下内容:
class ViewController: UIViewController {
var viewContainingTableView = UIView()
let navigationBarView = UINavigationBar()
let topView = UIView()
let tableView = UITableView()
override func viewDidLoad() {
super.viewDidLoad()
let margins = view.layoutMarginsGuide
view.addSubview(topView)
topView.translatesAutoresizingMaskIntoConstraints = false
topView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor).isActive = true
topView.heightAnchor.constraint(equalToConstant: 60).isActive = true
topView.leadingAnchor.constraint(equalTo: margins.leadingAnchor).isActive = true
topView.trailingAnchor.constraint(equalTo: margins.trailingAnchor).isActive = true
topView.addSubview(navigationBarView)
navigationBarView.translatesAutoresizingMaskIntoConstraints = false
navigationBarView.topAnchor.constraint(equalTo: topView.topAnchor).isActive = true
navigationBarView.bottomAnchor.constraint(equalTo: topView.bottomAnchor).isActive = true
navigationBarView.leadingAnchor.constraint(equalTo: topView.leadingAnchor).isActive = true
navigationBarView.trailingAnchor.constraint(equalTo: topView.trailingAnchor).isActive = true
self.navigationItem.title = "Test"
let buttonNavBar = UIBarButtonItem(title: "Button", style: .plain, target: nil, action: #selector(buttonAction))
navigationItem.rightBarButtonItem = buttonNavBar
navigationBarView.setItems([navigationItem], animated: false)
view.addSubview(viewContainingTableView)
viewContainingTableView.translatesAutoresizingMaskIntoConstraints = false
viewContainingTableView.topAnchor.constraint(equalTo: topView.bottomAnchor, constant: 0).isActive = true
viewContainingTableView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
viewContainingTableView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
viewContainingTableView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true
viewContainingTableView.backgroundColor = UIColor.white
viewContainingTableView.addSubview(tableView)
tableView.translatesAutoresizingMaskIntoConstraints = false
tableView.topAnchor.constraint(equalTo: viewContainingTableView.topAnchor, constant: 20).isActive = true
tableView.bottomAnchor.constraint(equalTo: viewContainingTableView.bottomAnchor).isActive = true
tableView.leadingAnchor.constraint(equalTo: viewContainingTableView.leadingAnchor).isActive = true
tableView.trailingAnchor.constraint(equalTo: viewContainingTableView.trailingAnchor).isActive = true
view.setNeedsUpdateConstraints()
view.updateConstraints()
//Change the corner radius to your liking
viewContainingTableView.layer.cornerRadius = 25
//Make the backround of your 'navigation controller' transparent
topView.backgroundColor = UIColor.white.withAlphaComponent(0.0)
//Declare a gradient
let gradient: CAGradientLayer = CAGradientLayer()
//Set the two colors of your gradient
gradient.colors = [UIColor.purple.cgColor, UIColor.red.cgColor]
//Set it's location
gradient.locations = [0.0 , 1.0]
gradient.startPoint = CGPoint(x: 0.0, y: 0.0)
gradient.endPoint = CGPoint(x: 1.0, y: 1.0)
gradient.frame = CGRect(x: 0.0, y: 0.0, width: self.view.frame.size.width, height: self.view.frame.size.height)
self.view.layer.insertSublayer(gradient, at: 0)
}
@objc func buttonAction() {
//Function of your button: add code to execute when button is pressed
}
}
关于ios - Snapchat 导航栏样式 - Swift,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48916564/
我使用 Runtime.getRuntime().exec 来运行 perl 程序。现在我想在执行过程中显示百分比进度条,然后在perl程序执行完成后,它应该关闭进度条。我该怎么做? Runtime.
我已广泛搜索该网站,但找不到答案。请我是新手,我需要你的帮助。 我想创建一个固定的导航栏,但每次在我的 CSS 样式表中放置一个固定的规则时,导航栏都会消失。这是我的 html 代码:
Here's a nice jsFiddle illustrating the problem 我正在尝试创建一个标题栏元素... 永远只有 1 行高 在右上角有始终存在的控件 在左上角有一个标题,如
int fd = open(JOYSTICK_NAME, O_RDONLY | O_NONBLOCK); O_RDONLY 和 O_NONBLOCK 之间的栏是什么意思?我在 OpenGL/GLUT
我注意到我的网页在页脚之后和页面底部有一个空白/栏: 我试图通过使用 Chrome 中的 inspect 元素来查找此问题的原因,但找不到任何内容。我正在使用 Boostrap,这是我的页脚 HTML
我已经对这个主题进行了一些研究,但我找不到完整的解决方案,因此,我一步一步地尝试和错误,我终于找到了如何实现这些结果:透明或彩色Actionbar 和 Statusbar。请参阅下面的答案。 最佳答案
Highcharts 教程中的经典示例是: $(function () { $('#container').highcharts({ chart: { type: 'bar'
注意 :这与 iOS 13 中使用的新默认模态呈现样式无关。 我有一个奇怪的问题,显示模态 UINavigationController . 考虑一个 UIViewController位于 UINav
我需要帮助了解如何在加载页面时隐藏 iPad 地址栏或顶部的整个地址栏。 我正在开发基于在线客户管理系统的系统,需要隐藏 iPad 地址栏,因为它在查看网站时会占用大量空间。 问候涡流 已经尝试了以下
我在向栏中添加文本时遇到了一些问题。我想在栏上方显示值,但我无法向每个栏添加文本。 现在我的dom结构是: g rect rect rect 我想要什么: g g.bar rect
我有 ListView ,数据将从数据表显示在 ListView 中像这样我已经完成了但是我在数据行 6 有问题 dt = classes.xxxxx.GetData(sql,
我使用 opposite 属性将 xAxis 向右移动。条形图怎么可能也从右侧开始? 谢谢! Highcharts.chart('absoluteInterruptions', { chart:
我得到了这张图片,我想在我的导航 Controller 中使用它: 我是这样设置的(根据 this 问题的建议): UINavigationBar *theBar = self.navigationC
这个问题在这里已经有了答案: How to disable breadcrumbs in Eclipse (11 个答案) 关闭 9 年前。 有谁知道如何删除我在 Eclipse 中用红色圈出的栏?
总而言之,我的应用程序中有一个浏览器,我希望它只启动 5 个网站,仅此而已。有没有办法让我的浏览器通过设置自定义字符串来启动 5 个网站,例如 if {用户键入此字符串} 转到该网站,然后 else
我想在我的应用程序中实现一个进度条。发生的过程是应用程序将一个目录复制到 iOS 文档目录中。通常需要 7-10 秒(iPhone 4 测试)。我对进度条的理解是你在事情发生时更新进度条。但是根据目录
我正在寻找一种创建交互式子弹图的方法,它允许用户单击图中的任意位置并设置一个标记,然后根据该标记所在的位置计算一些简单的值。例如,我希望它看起来类似于: http://www.usrecordings
我目前在一个网站上工作,我有一张人的照片。在图片的右侧,我想要名称和描述。名称应与描述具有不同的背景。我上传了一张它应该是什么样子的图片:http://www.tiikoni.com/tis/view
我将 div 栏设置为不滚动,因此它将始终显示在网站顶部。在这个栏内,我有另一个 div 框,里面有两个按钮,它们向右浮动,所以它们总是在右上角。 问题是我希望按钮居中于页面的右上角而不是右上角。相反
因此,我在我的网站中使用了一个选择栏。我试图在悬停时更改选项的背景颜色。此外,如果有人知道设置垂直 slider 样式的好方法,那就太棒了。 这是我正在尝试做的事情的 fiddle : http://
我是一名优秀的程序员,十分优秀!