设为首页收藏本站|繁體中文

Project1

 找回密码
 注册会员
搜索
查看: 4074|回复: 14
打印 上一主题 下一主题

[有事请教] 视频标题插件PH_VideoTitle

[复制链接]

Lv5.捕梦者

梦石
0
星屑
20631
在线时间
123 小时
注册时间
2019-5-18
帖子
68
跳转到指定楼层
1
发表于 2019-11-12 17:26:51 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
500星屑
找到一个可以用视频做标题的插件
但是可能插件太久了,有语法错误了
本人是小白,恳请大佬们修复一下




插件
PH_VideoTitle.zip (1.58 KB, 下载次数: 100)





















貌似就是这一个地方的错误





影片标题
该插件可让您将视频放在标题屏幕的背景上,而不是静态图像。

安装
下载JS文件,并将其包含/plugins在项目的文件夹中。
打开插件管理器,选择文件PH_VideoTitle.js并将其打开。
使用Video Name参数定义要在背景中展示的视频的名称。该视频必须在/movies您项目的文件夹中(仅webm允许扩展)。
您可能需要在变量中定义可选的海报图像Video Poster Name。该图像应位于/img/pictures项目的文件夹中。
如何使用
您可以在此处通过示例查看完整的文档。
参量
Video Name:视频名称。
Video Muted:将标题中的视频静音(0:否,1:是)
Video Loop:使视频循环播放(0:否,1:是)
Video Poster Name:视频加载时要显示的图像的名称和扩展名(例如“ poster.png”)
Video Width:画布中视频的宽度(默认值:816)
Video Height:画布中视频的高度(默认值:624)
Video Coord X:画布中视频的X坐标(默认值:0)
Video Coord Y:画布中视频的Y坐标(默认值:0)
变更日志
2015年11月12日:版本1.1
2015年11月3日:README.md已更新
2015年11月2日:版本1.0

最佳答案

查看完整内容

拿去试试,我这找了个视频测试了下,有声音,可是没视频,是黑的,不知道是视频问题还是没改对,你先试试,要是你那也不行,我再看看什么情况。 编辑了下:把代码折叠了,不然好大一篇; 编辑了下:黑屏问题已经解决,屏蔽播放和暂停按钮即可,经过测试,静音、循环功能是完好的,我这视频文件较小,所以哪个poster image没看到效果; 遗留问题:不能控制播放和暂停; 测试环境,rmmv1.6.1; 编辑了下:新增增强优化版标题页面视频 ...

Lv4.逐梦者

梦石
0
星屑
14229
在线时间
718 小时
注册时间
2011-7-16
帖子
1428

开拓者

2
发表于 2019-11-12 17:26:52 | 只看该作者
本帖最后由 walf_man 于 2019-11-15 13:09 编辑

拿去试试,我这找了个视频测试了下,有声音,可是没视频,是黑的,不知道是视频问题还是没改对,你先试试,要是你那也不行,我再看看什么情况。
编辑了下:把代码折叠了,不然好大一篇;
编辑了下:黑屏问题已经解决,屏蔽播放和暂停按钮即可,经过测试,静音、循环功能是完好的,我这视频文件较小,所以哪个poster image没看到效果;
遗留问题:不能控制播放和暂停;

测试环境,rmmv1.6.1;
编辑了下:新增增强优化版标题页面视频背景插件:RMMV标题页面用视频做背景的插件

代码

点评

