css

目录

css样式的声明

替换元素

非替换元素

基础选择器

元素选择器

属性选择器

伪类选择器

a链接标签中的伪类选择器

子元素是行内元素

子元素是块元素

子元素是不定宽的块元素(导航栏)

li标签取消样式

CSS背景控制

列表标签

链接标签

定位

浮动

图文混排

三列布局

网站企业布局


CSS基础

元素用html标签声明,用CSS修改样式

css样式的声明

       内联声明:写在style属性中

       内部申明:写在style标签中

       外部申明:在head标签中使用link标签加载css样式文件到html中

替换元素

       元素的内容由标签的属性来设置,标签就是一个占位符,默认导入的资源是做为行内元素,替换元素如果是可视元素的话,此元素就是一个行内块

非替换元素

       元素的内容由用户直接提供或者来自文档自身

基础选择器

       元素选择器

              h1{ color:red }

       ID选择器

              #id{ color:red }

       类选择器

              .class{ color:red }

元素选择器

       层级选择器(父子选择器)

              ul li{ color:red }

              ul *{ color:red } 通配选择器,选择ul下的所有li标签

       子元素选择器

              ul > li {color : red}

       相邻兄弟选择器

              h1 + h2{ color:red} 选择h1标签后面相邻的h2标签

              h1 ~ h2{ color:red} 选择h1标签后面所有的h2标签

属性选择器

       根据属性名来选择元素

              *[id]{ color:red} 选择所有有id属性的元素

       根据属性的名和值来选   --- 其它的都是根据这个来的

              li[class = ”c”]{ color:red} 选择class=”c”的元素

       根据class属性中包含指定单词的元素

              li[class ~=”red”] 选择class属性中有red单词的元素

       选择以”xx”开头的类样式元素

              li [ class ^= “xx” ]

       选择以”yy”结尾的类样式元素

              li [ class $= “yy”]

       选择class属性值中包括指定字母”z” 的元素

              li [class *=”z”]

伪类选择器

       ul: before { content:”php” 插入的是行内元素} 在ul标签前面插入

       ul: after { url(../image.png) 插入图片} 在ul标签后面插入  主要用来清除浮动

       ul li:first-child { } 选择ul下的第一个li标签

       ul li:last-child { } 选择ul下的最后一个li标签

       div p:only-child { } 选择div标签中唯一子元素P,且同级无其它元素

       div p:only-of-type { } 选择div标签中的唯一的P元素,同级可以有其它元素

       nth-child( n ) { } 选择器匹配父元素中的第 n 个子元素,元素类型没有限制。

              n 可以是一个数字,一个关键字,或者一个公式。

              odd 为奇数 even 为偶数

       :nth-of-type(n)选择器匹配同类型中的第n个同级兄弟元素。

              n 可以是一个数字,一个关键字,或者一个公式。

              odd 为奇数 even 为偶数

