2012-03-07 24 views
6

Tôi đang tìm một giải pháp tốt về cách tạo một vignette effect cho một trang web. Các góc phải đậm hơn màu nền của trang giống như một hình tròn xuyên tâm.HTML/CSS: Cách tạo hiệu ứng họa tiết? 4 hình ảnh? CSS3 Gradient?

Cho đến nay tôi đã cố gắng tiếp cận khác nhau:

  • 4 DIV thiết lập để position: absolute, trên/dưới: 0px, trái/phải:. 0px với một hình ảnh trong mỗi trong số họ (hình ảnh chặn các liên kết ý tưởng Xấu nói chung?)
  • Tương tự như trên nhưng với chiều cao cố định/chiều rộng cho div và hình nền thay vì hình ảnh (vẫn chặn liên kết ?!)
  • CSS3 nhiều hình nền. Hai trên cơ thể cho trên cùng bên trái/phải và một div phụ ở phía dưới với chiều cao: 300; margin-top: -300px luôn luôn được hiển thị ở phía dưới (hỗ trợ trình duyệt kém)
  • CSS3 radial gradient on body (ngay sau đó . khi bạn di chuyển bạn mất nền An div thêm có thể khắc phục điều này cũng xấu hỗ trợ trình duyệt một lần nữa)

về hỗ trợ trình duyệt:. giải pháp phải làm việc trong phiên bản mới nhất của firefox, chrome, IE và nếu có thể opera và safari (được sắp xếp theo tầm quan trọng). Đó là mức tối thiểu tuyệt đối. Nhưng nó cũng thực sự hoạt động trên các trình duyệt cũ. Firefox 3.6 và IE 8 hoặc thậm chí 7 nếu có thể. Tôi không biết nhiều về lịch sử phiên bản chromes, nhưng có vẻ như người dùng Chrome gần như tất cả đều được cập nhật, vì vậy không có vấn đề gì lớn khi bỏ hỗ trợ cho chrome 15 trở xuống ?! Thậm chí có bất kỳ thay đổi quan trọng nào có thể làm cho một cái gì đó hoạt động trong chrome 17, nhưng không phải là ví dụ 15?

Độ nghiêng bố cục CSS3 theo ý kiến ​​của tôi là giải pháp tìm kiếm tốt nhất, nhưng tôi e rằng rất nhiều người dùng sẽ không hỗ trợ vì trình duyệt cũ của họ. Và với giải pháp 4 DIV, tôi gặp vấn đề với các liên kết không thể nhấp được, vì hình ảnh chặn nó. Tôi đã thử rối tung với chỉ số z, nhưng điều đó không hiệu quả. Tôi đã đưa chỉ số z của DIV: 1 và #container (nơi tất cả nội dung được đặt) chỉ mục z là 10. Không nên hoạt động? Chỉ số z-index có ảnh hưởng đến các liên kết không?

Vì vậy, các bạn nghĩ gì, sẽ là một giải pháp tốt? Tôi rõ ràng cần một số trợ giúp ở đây. Cảm ơn!

Trả lời

1

Tôi đã sử dụng kỹ thuật này được giải thích trong this blog trước đó và nó hoạt động thực sự tốt. Tuy nhiên, không chắc chắn về hỗ trợ cho các trình duyệt cũ.

+0

Tôi đã thấy điều này. Đó là những gì tôi đã thử lúc đầu, nhưng anh ấy có cùng một vấn đề, rằng nội dung của trang bị chặn bởi hiệu ứng. Vì vậy, các liên kết sẽ không thể nhấp được, v.v. "Bí quyết với kỹ thuật này chỉ sử dụng đúng số lượng chiều cao/chiều rộng. Quá nhiều và nội dung sẽ không thể chọn được trên tài khoản của các div có giá trị chỉ mục z cao". Và anh ấy đang sử dụng CSS3 với hầu như không có dự phòng. Tôi đã làm cho nó gần như giống nhau nhưng được sử dụng hình ảnh thay vì mã CSS3. Nhưng cảm ơn cho bài viết của bạn mặc dù :) – DiLer

1

tùy thuộc vào những gì bạn muốn, một cái gì đó như thế này có thể hoạt động;

<style> 

height: 100%; 
width: 100%; 
/* IE9 SVG, needs conditional override of 'filter' to 'none' */ 

background: url(); 

background: -moz-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 63%, rgba(0,0,0,0.65) 99%, rgba(0,0,0,0.65) 100%); /* FF3.6+ */ 

