使用Liferay DXP创建图片播放

Liferay DXP本身带有一个Carousel的模板,但是这个模板使用的是旧的AUI的模板。现在因为Liferay DXP是基于Lexicon和Bootstrap 3的,创建一个响应式的图片播放非常简单。

基本需求:
图片播放基本功能
屏幕尺寸变化后,图片不变型
修改图片不需要修改代码
不需要部署插件
可复用

分析:
可以利用Bootstrap 3的carousel插件实现图片播放基本功能。
可以利用Lexicon的Image Aspect Ratios保持图片的长宽比

可以利用Web Content来实现内容存储和模板化,同时可复用。

不需要额外的OSGi插件开发。JSON格式的structure和FTL格式的模板移植起来很容易。

1. 创建Web Content Structure

可以简单的创建一个web content structure。其中包含一个文本字段,用于设置长宽比,一个可重复的图片字段。


2. 创建对应的模板
我们可以直接为刚刚创建好的carousel structure创建一个模板。


3. 定义图片长宽比
参考Lexicon的文档,可以通过css为图片播放定义一个固定的长宽比。在我这里,长宽比可以通过structure设置,针对移动设备响应式的比例为了简单,我就直接写在模板中了。

<style>
 #carousel-<@portlet.namespace /> .aspect-ratio-custom {
  padding-bottom: ${aspectRatio.getData()};
 }
@media (max-width: 799px) {
     #carousel-<@portlet.namespace /> .aspect-ratio-custom {
      padding-bottom: 67%;
     }
 }
</style>

4. 实现Bootstrap的carousel和Lexicon的固定比例
可以直接参考Bootstrap的carousel的实现方式写HTML,CSS,并且通过freemarker循环写入图片。在图片所在的div中定义class为aspect-ratio和aspect-ratio-custom。

<#if image.getSiblings()?has_content>
 <section class="carousel-container">
  <div class="carousel slide" data-ride="carousel" id='carousel-<@portlet.namespace />'>
   <ol class="carousel-indicators hidden-sm hidden-xs">
    <#list image.getSiblings() as cur_img>
     <li class="${(cur_img?counter == 1)?then('active', '')}" data-slide-to="${(cur_img?counter == 1)?then(0, (cur_img?counter - 1))}" data-target='carousel-<@portlet.namespace />'></li>
    </#list>
   </ol>

   <div class="carousel-inner" role="listbox">
    <#list image.getSiblings() as cur_innerImage>
     <div class="${(cur_innerImage?counter == 1)?then('active', '')} item">
      <div class="aspect-ratio aspect-ratio-custom aspect-ratio-middle">
        <img alt="${cur_innerImage.getAttribute("alt")}" src="${cur_innerImage.getData()}">
      </div>
     </div>
    </#list>
   </div>

   <a class="left carousel-control" href='#carousel-<@portlet.namespace />' role="button" data-slide="prev">
    <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>

    <span class="sr-only">Previous</span>
   </a>

   <a class="right carousel-control" href='#carousel-<@portlet.namespace />' role="button" data-slide="next">
    <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>

    <span class="sr-only">Next</span>
   </a>
  </div>
 </section>
</#if>

5. 上传图片,添加web content
可以在Document and Media中新建个文件夹,然后上传一些图片

利用我们刚刚创建好的structure和template创建web content。在我这里我的Aspect Ratio是26%,即长度大概是宽度的4倍。



也可以使用Liferay内置的图片编辑器添加一些滤镜效果。



6. 预览并发布
创建完成之后,就可以发布了,然后可以使用Web Content Display portlet在页面上显示了。



你可以尝试改变浏览器尺寸,试试插件是否保持长宽比。

也可以使用Simulation工具来预览我们设置的响应式尺寸是否正常(67%)。



这样一个响应式的图片滚动插件就完成啦。
希望你能喜欢。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
框架特点: 1.完善的企业应用解决方案,包括表现层,业务逻辑层,报表,权限,日志,国际化,部署等企业应用的各个环节。 2.B/S,C/S优势互补,随需应变。 3.全新的模式开发C/S客户端,无需布局,无需调整控件和组件的大小,不懂Swing也可以快速开发界面。 4.Spring+Hibernate的轻量级架构轻松开发业务逻辑。 5.提升用户体验,提高最终用户满意度,快速开发企业应用。 配置开发环境 1导入开发项目 下载(http://www.soyframework.com)已经配置好的空项目,此空项目包括empty-client (以下简称示例client项目)、empty-server (以下简称示例server项目),并将它们导入到Eclipse中。如果Eclipse的Problems标签下没有出现错误那么表示项目成功导入。 如果使用其他的集成开发环境,请将client和server分别配置成java项目,且client依赖server。 2.1.2创建数据库 用户需要在自己的数据库管理系统中创建一个数据库,并确保此数据库实例能正常运行。示例项目使用的数据库为MYSQL,假定我们在MYSQL中创建数据库empty,并且创建用户empty,将数据库empty的所有权限授予给用户empty。 2.1.3配置hibernate 打开server项目下的hibernate.properties 文件,修改Hibernate数据库方言的配置(hibernate.dialect)为项目选用的数据库类型,如果采用是mysql 5.0数据库,设置为org.hibernate.dialect.MySQLDialect, 如果采用oracle9+数据库则设置为org.hibernate.dialect.Oracle9Dialect,如果是其他数据库请参考hibernate数据库方言。示例项目使用Mysql,故配置方言为org.hibernate.dialect.MySQLDialect。 打开server项目下的dataSourceConfig.xml文件,根据具体使用的数据库配置数据库连接池,下面列出了选用的数据库为Mysql时,连接池的配置: <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName"> <value>com.mysql.jdbc.Driver</value> </property> <property name="url"> <value>jdbc:mysql://${database.host}:${database.port}/empty?autoReconnect=true&useUnicode=true&characterEncoding=utf-8</value> </property> <property name="username"> <value>empty</value> </property> <property name="password"> <value>empty</value> </property> </bean> 在dataSourceConfig.properties中配置数据库服务器的主机地址和端口: database.host=localhost database.port=3306 2.1.4运行项目 开发时使用的应用服务器为Jetty,Server项目下的JettyLauncher.java已经配置了一个Jetty服务器,应用名默认为empty,端口使用8888(用户可以根据实际情况自行修改)。将JettyLauncher作为java application运行,启动服务器,如不出现异常,则server项目配置成功。 打开client项目下的ApplicationLauncher.java文件,作为java application 运行,启动客户端。如果出现设置管理员界面,则client项目配置成功。设置管理员后在用户登录界面以管理员身份登录后即出现系统主界面。 转http://hi.csdn.net/mysoy
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值