a链接标签中的伪类选择器

       a:link {color:#FF0000;} /* 未访问的链接 */

a:visited {color:#00FF00;} /* 已访问的链接 */

a:hover {color:#FF00FF;} /* 鼠标划过链接 */

a:active {color:#0000FF;} /* 已选中的链接 */

a:hover 必须被置于 a:link 和 a:visited 之后

a:active 必须被置于 a:hover 之后

盒子模型

盒子模型的组成

       content padding border margin

内边距padding撑开盒子大小的解决方法

  1. 修改盒子的大小
  2. 给当前盒子添加一个父级盒子,并设置它的宽高

外边距的叠压

  1. 当两盒子垂直方向的上下边距相等时会重叠
  2. 当两盒子垂直方向的上下边距不相等时会以大的为准,小的陷入大的外边距中

边框

       边框可以设置宽,样式,颜色

       border: 1px solid #ccc ;  solid>实线 dashed>虚线

       边框折叠

              border-collapse:collapse;

      

圆角盒子

       border-radius: 20px; 可以设置百分比,正方形盒子设置50%则为圆

阴影盒子

       box-shadow:

       水平方向位移 垂直方向位移 阴影大小 阴影扩展面 阴影颜色 反投影inset(可选)

       外发光

       box-shadow:0 0 8px 3px #ccc;

       内发光

       box-shadow:0 0 8px 3px #ccc inset;

       右下(右上左上左下同理,类似于向限)

       box-shadow:8px 8px 8px 3px #ccc inset;

表格

背景

       background-image(../img)

背景重复

       background-repeat:no-repeat; 不会重复

       repeat-y 只有垂直方向重复

       repeat-x 只有水平方向重复

       inherit   从父元素继承样式

背景大小

       background-size:cover;    此时会保持图像的纵横比并将图像缩放成将完全覆盖背景定位区域的最小大小。

       background-size:contain   此时会保持图像的纵横比并将图像缩放成将适合背景定位区域的最大大小。

       background-size:100px;    设置背景图片高度和宽度。第一个值设置宽度,第二个值设置的高度。如果只给出一个值,第二个是设置为 auto(自动)

       background-size:50%;        将计算相对于背景定位区域的百分比。第一个值设置宽度,第二个值设置的高度。如果只给出一个值,第二个是设置为"auto(自动)"

字体大小

       font-size: 1.6em;

字体加粗

       font-weight: bolder;

字体倾斜

       font-style: italic;

       font-style:oblique;

字体类型

       font-family:” Arial”;

文本居中

子元素是行内元素

单行文本居中

水平居中: 在父元素设置 text-align:center;

垂直居中: 在行内元素(子元素)设置行高为父元素的高; line-heigh:

多行文本居中 

水平居中: 在父元素设置 text-align:center;

              垂直居中: 在父元素设置 display:table-cell ; vertical-align: middle;

子元素是块元素

       水平居中: 子元素设置margin:atuo;

       垂直居中: 在父元素设置 display:table-cell ; vertical-align: middle;

子元素是不定宽的块元素(导航栏)

       水平居中: 在父元素设置 text-align:center; 子元素设置display:inline-block

       垂直居中: 在ul标签设置 line-height

       底部居中: 在父元素设置 display:table-cell ; vertical-align: middle;

li标签取消样式

 li { list-type:none; }

 ul { padding-left:0; }

CSS背景控制

       背景颜色: background-color:transparent;  transparent(默认背景)

       背景图片:background-repeat:no-repeat;不重复

       背景位置:background-position: 0 0; (默认)

       背景图片固定     background-attachment:fixed;

                     Background-position:center center;

       背景大小:background-size:

列表标签

       list-style-type:disc;默认 实心圆  设置列表项标志的类型。

              circle>空心圆  square>实心方块  decimal>数字

       list-style-image: url(../img)  将图象设置为列表项标志。

       list-style-position: inside; 列表项目标记放置在文本以内,且环绕文本根据标记对齐

              outside>默认值。保持标记位于文本的左侧。列表项目标记放置在文本以外,且环绕文本不根据标记对齐。

链接标签

       text-decoration: none; 取消下划线

              underline>显示下划线

定位

static:默认文档流定位

relative:相对定位 元素相对于它原来的文档流中的位置进行定位

       position:relative

       top:50px; 距离上方50px

       left:50px;距离左方50px;

absolute:绝对定位 脱离文档流,并且使行内元素支持宽高,相对于父级进行定位

       定位父级position:relative;  如果没有定位父级则相对于body进行定位

       子级     position:abslute;

              top 50px;

              left 50px;

fixed:固定定位

       position: fixed;

       top: 50px;

       left: 50px;

浮动

会脱离文档流

任何元素浮动之后都支持宽高

浮动总是沿水平方向

浮动的定义: float: left;

同级元素   浮动的清除

       clear:left

       clear:right

       clear:both;

层级元素  浮动的清除

  1. 让父元素一起浮动
  2. 给父元素添加overflower: hidden;
  3. 添加一个多余的空元素来实现 (不推荐)
  4. 给父元素添加一个after伪类 { content: “” ;   display: block;   clear: both;}

图文混排

去掉img默认的下面的空白区

  1. 给父级添加一个极小的行高
  2. 子元素设置属性vertical-align: top;  middle也行

首段落空两字符

       text-indent: 2em;

三列布局

固定布局

  1. 主体中间设置父级relative,将左右侧边栏设置absolute ,内容区通过margin挤出来
  2. min-height设置最小高度为100%
  3. 左中右都相互独立,共同存在于主体中间

双飞翼布局

  1. 内容区放前面,然后再左边,再右边,全部浮动,内容区套一个子标签
  2. 主体中间设置宽度1000px;设置显示隐藏 overflow:hidden (消除层级浮动)
  3. 设置内容区宽度100%, 高度在子标签设置
  4. 子标签设置margin 挤出位置,左边设置margin-left:-100%; 右边设置margin-left:-200px
  5. 相当于内容区两边被左右给盖着, 内容由子标签显示出来

圣杯布局

  1. 内容区放前面,然后再左边,再右边
  2. 主体中间设置宽度为内容区的宽度,左右边分别再主体中间的两边,相当于主体中间用来显示内容
  3. 设置内容区的宽度100%; 左边和右边分别移动margin-left
  4. 主体中间 通过padding来填充内容区大小
  5. 通过相对布局 使得 左边和右边的内容压在padding上面显示

网站企业布局

       一般至少创建三个CSS文件

  1. 样式重置文件 reset.css
    • html
      1. overflow-y:auto;      显示垂直滚动条
      2. overflow-x:hidden;  隐藏水平滚动条
    • body , h1 , h2 , h3 , ul , li , p
      1. margin:0;
      2. padding:0
      3. font-family: ’ ’,’’,’’;  设置字体
    • p , li , a
      1. font-size: 设置字体大小
    • ul , li
      1. list-style-type:none; 清除样式
    • a : link  a:visited   a: active
      1. text-decoration : none ;  取消下划线
    • a: hover
      1. text-decoration : none ;
  2. 公共CSS文件 common.css

cursor : pointer; 鼠标悬停显示为 手

  1. 其它css文件

opacity:0.3; 透明度

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 目标检测的定义 目标检测(Object Detection)的任务是找出图像中所有感兴趣的目标(物体),确定它们的类别和位置,是计算机视觉领域的核心问题之一。由于各类物体有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具有挑战性的问题。 目标检测任务可分为两个关键的子任务,目标定位和目标分类。首先检测图像中目标的位置(目标定位),然后给出每个目标的具体类别(目标分类)。输出结果是一个边界框(称为Bounding-box,一般形式为(x1,y1,x2,y2),表示框的左上角坐标和右下角坐标),一个置信度分数(Confidence Score),表示边界框中是否包含检测对象的概率和各个类别的概率(首先得到类别概率,经过Softmax可得到类别标签)。 1.1 Two stage方法 目前主流的基于深度学习的目标检测算法主要分为两类:Two stage和One stage。Two stage方法将目标检测过程分为两个阶段。第一个阶段是 Region Proposal 生成阶段,主要用于生成潜在的目标候选框(Bounding-box proposals)。这个阶段通常使用卷积神经网络(CNN)从输入图像中提取特征,然后通过一些技巧(如选择性搜索)来生成候选框。第二个阶段是分类和位置精修阶段,将第一个阶段生成的候选框输入到另一个 CNN 中进行分类,并根据分类结果对候选框的位置进行微调。Two stage 方法的优点是准确度较高,缺点是速度相对较慢。 常见Tow stage目标检测算法有:R-CNN系列、SPPNet等。 1.2 One stage方法 One stage方法直接利用模型提取特征值,并利用这些特征值进行目标的分类和定位,不需要生成Region Proposal。这种方法的优点是速度快,因为省略了Region Proposal生成的过程。One stage方法的缺点是准确度相对较低,因为它没有对潜在的目标进行预先筛选。 常见的One stage目标检测算法有:YOLO系列、SSD系列和RetinaNet等。 2 常见名词解释 2.1 NMS(Non-Maximum Suppression) 目标检测模型一般会给出目标的多个预测边界框,对成百上千的预测边界框都进行调整肯定是不可行的,需要对这些结果先进行一个大体的挑选。NMS称为非极大值抑制,作用是从众多预测边界框中挑选出最具代表性的结果,这样可以加快算法效率,其主要流程如下: 设定一个置信度分数阈值,将置信度分数小于阈值的直接过滤掉 将剩下框的置信度分数从大到小排序,选中值最大的框 遍历其余的框,如果和当前框的重叠面积(IOU)大于设定的阈值(一般为0.7),就将框删除(超过设定阈值,认为两个框的里面的物体属于同一个类别) 从未处理的框中继续选一个置信度分数最大的,重复上述过程,直至所有框处理完毕 2.2 IoU(Intersection over Union) 定义了两个边界框的重叠度,当预测边界框和真实边界框差异很小时,或重叠度很大时,表示模型产生的预测边界框很准确。边界框A、B的IOU计算公式为: 2.3 mAP(mean Average Precision) mAP即均值平均精度,是评估目标检测模型效果的最重要指标,这个值介于0到1之间,且越大越好。mAP是AP(Average Precision)的平均值,那么首先需要了解AP的概念。想要了解AP的概念,还要首先了解目标检测中Precision和Recall的概念。 首先我们设置置信度阈值(Confidence Threshold)和IoU阈值(一般设置为0.5,也会衡量0.75以及0.9的mAP值): 当一个预测边界框被认为是True Positive(TP)时,需要同时满足下面三个条件: Confidence Score > Confidence Threshold 预测类别匹配真实值(Ground truth)的类别 预测边界框的IoU大于设定的IoU阈值 不满足条件2或条件3,则认为是False Positive(FP)。当对应同一个真值有多个预测结果时,只有最高置信度分数的预测结果被认为是True Positive,其余被认为是False Positive。 Precision和Recall的概念如下图所示: Precision表示TP与预测边界框数量的比值 Recall表示TP与真实边界框数量的比值 改变不同的置信度阈值,可以获得多组Precision和Recall,Recall放X轴,Precision放Y轴,可以画出一个Precision-Recall曲线,简称P-R
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值