html從入門到賣電腦(三)

CSS3中和動畫有關的屬性有三個???transform、??transition?和?animation。下面來一一說明:?
?
????? transform??
?
從字面來看transform的釋義為改變,使…變形;轉換 。這里我們就可以理解為變形。那都能怎么變呢??
none 表示不進行變換;?
rotate 旋轉? ? ?? ? ?? transform:rotate(20deg) 旋轉角度可以為負數。需要先有transform-origin定義旋轉的基點可為left top center right bottom 或坐標值(50px 70px)。?
skew? 扭曲 ? ? ?? ?? ? transform:skew(30deg,30deg) ?skew(相對x軸傾斜,相對y軸傾斜)?
scale ?縮放 ? ? ?? ?? ? transform:scale(2,3) 橫向放大2倍,縱向放大3倍。如等比放大寫一個參數即可。?
translate?移動 ?? ??? transform:translate(50px, 50px);
matrix?矩陣變形 ? ??基本語法transform: matrix(a, c, b, d, tx, ty);其中a, c, b, d是一個二維矩陣:?

?

   ┌     ┐ │ a b ││ c d │└     ┘
a:X軸縮放比例 b:Y軸傾斜 c:Y軸縮放比例 d:X軸傾斜
 tx, ty就是就是基于X和Y 坐標重新定位元素。其實就是translate?(tx,ty)



?Transition???
W3C標準中對CSS3的transition這是樣描述的:“CSS的transition允許CSS的屬性值在一定的時間區間內平滑地過渡。這種效果可以在鼠標單擊、獲得焦點、被點擊或對元素任何改變中觸發,并圓滑地以動畫效果改變CSS的屬性值。
transition主要包含四個屬性值:

transition-property:?執行變換的屬性;
transition- duration:     ?變換延續的時間:
transition-timing-function:    在延續時間段,變換的速率變化;
transition- delay?:變換延遲時間
下面一一說明這四個屬性:
transition-property

語法:

transition-property : none | all | [ <IDENT> ]

transition-property是用來指定當元素其中一個屬性改變時執行transition效果,其 主要有以下幾個值:none(沒有屬 性改 變);all(所有屬性改變)這個也是其默認值;indent(元素屬性名);當其值為none時,transition馬上停止執行,當指定為all 時,則元素產生任何屬性值變化時都將執行transition效果,ident是可以指定元素的某一個屬性值。其對應的類型如下:?

1、color: 通過紅、綠、藍和透明度組件變換(每個數值單獨處理),如:background-color,border-color,color,outline-color等CSS屬性;

2、length:真實的數字,如:word-spacing,width,vertical- align,top,right,bottom,left,padding,outline-width,margin,min-width,min- height,max-width,max-height,line-height,height,border-width,border- spacing,background-position等屬性;

3、percentage:真實的數字,如:word-spacing,width,vertical- align,top,right,bottom,left,min-width,min- height,max-width,max-height,line-height,height,background-position等屬性;

4、integer 離散步驟(整個數字),在真實的數字空間,以及使用floor()轉換為整數時發生,如:outline-offset,z-index等屬性;

5、number真實的(浮點型)數值,如:zoom,opacity,font-weight等屬性;

6、transform list:詳情請參閱:《CSS3 Transform》。

7、rectangle:通過x、 y、 width和height(轉為數值)變換,如:crop;

8、visibility:離散步驟,在0到1數字范圍之內,0表示“隱藏”,1表示完全“顯示”,如:visibility;

9、shadow:作用于color、x、y、和blur(模糊)屬性,如:text-shadow;

10、gradient:通過每次停止時的位置和顏色進行變化。它們必須有相同的類型(放射狀的或是線性的)和相同的停止數值以便執行動畫,如:background-image;

11、paint server (SVG):只支持下面的情況:從gradient到gradient以及color到color,然后工作與上面類似;

12、space-separated list of above:如果列表有相同的項目數值,則列表每一項按照上面的規則進行變化,否則無變化;

13、a shorthand property:如果縮寫的所有部分都可以實現動畫,則會像所有單個屬性變化一樣變化。

支持執行transition效果的屬性:

