You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
200 lines
4.4 KiB
SCSS
200 lines
4.4 KiB
SCSS
@import "./../common/abstracts/_mixin.scss";
|
|
@import "./../common/abstracts/variable.scss";
|
|
|
|
@include b(img-cropper) {
|
|
background: rgba(0, 0, 0, 1);
|
|
position: fixed;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100vw;
|
|
height: 100vh;
|
|
z-index: 1;
|
|
// 裁剪框包裹器
|
|
@include e(wrapper) {
|
|
position: relative;
|
|
background: rgba(0, 0, 0, 0.45);
|
|
}
|
|
@include e(cut) {
|
|
z-index: 9;
|
|
position: absolute;
|
|
width: 100vw;
|
|
height: 100vh;
|
|
display: flex;
|
|
flex-direction: column;
|
|
pointer-events: none;
|
|
|
|
.wd-img-cropper__cut--top,
|
|
.wd-img-cropper__cut--bottom,
|
|
.wd-img-cropper__cut--left,
|
|
.wd-img-cropper__cut--right {
|
|
// 拖动中背景蒙层为0 拖动结束为0.85
|
|
background-color: rgba(0, 0, 0, 0.85);
|
|
transition: background 0.2s;
|
|
@include when(hightlight) {
|
|
background-color: rgba(0, 0, 0, 0);
|
|
}
|
|
}
|
|
.wd-img-cropper__cut--bottom,
|
|
.wd-img-cropper__cut--right {
|
|
flex: auto;
|
|
}
|
|
@include m(middle) {
|
|
display: flex;
|
|
}
|
|
@include m(body) {
|
|
// 若需要变化窗体大小,支持控制窗体的大小来控制下方所有对应的展示
|
|
background-color: transparent;
|
|
position: relative;
|
|
// 节选框的窗体最外部边缘线
|
|
&::before {
|
|
content: "";
|
|
border: 1px solid #fff;
|
|
width: calc(200% - 1px);
|
|
height: calc(200% - 1px);
|
|
position: absolute;
|
|
transform: scale(0.5) translate(-1px, -1px);
|
|
top: -50%;
|
|
left: -50%;
|
|
}
|
|
|
|
// 结算框对角尺寸
|
|
$border-size: 2px;
|
|
// 节选框的四个角
|
|
.is-left-top,
|
|
.is-left-bottom,
|
|
.is-right-top,
|
|
.is-right-bottom {
|
|
&::before {
|
|
content: "";
|
|
position: absolute;
|
|
width: $border-size;
|
|
height: 20px;
|
|
background-color: #fff;
|
|
}
|
|
&::after {
|
|
content: "";
|
|
position: absolute;
|
|
width: 20px;
|
|
height: $border-size;
|
|
background-color: #fff;
|
|
}
|
|
}
|
|
.is-left-top {
|
|
&::before,
|
|
&::after {
|
|
left: -$border-size;
|
|
top: -$border-size;
|
|
}
|
|
}
|
|
.is-left-bottom {
|
|
&::before,
|
|
&::after {
|
|
left: -$border-size;
|
|
bottom: -$border-size;
|
|
}
|
|
}
|
|
.is-right-top {
|
|
&::before,
|
|
&::after {
|
|
right: -$border-size;
|
|
top: -$border-size;
|
|
}
|
|
}
|
|
.is-right-bottom {
|
|
&::before,
|
|
&::after {
|
|
right: -$border-size;
|
|
bottom: -$border-size;
|
|
}
|
|
}
|
|
|
|
// 内部网格线
|
|
.is-gridlines-x,
|
|
.is-gridlines-y {
|
|
width: 100%;
|
|
height: 100%;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
display: flex;
|
|
}
|
|
.is-gridlines-x {
|
|
justify-content: center;
|
|
&::before {
|
|
content: "";
|
|
display: inline-block;
|
|
width: 66.66%;
|
|
height: 200%;
|
|
border: 1px solid #fff;
|
|
border-top: none;
|
|
border-bottom: none;
|
|
transform: scale(0.5) translate(0, -50%);
|
|
}
|
|
}
|
|
// 内部网格线 - y轴
|
|
.is-gridlines-y {
|
|
align-items: center;
|
|
&::after {
|
|
content: "";
|
|
flex-shrink: 0;
|
|
display: inline-block;
|
|
width: 200%;
|
|
height: 66.66%;
|
|
border: 1px solid #fff;
|
|
border-left: none;
|
|
border-right: none;
|
|
transform: scale(0.5) translate(-50%, 0);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@include e(img) {
|
|
z-index: 2;
|
|
top: 0;
|
|
left: 0;
|
|
position: absolute;
|
|
border: none;
|
|
width: 100%;
|
|
backface-visibility: hidden;
|
|
transform-origin: center;
|
|
}
|
|
@include e(canvas) {
|
|
position: fixed;
|
|
background: white;
|
|
width: 150px;
|
|
height: 150px;
|
|
z-index: 10;
|
|
top: -200%;
|
|
pointer-events: none;
|
|
}
|
|
@include e(footer) {
|
|
position: fixed;
|
|
z-index: 10;
|
|
bottom: 10px;
|
|
width: 100%;
|
|
height: 15vh;
|
|
text-align: center;
|
|
@include m(button) {
|
|
position: relative;
|
|
text-align: left;
|
|
margin: 0 20px;
|
|
padding-top: 4vh;
|
|
// line-height: 32px;
|
|
box-sizing: border-box;
|
|
.is-cancel {
|
|
display: inline-block;
|
|
color: #fff;
|
|
font-size: 16px;
|
|
}
|
|
.is-confirm {
|
|
position: absolute;
|
|
right: 0;
|
|
// height: 32px;
|
|
width: 56px;
|
|
border-radius: 16px;
|
|
font-size: 16px;
|
|
}
|
|
}
|
|
}
|
|
}
|