淘宝网缩略图预览生成大图的代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>淘宝网鼠标放上小图生成大图的效果</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<style type="text/css">
div#PreviewBox{
  position:absolute;
  padding-left:6px;
  display: none;
  Z-INDEX:2006;
}
div#PreviewBox span{
  width:7px;
  height:13px;
  position:absolute;
  left:0px;
  top:9px;
  background:url() 0 0 no-repeat;
}
div#PreviewBox div.Picture{
  float:left;
  border:1px #666 solid;
  background:#FFF;
}
div#PreviewBox div.Picture div{
  border:4px #e8e8e8 solid;
}
div#PreviewBox div.Picture div a img{
  margin:19px;
  border:1px #b6b6b6 solid;
  display: block;
  max-height: 250px;
  max-width: 250px;
}
</style>
</head>
<body>
<script language="javascript" type="text/javascript">
var maxWidth=250;
var maxHeight=250;
function getPosXY(a,offset) {
       var p=offset?offset.slice(0):[0,0],tn;
       while(a) {
           tn=a.tagName.toUpperCase();
           if(tn=='IMG') {
              a=a.offsetParent;continue;
           }
          p[0]+=a.offsetLeft-(tn=="DIV"&&a.scrollLeft?a.scrollLeft:0);
          p[1]+=a.offsetTop-(tn=="DIV"&&a.scrollTop?a.scrollTop:0);
          if(tn=="BODY")
                break;
          a=a.offsetParent;
      }
      return p;
}
function checkComplete() {
     if(checkComplete.__img&&checkComplete.__img.complete)
              checkComplete.__onload();
}
checkComplete.__οnlοad=function() {
         clearInterval(checkComplete.__timeId);
         var w=checkComplete.__img.width;
         var h=checkComplete.__img.height;
         if(w>=h&&w>maxWidth) {
              previewImage.style.width=maxWidth+'px';
         }
        else if(h>=w&&h>maxHeight) {
              previewImage.style.height=maxHeight+'px';
        }
        else {
              previewImage.style.width=previewImage.style.height='';
        }
       previewImage.src=checkComplete.__img.src;previewUrl.href=checkComplete.href;checkComplete.__img=null;
}
function showPreview(e) {
         hidePreview (e);
         previewFrom=e.target||e.srcElement;
         previewImage.src=loadingImg;
         previewImage.style.width=previewImage.style.height='';
         previewTimeoutId=setTimeout('_showPreview()',500);
         checkComplete.__img=null;
}
function hidePreview(e) {
        if(e) {
            var toElement=e.relatedTarget||e.toElement;
            while(toElement) {
                  if(toElement.id=='PreviewBox')
                          return;
                  toElement=toElement.parentNode;
            }
       }
       try {
            clearInterval(checkComplete.__timeId);
            checkComplete.__img=null;
            previewImage.src=null;
       }
       catch(e) {}
       clearTimeout(previewTimeoutId);
       previewBox.style.display='none';
}
function _showPreview() {
        checkComplete.__img=new Image();
        if(previewFrom.tagName.toUpperCase()=='A')
               previewFrom=previewFrom.getElementsByTagName('img')[0];
        var largeSrc=previewFrom.getAttribute("large-src");
        var picLink=previewFrom.getAttribute("pic-link");
        if(!largeSrc)
             return;
        else {
             checkComplete.__img.src=largeSrc;
             checkComplete.href=picLink;
             checkComplete.__timeId=setInterval("checkComplete()",20);
             var pos=getPosXY(previewFrom,[106,26]);
             previewBox.style.left=pos[0]+'px';
             previewBox.style.top=pos[1]+'px';
             previewBox.style.display='block';
        }
}
</script>
<div id="PreviewBox" οnmοuseοut="hidePreview(event);">
  <div class="Picture" οnmοuseοut="hidePreview(event);">
   <span></span>
   <div>
    <a id="previewUrl" href="javascript:void(0)" target="_blank"><img οncοntextmenu="return(false)" id="PreviewImage" src="about:blank" border="0" οnmοuseοut="hidePreview(event);" /></a>
   </div>
  </div>