Property NameType
background-coloras?color
background-positionas?repeatable list?of?simple list?of?length, percentage, or calc
border-bottom-coloras?color
border-bottom-widthas?length
border-left-coloras?color
border-left-widthas?length
border-right-coloras?color
border-right-widthas?length
border-spacingas?simple list?of?length
border-top-coloras?color
border-top-widthas?length
bottomas?length, percentage, or calc
clipas?rectangle
coloras?color
font-sizeas?length
font-weightas?font weight
heightas?length, percentage, or calc
leftas?length, percentage, or calc
letter-spacingas?length
line-heightas either?number?or?length
margin-bottomas?length
margin-leftas?length
margin-rightas?length
margin-topas?length
max-heightas?length, percentage, or calc
max-widthas?length, percentage, or calc
min-heightas?length, percentage, or calc
min-widthas?length, percentage, or calc
opacityas?number
outline-coloras?color
outline-widthas?length
padding-bottomas?length
padding-leftas?length
padding-rightas?length
padding-topas?length
rightas?length, percentage, or calc
text-indentas?length, percentage, or calc
text-shadowas?shadow list
topas?length, percentage, or calc
vertical-alignas?length
visibilityas?visibility
widthas?length, percentage, or calc
word-spacingas?length
z-indexas?integer
?

?

transition-duration

transition-duration是用來指定元素 轉換過程的持續時間,取值:<time>為數值,單位為s(秒),可以作用于所有元素,包括:before和:after偽元素。其默認值是0,也就是變換時是即時的。

transition-timing-function

? 取值:

transition-timing-function的值允許你根據時間的推進去改變屬性值的變換速率,transition-timing-function有6個可能值:

1、ease:(逐漸變慢)默認值,ease函數等同于貝塞爾曲線(0.25, 0.1, 0.25, 1.0);

2、linear:(勻速),linear 函數等同于貝塞爾曲線(0.0, 0.0, 1.0, 1.0);

3、ease-in:(加速),ease-in 函數等同于貝塞爾曲線(0.42, 0, 1.0, 1.0);

4、ease-out:(減速),ease-out 函數等同于貝塞爾曲線(0, 0, 0.58, 1.0);

5、ease-in-out:(加速然后減速),ease-in-out 函數等同于貝塞爾曲線(0.42, 0, 0.58, 1.0);

6、cubic-bezier:(該值允許你去自定義一個時間曲線), 特定的cubic-bezier曲線。 (x1, y1, x2, y2)四個值特定于曲線上點P1和點P2。所有值需在[0, 1]區域內,否則無效。

其是cubic-bezier為通過貝賽爾曲線來計算“轉換”過程中的屬性值,如下曲線所示,通過改變P1(x1, y1)和P2(x2, y2)的坐標可以改變整個過程的Output Percentage。初始默認值為default。

transition-delay

? transition-delay是用來指定一個動畫開始執行的時間,也就是說當改變元素屬性值后多長時間開始執行transition效果,取 值:<time>為數值,單位為s(秒),它的使用和transition-duration極其相似,也可以作用于所有元素,包 括:before和:after偽元素。 默認大小是”0″,也就是變換立即執行,沒有延遲。

有時我們不只改變一個CSS效果的屬性,而是想改變兩個或者多個CSS屬性的transition效果,那么我們只要把幾個transition的 聲明串 在一起,用逗號(“,”)隔開,然后各自可以有各自不同的延續時間和其時間的速率變換方式。但需要值得注意的一點:transition-delay與 transition-duration的值都是時間,所以要區分它們在連寫中的位置,一般瀏覽器會根據先后順序決定,第一個可以解析為時間的怭值為 transition-duration第二個為transition-delay。如:

? ?a {transition: background 0.5s ease-in,color 0.3s ease-out}

如果你想給元素執行所有transition效果的屬性,那么我們還可以利用all屬性值來操作,此時他們共享同樣的延續時間以及速率變換方式,如:

a{transition: all 0.5s ease-in}

}

?

?animation??

顧名思義為動畫的意思。Animation應用在頁面DOM上 使其產生動畫的效果。在開始介紹Animation之前我們有必要先來了解一個特殊的東西,那就是"Keyframes",我們把他叫做“關鍵幀”,玩過flash的朋友可能對這個東西并不會陌生。

一個官網的示例:

@-webkit-keyframes 'wobble' {0% {margin-left: 100px;background: green;}40% {margin-left: 150px;background: orange;}60% {margin-left: 75px;background: blue;}100% {margin-left: 100px;background: red;}}
這里我們定義了一個叫“wobble”的動畫,名字任意取。分幾個階段0% 40% 60% 100% 來過渡。

keyframes定義好了以后,就可以去調用定義好的動畫“wobble”了。

下面我們來看看怎么給一個元素調用animation屬性

  .demo1 {width: 50px;height: 50px;margin-left: 100px;background: blue;-webkit-animation-name:'wobble';/*動畫屬性名,也就是我們前面keyframes定義的動畫名*/-webkit-animation-duration: 10s;/*動畫持續時間*/-webkit-animation-timing-function: ease-in-out; /*動畫頻率,和transition-timing-function是一樣的*/-webkit-animation-delay: 2s;/*動畫延遲時間*/-webkit-animation-iteration-count: 10;/*定義循環資料,infinite為無限次*/-webkit-animation-direction: alternate;/*定義動畫方式*/}
 