background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%,rgba(0,0,0,0)), color-stop(63%,rgba(0,0,0,0)), color-stop(99%,rgba(0,0,0,0.65)), color-stop(100%,rgba(0,0,0,0.65))); /* Chrome,Safari4+ */ 

background: -webkit-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 63%,rgba(0,0,0,0.65) 99%,rgba(0,0,0,0.65) 100%); /* Chrome10+,Safari5.1+ */ 

background: -o-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 63%,rgba(0,0,0,0.65) 99%,rgba(0,0,0,0.65) 100%); /* Opera 12+ */ 

background: -ms-radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 63%,rgba(0,0,0,0.65) 99%,rgba(0,0,0,0.65) 100%); /* IE10+ */ 

background: radial-gradient(center, ellipse cover, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 63%,rgba(0,0,0,0.65) 99%,rgba(0,0,0,0.65) 100%); /* W3C */ 

filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#a6000000',GradientType=1); /* IE6-8 fallback on horizontal gradient */ 


} 
</style> 

Hoạt động trên trình duyệt của tôi, sẽ hoạt động trên tất cả các trình duyệt. Nó chắc chắn, chắc chắn, nhưng cho phép bạn thiết lập điều này thành HTML, sau đó bạn có thể có cơ thể, ví dụ, với màu sắc hoặc hình ảnh mà bạn muốn.

Xem tính năng hoạt động tại đây. http://jsfiddle.net/joshuamartin/taN2Z/4/

http://www.colorzilla.com/gradient-editor/

+0

Tôi đã sử dụng một cái gì đó như thế này cho gradient CSS3 của tôi thử. Đó là trên thực tế cùng một trang (colorzilla). Tôi đã thử nhiều hơn một chút và có vẻ tốt trong firefox, chrome, opera và thậm chí cả IE9. Nhưng không có cách nào để thay đổi bộ lọc IE? Khi bạn thay đổi thanh trượt ở colorzilla, bộ lọc IE vẫn giữ nguyên. Tôi muốn làm cho các cạnh tối hơn một chút. Tôi loại bỏ các gradient IE, vì vậy nó chỉ là backgroundcolor + cạnh tối hơn trong IE9. Và tất nhiên không hỗ trợ cho các trình duyệt cũ hơn:/ Nhưng cảm ơn bạn đã trả lời. – DiLer

9

Bạn có thể sử dụng một bên trong hộp bóng

box-shadow: inset 0 0 100px #000; 

demo: http://jsfiddle.net/ACPUP/

Nhưng nó không hoạt động trong IE7/8.Các phiên bản cũ hơn của Firefox, Chrome, Safari hoặc Opera có thể cần tiền tố của chúng: -webkit-box-shadow, moz-box-shadow hoặc -o-box-shadow.

Bạn cũng có thể xếp các bóng này để có hiệu ứng ấn tượng hơn, nhưng tôi không biết liệu các phiên bản trình duyệt cũ có hỗ trợ điều đó không.

box-shadow: inset 0 0 120px #000, inset 0 0 80px #000, inset 0 0 40px #000; 
+0

Làm thế nào tốt là so với phương pháp gradient xuyên tâm CSS3? Hộp bóng có được hỗ trợ tốt hơn không? Dường như nó có hỗ trợ IE9 tốt hơn, phải không? Tôi có nên chọn một phương pháp khác không? Cảm ơn :) – DiLer

+0

độ phân giải css cần cú pháp khác nhau cho mỗi trình duyệt và được hỗ trợ trong ít trình duyệt hơn (/ phiên bản). IE9 không hỗ trợ gradient xuyên tâm, nhưng IE10 sẽ. – Willem

+0

Tôi đã sử dụng công cụ lọc SVG từ colorzilla cho IE9. Không phải là tốt nhất, nhưng nó hoạt động. Tôi nghĩ rằng cách tiếp cận của bạn là tốt hơn mặc dù. Hãy thử nó sau, nhờ :) – DiLer

1

Sử dụng CSS!

biến thể nhẹ về câu trả lời của Willem, theo khuyến cáo của JohnK người mũ nghiêng Chris Coyier:

box-shadow: inset 0 0 85px rgba(0, 0, 0, 0.4); 

JSFiddle: http://jsfiddle.net/charlesgoodwin/wKQ2y/

Nó hoạt động rất tốt!

Các vấn đề liên quan