多谢大佬,完美解决问题  发表于 2019-11-15 00:39
RMMV网络插件,开源免费,内含服务器端,无需强制登录,云数据,弹幕,云存档,排名,兑换码,版本检测,可自由上架下架删除。q群399090587
免打包运行MV游戏,云游戏,安卓App雷神游戏厅,在线玩游戏,上传下载游戏
开源游戏:重装机兵之重装归来【RMMV制作】全球首款按照美剧分季分集的方式发布的游戏
体素画 -- MV画3D像素图的画板
RMMV显示3D模型和场景的插件
RMMV显示spine骨骼动画的插件
RMMV秘密通道插件
突破敌群数量上限8个的插件
在rmmv中显示gif动态图片的插件
一款可以在mv游戏界面的任意位置显示任意文字的插件
RMMV Toast 插件 带物品得失提示,可以设置开启关闭 兼容yep itemcore
制作一个改名卡道具插件、调整标题页面菜单的插件、在标题页面之前显示大段文字的插件、标题页面显示版本号的插件
物品得失自动提示自动上色自动换行插件
我的Q群 663889472
另外,我的插件、范例、游戏都在这里
回复

使用道具 举报

Lv2.观梦者

梦石
0
星屑
451
在线时间
64 小时
注册时间
2019-8-9
帖子
9
3
发表于 2019-11-12 22:06:37 手机端发表。 | 只看该作者
更明显了,PixiJs版本老了,回去改一下,

点评

改了是黑屏,然后屏蔽了下面两个 是显视频第一帧图片,不播放视频啊  发表于 2019-11-13 01:44
新版已经不用PIXI.VideoTexture.textureFromVideo这样的写法了,改用PIXI.Texture.from或PIXI.Texture.fromVideo这样的写法了,而PIXI.Texture.fromVideo也在pixijsV5中将被弃用  发表于 2019-11-12 23:42
神了 您怎么看出来的?  发表于 2019-11-12 23:37
回复

使用道具 举报

Lv5.捕梦者

梦石
0
星屑
20631
在线时间
123 小时
注册时间
2019-5-18
帖子
68
4
 楼主| 发表于 2019-11-13 01:40:58 | 只看该作者
walf_man 发表于 2019-11-12 23:38
拿去试试,我这找了个视频测试了下,有声音,可是没视频,是黑的,不知道是视频问题还是没改对,你先试试, ...

大佬,现在是有声音,但不能播放视频啊,
只显示视频开始的那一帧图片啊,
求大佬解决一下,

点评

试试楼下的代码,楼下大神增加了个update  发表于 2019-11-13 16:02
我编辑了两次,第二次编辑已经解决了播放视频只有声音没有画面的问题,现在我准备编辑第三次,因为我写了个增强版。  发表于 2019-11-13 02:36
回复

使用道具 举报

Lv2.观梦者

梦石
0
星屑
451
在线时间
64 小时
注册时间
2019-8-9
帖子
9
5
发表于 2019-11-13 09:54:55 | 只看该作者
/*:

PH - Video Title
@plugindesc This plugin allows you to put a video at the background of the Title Screen instead of a static image.
@author PrimeHover
@version 1.1
@date 11/12/2015

---------------------------------------------------------------------------------------
This work is licensed under the Creative Commons Attribution 4.0 International License.
To view a copy of this license, visit http://creativecommons.org/licenses/by/4.0/
---------------------------------------------------------------------------------------

@param Video Name
@desc Name of the video (See Help Section) | (E.g. "myVideo")

@param Video Muted
@desc Mutes the video in the title (0: No, 1: Yes)
@default 0

@param Video Loop
@desc Makes the video plays in a loop (0: No, 1: Yes)
@default 1

@param Video Poster Name
@desc Name and extension of the image to be shown when the video is loading (E.g. "poster.png")

@param Video Width
@desc Width of the video in the canvas (Default: 816)
@default 816

@param Video Height
@desc Height of the video in the canvas (Default: 624)
@default 624

@param Video Coord X
@desc Coordinate X of the video in the canvas (Default: 0)
@default 0

@param Video Coord Y
@desc Coordinate Y of the video in the canvas (Default: 0)
@default 0

@help

The video you want to play in background must be inside the "movies" folder in your project.
Supported extensions: "webm"

The poster you want to show while the video is not ready must be inside the "pictures" folder in your project.


Maintenance by Mikan on 2019.11.13
For PixiJs v4

*/