animation-name:
animation-name:是用來定義一個動畫的名稱,為Keyframes中的名稱,否則不會有動畫效果。none為默認值,當值為none時,將沒有任何動畫效果。另外我們這個屬性跟前面所講的transition一樣,我們可以同時附幾個animation給一個元素,我們只需要用逗號“,”隔開。
 

CSS3的animation類似于transition屬性,他們都是隨著時間改變元素的屬性值。他們主要區別是transition需要觸發一 個事件(hover事件或click事件等)才會隨時間改變其css屬性;而animation在不需要觸發任何事件的情況下也可以顯式的隨著時間變化來 改變元素css的屬性值,從而達到一種動畫的效果。這樣我們就可以直接在一個元素中調用animation的動畫屬性,基于這一點,css3的 animation就需要明確的動畫屬性值,這也就是回到我們上面所說的,我們需要keyframes來定義不同時間的css屬性值,達到元素在不同時間 段變化的效果。

?


<script type="text/javascript"><!-- google_ad_client = "ca-pub-1944176156128447"; /* cnblogs 首頁橫幅 */ google_ad_slot = "5419468456"; google_ad_width = 728; google_ad_height = 90; //--></script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>

轉載于:https://www.cnblogs.com/hunterhu/p/6921884.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258615.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258615.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258615.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

visual studio 2015安裝 無法啟動程序,因為計算機丟失D3DCOMPILER_47.dll 的解決方法

對于題目中的解決方法&#xff0c;我查到了微軟提供的一個方案&#xff1a;https://support.microsoft.com/en-us/help/4019990/update-for-the-d3dcompiler-47-dll-component-on-windows 進入如下頁面&#xff1a;http://www.catalog.update.microsoft.com/Search.aspx?qKB4…

UI1_UIView層操作

// // ViewController.m // UI1_UIView層操作 // // Created by zhangxueming on 15/7/1. // Copyright (c) 2015年 zhangxueming. All rights reserved. //#import "ViewController.h"interface ViewController ()endimplementation ViewController- (void)view…

JavaScript Patterns 1 Introduction