</div>
<script language="javascript" type="text/javascript">
var previewBox = document.getElementById('PreviewBox');
var previewImage = document.getElementById('PreviewImage');
var previewUrl = document.getElementById('previewUrl');
var previewFrom = null;
var previewTimeoutId = null;
var loadingImg = '/jscss/demoimg/loading.gif';
</script>
<a href="/" οnmοuseοver='showPreview(event);' οnmοuseοut='hidePreview(event);'>
<img src="/jscss/demoimg/wall_s7.jpg" alt="" large-src="/jscss/demoimg/wall7.jpg" pic-link="/"  border="0" width="100"/></a>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在安卓平台上,可以使用ffmpeg库来生成网络视频的缩略图。以下是一个简单的代码示例: ```java private void generateThumbnail(String videoUrl) { FFmpegMediaMetadataRetriever retriever = new FFmpegMediaMetadataRetriever(); retriever.setDataSource(videoUrl); // 获取视频时长 String durationStr = retriever.extractMetadata(FFmpegMediaMetadataRetriever.METADATA_KEY_DURATION); long duration = Long.parseLong(durationStr); // 获取第一帧的缩略图 Bitmap bitmap = retriever.getFrameAtTime(0); // 缩放图片 int width = bitmap.getWidth(); int height = bitmap.getHeight(); float scale = Math.min(200f / width, 200f / height); Matrix matrix = new Matrix(); matrix.postScale(scale, scale); Bitmap thumb = Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true); // 保存缩略图 String thumbPath = getApplicationContext().getCacheDir().getPath() + "/thumb.jpg"; try (FileOutputStream out = new FileOutputStream(thumbPath)) { thumb.compress(Bitmap.CompressFormat.JPEG, 90, out); } catch (IOException e) { e.printStackTrace(); } retriever.release(); } ``` 其中,FFmpegMediaMetadataRetriever是一个基于ffmpeg库的多媒体元数据获取器,可以用来获取视频的各种信息,包括时长、帧率等等。通过调用getFrameAtTime()方法可以获取视频的第一帧缩略图。最后,通过Bitmap对象的createBitmap()方法和compress()方法可以对缩略图进行缩放和保存。 ### 回答2: 安卓平台上生成网络视频的缩略图可以通过使用Android系统自带的MediaMetadataRetriever类来实现。 首先,我们需要在AndroidManifest.xml文件中添加读取网络和本地存储的权限: <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 然后,在生成缩略图的Activity中,我们可以使用以下代码来获取网络视频的缩略图: ```java String videoUrl = "网络视频的URL"; // 替换为你要获取缩略图的网络视频地址 Bitmap thumbnail = null; // 创建 MediaMetadataRetriever 对象 MediaMetadataRetriever retriever = new MediaMetadataRetriever(); try { // 设置要获取缩略图的视频地址 retriever.setDataSource(videoUrl, new HashMap<>()); // 获取第一帧的缩略图 thumbnail = retriever.getFrameAtTime(0); } catch (IllegalArgumentException e) { e.printStackTrace(); } finally { // 释放资源 retriever.release(); } // 在这里可以将缩略图显示在ImageView上或保存到本地 // imageView.setImageBitmap(thumbnail); // saveThumbnailToLocal(thumbnail); ``` 上述代码中,首先创建了一个MediaMetadataRetriever对象,然后使用setDataSource方法设置要获取缩略图的视频地址。接着,调用getFrameAtTime方法即可获取第一帧的缩略图。 获取到缩略图后,你可以选择将其显示在ImageView上或保存到本地。可以使用imageView.setImageBitmap方法将缩略图显示在ImageView上,或者编写一个saveThumbnailToLocal方法将缩略图保存到本地存储中。 需要注意的是,上述代码需要在后台线程中执行,以避免阻塞主线程。可以使用AsyncTask或其他异步方式执行该代码。 总结起来,要在安卓平台上生成网络视频的缩略图,可使用Android系统的MediaMetadataRetriever类来实现,通过设置要获取缩略图的视频地址并调用getFrameAtTime方法来获取第一帧的缩略图。最后,将缩略图显示在ImageView上或保存到本地即可。 ### 回答3: 在安卓系统中,我们可以使用一些库和技术来生成网络视频的缩略图。 首先,我们需要使用一个网络视频加载库,例如播放器库ExoPlayer或VideoView来加载网络视频。这些库提供了方便的接口来加载和处理网络视频。 一旦视频加载完成,我们可以使用Android的MediaMetadataRetriever类来提取视频的元数据。通过使用该类的getFrameAtTime()方法,我们可以获取视频的指定时间点的帧图像,并将其作为缩略图生成缩略图的过程可以通过以下步骤完成: 1. 初始化网络视频加载库,加载网络视频。 2. 在视频加载完成后,使用MediaMetadataRetriever类提取视频元数据。 3. 设定要提取缩略图的时间点,使用getFrameAtTime()方法获取该时间点的帧图像。 4. 将获取到的帧图像进行缩放和裁剪,生成所需的缩略图。 5. 可选择将缩略图保存到本地文件,以便之后使用。 需要注意的是,由于网络视频的大小和加载时间可能会有所不同,生成缩略图的效率和质量也可能会受到影响。为了更好的用户体验,可以考虑使用异步操作或后台线程来处理缩略图生成的过程。 总之,通过使用安卓的网络视频加载库和MediaMetadataRetriever类,我们可以方便地生成网络视频的缩略图并进行进一步处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值