(function() {

    /* Getting the parameters */
    var parameters = PluginManager.parameters('PH_VideoTitle');
    var videoName = String(parameters['Video Name']);
    var posterName = String(parameters['Video Poster Name']);
    var videoMuted = Number(parameters['Video Muted']);
    var videoLoop = Number(parameters['Video Loop']);
    var videoWidth = Number(parameters['Video Width']);
    var videoHeight = Number(parameters['Video Height']);
    var videoX = Number(parameters['Video Coord X']);
    var videoY = Number(parameters['Video Coord Y']);

    /* Video Title Class */
    var PH_VideoTitle = null;

    function VideoTitle() {
        this.name = videoName;
        this.posterName = posterName;

        this.setVideoTexture();
    }
    VideoTitle.prototype.constructor = VideoTitle;

    VideoTitle.prototype.setControlOptions = function() {
        if (videoLoop == 1) {
            this._video.loop = true;
        } else {
            this._video.loop = false;
        }

        if (videoMuted == 1) {
            this._video.muted = true;
        } else {
            this._video.muted = false;
        }

        if (posterName.trim() != '') {
            this._video.poster = 'img/pictures/' + this.posterName;
        }
    };

    VideoTitle.prototype.getVideoSrc = function() {
        return 'movies/' + this.name + '.webm';
    }

    VideoTitle.prototype.setVideoTexture = function() {
        this._texture = PIXI.Texture.from(this.getVideoSrc());

        this._video = this._texture.baseTexture.source;
        this.setControlOptions();

        this._texture.baseTexture.source.pause();

        this._spriteVideo = new PIXI.Sprite(this._texture);
        this._spriteVideo.width = videoWidth;
        this._spriteVideo.height = videoHeight;
        this._spriteVideo.x = videoX;
        this._spriteVideo.y = videoY;
    };

    VideoTitle.prototype.pauseVideo = function() {
        this._video.pause();
    };

    VideoTitle.prototype.playVideo = function() {
        this._video.play();
    };

    VideoTitle.prototype.update = function() {
        this._texture.update();
    };


    /* Overwritten Scene_Title methods */
    Scene_Title.prototype.create = function() {

        /* Prevent the video to be duplicated */
        if (PH_VideoTitle === null) {
            PH_VideoTitle = new VideoTitle();
        }
        this.videoTitle = PH_VideoTitle;
        this.addChild(this.videoTitle._spriteVideo);
        this.createForeground();
        this.createWindowLayer();
        this.createCommandWindow();
    };

    Scene_Title.prototype.start = function() {
        Scene_Base.prototype.start.call(this);
        SceneManager.clearStack();
        if (videoMuted == 1) {
            this.playTitleMusic();
        }
        this.startFadeIn(this.fadeSpeed(), false);
    };

    Scene_Title.prototype.terminate = function() {
        Scene_Base.prototype.terminate.call(this);
        this.videoTitle.pauseVideo();
        SceneManager.snapForBackground();
    };

    var _MK_Scene_Title_update = Scene_Title.prototype.update;
    Scene_Title.prototype.update   = function() {
       _MK_Scene_Title_update.call(this);
       this.videoTitle.update();
    };

})();

点评

大佬你这个能播放视频,但是打开设置或者进入游戏再返回标题界面就又变成静态图片了  发表于 2019-11-15 00:38
回复

使用道具 举报

Lv2.观梦者

梦石
0
星屑
451
在线时间
64 小时
注册时间
2019-8-9
帖子
9
6
发表于 2019-11-13 09:57:12 | 只看该作者

适应了RMMV的pixiJS v4版本

点评

感谢大佬指点,仔细对比了和你的代码的区别,除了你的闭包,我的没闭包,发现没什么其它不同,我闭包之后,应该就没问题了。  发表于 2019-11-15 13:15
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

拿上你的纸笔,建造一个属于你的梦想世界,加入吧。
 注册会员
找回密码

站长信箱:[email protected]|手机版|小黑屋|无图版|Project1游戏制作

GMT+8, 2024-5-3 16:45

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表