1.1 Pattern "theme of recurring events or objects… it can be a template or model which can be used to generate things" (http://en.wikipedia.org/wiki/Pattern). ? Design patterns - Elements of Reusable Object-Oriented Software. ? Coding patte…

基于像素聚類的分割方法基于slic的方法_博士論文摘要 | 張榮春:數碼影像與TLS點云數據融合提取地質結構面方法研究...

《測繪學報》構建與學術的橋梁 拉近與權威的距離數碼影像與TLS點云數據融合提取地質結構面方法研究張榮春1,21.南京郵電大學地理與生物信息學院, 江蘇 南京 210023;2.河海大學地球科學與工程學院, 江蘇 南京 211100收稿日期&#xff1a;2019-03-27基金項目&#xff1a;國家自然…

制作IOS 后臺極光推送時,遇到的小問題

推送廣義上分為兩種&#xff0c; 一種是 程序在前臺的時候&#xff0c;不想在任務欄里面顯示通知&#xff0c;直接在app中進行某種操作。這個叫做自定義消息。這個是在前臺時&#xff0c;app與極光后臺建立了一個長鏈接。 另一種是 程序處于前、后臺 或者殺死狀態的時候&…

Visual Studio 2008 環境變量的配置(參考設置VS2010)

本文轉載自&#xff1a;http://blog.csdn.net/tracyliang223/article/details/21539361COPY FROM&#xff1a;http://www.cnblogs.com/waterlin/archive/2011/10/31/2230341.html 在調試 Visual Studio 2008 程序時&#xff0c;經常有一些動態鏈接庫&#xff08;即 dll 文件&am…

Linq 中 Any與All

昨天突然看到之前寫的一個積累文檔&#xff0c;其中文檔中有一個Linq Any和All的注意事項&#xff1a;注意Any 和 All var list new List<int>(); var aa list.All(n > n > 1); var bb list.Any(n > n > 1); // aa: true bb: false其中List是一個元…

jaxb轉xml空值雙標簽_單品運營思維:標簽-詞路-聚焦-直搜-超直

非標品標簽思維&#xff1a;針對非標品 主要是2.0為主的打法根據搜索入池的關鍵詞&#xff0c;有什么詞做什么詞。有個細節&#xff1a;不一定進什么詞做什么詞&#xff0c;這個維度當中加入3.0的思維3.0入手 轉2.0再切3.0(檢測詞路健康度&#xff0c;非嚴格意義估算單量)舉例&…

如何在PFSense中設置故障轉移和負載平衡

故障轉移是一種備份操作模式&#xff0c;僅在主系統由于系統故障或任何計劃停機時間而變得不可用時&#xff0c;系統組件&#xff08;如網絡&#xff09;的操作才由輔助系統承擔。在本教程中&#xff0c;我們將看到如何設置故障轉移和負載平衡&#xff0c;以使pfSense能夠將流量…

圖像金字塔總結

本文轉載自&#xff1a; http://blog.csdn.net/dcrmg/article/details/52561656 一、 圖像金字塔 圖像金字塔是一種以多分辨率來解釋圖像的結構&#xff0c;通過對原始圖像進行多尺度像素采樣的方式&#xff0c;生成N個不同分辨率的圖像。把具有最高級別分辨率的圖像放在底部…

表單的get和post使用情景

GET和POST兩種方法都是將數據送到服務器&#xff0c;但你該用哪一種呢&#xff1f;HTTP標準包含這兩種方法是為了達到不同的目的。POST用于創建資源&#xff0c;資源的內容會被編入HTTP請示的內容中。例如&#xff0c;處理訂貨表單、在數據庫中加入新數據行等。 當請求無副作用…

什么叫做羅列式_項目起盤的時候,如何確定自己該做什么社群?

這是祁杰『社群日記』第48篇持續日更&#xff0c;做最懂社群的營銷咨詢人很多人手上有資源&#xff0c;準備起盤項目的時候&#xff0c;總會思考一個問題&#xff1a;我能做什么樣的社群&#xff1f;今天我們從用戶需求出發&#xff0c;拆解一下哪些社群是能夠確切地滿足用戶的…

C++ exit 與 return 淺析

【摘要】 本文從代碼形式。經常使用方式&#xff0c;相關概念&#xff0c;調用關系和比較分析&#xff0c;這5個維度淺析 exit 與 return 在C的同樣點與差別。【常見形式】 exit(0)&#xff1a; 正常執行程序并退出程序。 exit(1)&#xff1a; 非正常執行導致退出程序&…

Feature Pyramid Networks for Object Detection 總結

最近在閱讀FPN for object detection,看了網上的很多資料&#xff0c;有些認識是有問題的&#xff0c;當然有些很有價值。下面我自己總結了一下&#xff0c;以供參考。 1. FPN解決了什么問題&#xff1f; 答&#xff1a; 在以往的faster rcnn進行目標檢測時&#xff0c;無論…

最近工作

最近的工作忙且亂&#xff0c;以至于&#xff0c;我第天早晨早早起來到晚上11點多才能回到家。今天早晨寫代碼的時候腰突然猛疼&#xff0c;疼的我直叫喚。躺在床上半天起不來。 最近每天的工作要計劃一下了&#xff0c;不能客戶說干嘛就干嘛&#xff0c;這樣累壞了自己&#x…

LeetCode OJ - Candy

題目&#xff1a; There are N children standing in a line. Each child is assigned a rating value. You are giving candies to these children subjected to the following requirements: Each child must have at least one candy.Children with a higher rating get mor…

那些 IT 界的神翻譯,原來我學不好編程的原因就在這

近日博主 ruanyf 在網上發布了一條關于套接字“socket”的解釋&#xff0c;引發了網友對于那些 IT 界的神翻譯的討論&#xff1a; 突然想到&#xff0c;socket就是插座。服務器的socket&#xff0c;就是服務器提供插座&#xff0c;等著客戶端的插頭插進來。一旦插入完成&#x…

navicat 結構同步會加鎖嗎_被柜員怠慢的張小波,真的會永久地轉走幾個億的結構性存款嗎?...

4月7日下午&#xff0c;北京鳳凰聯動文化傳媒有限公司總裁張小波發布微博稱&#xff0c;前幾天去安貞附近一銀行&#xff0c;想把借記卡的轉帳額度從每天五百萬上調一下&#xff0c;沒有想到&#xff0c;在其問到“最高可調到多少”時&#xff0c;柜員回答一個億并“鄙夷地看了…

Mask RCNN筆記

mask rcnn簡介 mask rcnn是何凱明基于以往的faster rcnn架構提出的新的卷積網絡&#xff0c;一舉完成了object instance segmentation. 該方法在有效地目標的同時完成了高質量的語義分割。 文章的主要思路就是把原有的Faster-RCNN進行擴展&#xff0c;添加一個分支使用現有的檢…

IOS開發之----常用函數和常數--秀清

介紹一下Objective-c常用的函數&#xff0c;常數變量 算術函數 【算術函數】函數名說明int rand()隨機數生成。&#xff08;例&#xff09;srand(time(nil)); //隨機數初期化int val rand()P; //0&#xff5e;49之間的隨機數int abs(int a)整數的絕對值&#xff08;例&#…