当前位置:  互联网>综合
本页文章导读:
    ▪在ServletContextListener实现类中获取spring注入对象       由于项目需要,需在ServletContextListener监听接口实现类中调用spring注入的对象,以获取系统初始化参数.代码如下:   import java.io.IOException; import java.util.List; import javax.servlet.ServletContextEven.........
    ▪FFMPEG-Java 入门              注意:FFMPEG-Java 和 Jffmpeg 不是一回事。FFMPEG-Java 是 Freedom for Media in Java(缩写为 FMJ)的一个子项目。         这个项目遵循了 LGPL 许可。它具有可选的 GPL 组.........
    ▪KML中使用本地js文件模块      GE5.0以上版本的description块中能直接使用html+js+css,GE使用webkit渲染。但是有一个很大的问题。 GE为了避免开放本地文件访问带来的危险,直接把<script src=/blog_article/"localfile.js">的使用封........._/font/index.html>

[1]在ServletContextListener实现类中获取spring注入对象
    来源: 互联网  发布时间: 2013-10-24

由于项目需要,需在ServletContextListener监听接口实现类中调用spring注入的对象,以获取系统初始化参数.代码如下:

 

import java.io.IOException;
import java.util.List;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
import pams.model.Device;
import pams.service.Impl.DeviceManage;
import pams.socket.TcpManager;
import pams.socket.TcpServer;
/**
 * 系统初始化
 * @author 恶灵骑士
 *
 */
public class SysInitServlet implements ServletContextListener {
 //获取spring注入的bean对象
 private WebApplicationContext springContext;
 private DeviceManage deviceManager;
 
 //数据采集仪服务线程
 TcpServer daqServer = null;
 //继电器服务线程
 TcpServer realyServer = null;
 //Tcp连接管理器
 Thread tcpManager = null;
 
 public SysInitServlet(){
  super();
 }
 /**
  *应用程序退出时调用
  */
 @Override
 public void contextDestroyed(ServletContextEvent event) {
  serverDestroyed();
  System.out.println("应用程序关闭!");
 }
 
 /**
  * 应用程序加载时调用
  */
 @Override
 public void contextInitialized(ServletContextEvent event) {
  springContext = WebApplicationContextUtils.getWebApplicationContext(event.getServletContext());
  if(springContext != null){
   deviceManager = (DeviceManage)springContext.getBean("deviceManage");
  }else{
   System.out.println("获取应用程序上下文失败!");
   return;
  }
  System.out.println("初始化系统服务!");
  serverInitialized();
  System.out.println("TcpServer初始化完成!");
 }
 
 /**
  * 系统服务初始化
  * device_type:由于只需要知道采集仪,继电器端口号
  * 所以device_type设置为0
  */
 public void serverInitialized(){
       if(deviceManager == null){
            System.out.println("获取设备管理器失败!");
         return;
      }
      List<Device> devices = this.deviceManager.load(0);
     for(Device device : devices){
          System.out.println("设备ID-->"+device.getId());
          System.out.println("采集仪端口号-->"+device.getProperty1());
          System.out.println("继电器端口号-->"+device.getProperty2());
          System.out.println("所属大棚-->"+device.getShed().getName());
    }
     //开启串口服务器-数据采集仪监听线程
     TcpServer daqServer = new TcpServer(5678);
     TcpServer realyServer = new TcpServer(5679);
    tcpManager = new Thread(new TcpManager());
    if(daqServer.getServer() != null)
    {
        new Thread(daqServer).start();
    }
    if(realyServer.getServer()!=null){
        new Thread(realyServer).start();
   }
    tcpManager.start();
 }
 
 /**
  * 系统服务注销
  */
 @SuppressWarnings("deprecation")
 public void serverDestroyed(){
  
  if(daqServer!=null){
   try {
    daqServer.getServer().close();
   } catch (IOException e) {
    System.out.println("数据采集仪服务线程关闭出错 --> "+e.getMessage());
   }
  }
  if(realyServer!=null){
   try {
    realyServer.getServer().close();
   } catch (IOException e) {
    System.out.println("继电器服务线程关闭出错 --> "+e.getMessage());
   }
  }
  if(tcpManager!=null){
   tcpManager.stop();
  }
 }
}

springContext为spring管理的应用程序上下文,里面存储spring管理的各种bean对象.deviceManager就是通过spring注入的设备控制业务层.

注意事项:

1.  由于实现的是ServletContextListener接口,故需要实现public void contextInitialized(ServletContextEvent event)方法和public void contextDestroyed(ServletContextEvent event)方法.前者在应用程序加载时调用,里面添加一些初始化业务.如初始化springContext,调用serverInitialized()完成系统服务初始化,后者用于应用程序关闭时调用,主要完成服务资源的注销.

既然是listener接口就要在web.xml中配置相关参数,如下:

<listener>
   <listener-class>pams.servlet.SysInitServlet</listener-class>
  </listener>

2.  由于需获取spring管理bean,故该listner配置需要放在spring监听器配置之后,以使spring完成初始化,如下:

 

 <!--Spring ApplicationContext载入-->
  <listener>
      <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <!-- Spring ApplicationContext配置文件的路径,此参数用于后面的Spring-Contextloader -->
  <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:beans.xml</param-value>
  </context-param>
<!-- 系统服务初始化 -->
  <listener>
   <listener-class>pams.servlet.SysInitServlet</listener-class>
  </listener>

如果想在外部类中调用通过这种方法得到的spring对象,可以把springContext设为static,然后提供相应的get方法,此处由于不需要故设为private...

作者:qbg19881206 发表于2013-5-30 16:08:41 原文链接
阅读:61 评论:0 查看评论

    
[2]FFMPEG-Java 入门
    来源: 互联网  发布时间: 2013-10-24
        注意:FFMPEG-Java 和 Jffmpeg 不是一回事。FFMPEG-Java 是 Freedom for Media in Java(缩写为 FMJ)的一个子项目。
        这个项目遵循了 LGPL 许可。它具有可选的 GPL 组件来使用 FFMPEG 的 GPL swscale 库。如果你要使用 swscale 和 GPL,可以使用 ffmpeg-java-gpl.jar。这个项目的标准的 LGPL jar 是 ffmpeg-java.jar。
        FFMPEG-Java 是一个使用 JNA 对 FFMPEG 的封装。它假定关于 FFMPEG 的动态库已经被编译好,并且放在你的库路径。
        注意:本示例中禁用 mmx,因为它曾经造成了很多问题。
        步骤一:拿到 FFMPEG 源码 http://ffmpeg.mplayerhq.hu
        步骤二:构建/安装 FFMPEG
        ./configure --disable-mmx --enable-shared
        make
        sudo make install
        步骤三:使用一个多媒体文件作为第一个参数,运行示例程序之一。
        在一些 *nix 系统中,有时必须明确设置你的库路径。例如:
        export LD_LIBRARY_PATH=/usr/local/lib
        播放例子
        在一个窗口播放视频:
        java -cp ./ffmpeg-java.jar:./lib/jna.jar net.sf.ffmpeg_java.example.PlayerExample http://www.javasaver.com/testjs/jmf/anim/2005-11-26.mov
        视频编解码例子
        使用视频的前五帧在当前目录创建 5 ppm 的文件:
        java -cp ./ffmpeg-java.jar:./lib/jna.jar net.sf.ffmpeg_java.example.AVCodecSample http://www.javasaver.com/testjs/jmf/anim/2005-11-26.mov
        很好的关于设置编译环境的文档 - msys 和 mingw - 以及如何在 Windows 上构建 FFMPEG 可以在这里(打不开的话请翻墙)去查找。FFMPEG 提供的也可以,但一些关于图像编解码/格式(的内容)丢失了。
原文链接:http://fmj-sf.net/ffmpeg-java/getting_started.php。
作者:defonds 发表于2013-5-30 17:31:10 原文链接
阅读:77 评论:0 查看评论

    
[3]KML中使用本地js文件模块
    来源: 互联网  发布时间: 2013-10-24

GE5.0以上版本的description块中能直接使用html+js+css,GE使用webkit渲染。但是有一个很大的问题。

GE为了避免开放本地文件访问带来的危险,直接把<script src=/blog_article/"localfile.js">的使用封掉了。即使按照官方的设置方法,开放本地文件读取,仍然不能使用本地js。在无网络环境下,这个很扯啊,必须有本地js啊。_/p/index.html>

看网上大神们,直接在各个description里添加完整的js代码,果断不靠谱啊。如果有n个description,就是有n-1份无用信息!

很幸运的是,GE允许iframe的本地文件访问,而且支持套嵌!这就给本地js重用带来了希望。思路如下:

1.把js代码都放到一个仅有<script>标签的html文件中,js.html。

2.在使用js的页面中,加入iframe,src设为js.html,设置name为jsCall。

3.在调用js时,使用jsCall.window.function()的调用方法,而且function()。

大功告成。

整体结构如下:

doc.kml

|--placemark

---|--description

------|--iframe src=/blog_article/description.html_/p/index.html>

---------|--iframe src=/blog_article/js.html name=jsCall

---------call function:jsCall.window.function();

代码:

kml:

<Placemark>
	<name>Descriptive HTML</name>
        <visibility>1</visibility>
	<Point>
        	<coordinates>-122.0856545755255,37.42243077405461,0</coordinates>
        </Point>
        <description><![CDATA[
	<iframe src=/blog_article/"desc.html"></iframe>/index.html
]]></description>
</Placemark>


js.html

<script>
function c(btn){
	alert(btn.value);
	btn.value = "clicked";
}
</script>

desc.html

<iframe name = "jsCall" src=/blog_article/"js.html" width="0" height="0">
</iframe>
<script>
function c(btn){
	jsCall.window.c(btn);
}
</script>
<input type = "button" onclick="c(this)" value = "click"/>

GE测试通过,起码代码看起来漂亮很多。


作者:pouloghost 发表于2013-5-30 22:04:35 原文链接
阅读:44 评论:0 查看评论

    
最新技术文章:
▪用户及权限基础 2---- Linux权限    ▪用户及权限基础 3---- Linux扩展权限    ▪git 简明教程(1) --创建及提交
▪背包 代码    ▪json对象的封装与解析    ▪01背包,完全背包,多重背包 ,模板代码
▪apache安装详解    ▪HDU 4668 Finding string (解析字符串 + KMP)    ▪《TCP-IP详解 卷1:协议》学习笔记(二)
▪《TCP-IP详解 卷1:协议》学习笔记(持续更新...    ▪windows下使用swig    ▪gensim试用
▪Linux Shell脚本编程--nc命令使用详解    ▪solr对跨服务器表联合查询的配置    ▪递归和非递归实现链表反转
▪Linux磁盘及文件系统管理 1---- 磁盘基本概念    ▪Cholesky Decomposition    ▪HTTP协议学习
▪用C语言写CGI入门教程    ▪用hdfs存储海量的视频数据的设计思路    ▪java多线程下载的实现示例
▪【原创】eAccelerator 一个锁bug问题跟踪    ▪hadoop学习之ZooKeeper    ▪使用cuzysdk web API 实现购物导航类网站
▪二维数组中的最长递减子序列    ▪内嵌W5100的网络模块WIZ812MJ--数据手册    ▪xss 跨站脚本攻击
▪RobotFramework+Selenium2环境搭建与入门实例    ▪什么是API    ▪用PersonalRank实现基于图的推荐算法
▪Logtype    ▪关于端口号你知道多少!    ▪Linux基本操作 1-----命令行BASH的基本操作
▪CI8.7--硬币组合问题    ▪Ruby on Rails 学习(五)    ▪如何使用W5300实现ADSL连接(二)
▪不允许启动新事务,因为有其他线程正在该会...    ▪getting start with storm 翻译 第六章 part-3    ▪递归求排列和组合(无重复和有重复)
▪工具类之二:RegexpUtils    ▪Coding Interview 8.2    ▪Coding Interview 8.5
▪素因子分解 Prime factorization    ▪C# DllImport的用法    ▪图的相关算法
▪Softmax算法:逻辑回归的扩展    ▪最小生成树---Kruskal算法---挑战程序设计竞赛...    ▪J2EE struts2 登录验证
▪任意两点间的最短路径---floyd_warshall算法    ▪Sqoop实现关系型数据库到hive的数据传输    ▪FFMPEG采集摄像头数据并切片为iPhone的HTTP Stream...
▪Ubuntu 13.04 – Install Jetty 9    ▪TCP/IP笔记之多播与广播    ▪keytool+tomcat配置HTTPS双向证书认证
▪安装phantomjs    ▪Page Redirect Speed Test    ▪windows media player 中播放pls的方法
▪sre_constants.error: unbalanced parenthesis    ▪http headers    ▪Google MapReduce中文版
▪The TCP three-way handshake (connect)/four wave (closed)    ▪网站反爬虫    ▪Log4j实现对Java日志的配置全攻略
▪Bit Map解析    ▪Notepad 快捷键 大全    ▪Eclipse 快捷键技巧 + 重构
▪win7 打开防火墙端口    ▪Linux Shell脚本入门--awk命令详解    ▪Linux Shell脚本入门--Uniq命令
▪Linux(Android NDK)如何避免僵死进程    ▪http Content-Type一览表    ▪Redis实战之征服 Redis + Jedis + Spring (二)
▪Tomcat7.0.40 基于DataSourceRealm的和JDBCRealm的资源...    ▪利用SQOOP将ORACLE到HDFS    ▪django输出 hello world
▪python re    ▪unity3D与网页的交互    ▪内存共享基本演示
▪python join    ▪不再为无限级树结构烦恼,且看此篇    ▪python实现变参
▪打开文件数限制功能不断地制造问题    ▪Arduino Due, Maple and Teensy3.0 的 W5200性能测试    ▪Selenium实例----12306网站测试
▪基于协同过滤的推荐引擎    ▪C4.5决策树    ▪C#HTTP代理的实现之注册表实现
▪nosql和关系型数据库比较?    ▪如何快速比较这两个字符串是否相等?    ▪hdoj 1863 畅通工程 最小生成树---prime算法
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3