`
mutongwu
  • 浏览: 454624 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

MultiselectItemSelector 多选框

    博客分类:
  • Ext
阅读更多

改造自MultiselectItemSelector(http://extjs.com/learn/Extension:Multiselect)。
原有代码在关闭该控件以后,会遗留大量无效代码,因此,自己用一个 panel + 2个grid来实现,暂不支持拖拽。

Ext.namespace('Ext.ux')
Ext.ux.IconPanel = function(config){
    Ext.apply(this,config);
    Ext.ux.IconPanel.superclass.constructor.call(this,config);
}

Ext.extend(Ext.ux.IconPanel,Ext.Panel,{
    imagePath:'',
    drawUpIcon:true,
    drawDownIcon:true,
    drawLeftIcon:true,
    drawRightIcon:true,
    drawTopIcon:true,
    drawBotIcon:true,
    
    //style: 'padding-left:5px;padding-right:5px',
    
    initComponent: function(){
    
        Ext.ux.IconPanel.superclass.initComponent.call(this);
        this.addEvents(
            ''
        )
    },
    onRender: function(ct, position){
       Ext.ux.IconPanel.superclass.onRender.call(this,ct,position);
       
       if (this.imagePath!="" && this.imagePath.charAt(this.imagePath.length-1)!="/")
            this.imagePath+="/";
        this.iconUp = this.imagePath + (this.iconUp || 'up2.gif');
        this.iconDown = this.imagePath + (this.iconDown || 'down2.gif');
        this.iconLeft = this.imagePath + (this.iconLeft || 'left2.gif');
        this.iconRight = this.imagePath + (this.iconRight || 'right2.gif');
        this.iconTop = this.imagePath + (this.iconTop || 'top2.gif');
        this.iconBottom = this.imagePath + (this.iconBottom || 'bottom2.gif');
        var el= this.getEl();
        if (!this.toSortField) {
            this.toTopIcon = el.createChild({tag:'img', src:this.iconTop, style:{cursor:'pointer', margin:'2px'}});
            el.createChild({tag: 'br'});
            this.upIcon = el.createChild({tag:'img', src:this.iconUp, style:{cursor:'pointer', margin:'2px'}});
            el.createChild({tag: 'br'});
        }
        this.addIcon = el.createChild({tag:'img', src:this.switchToFrom?this.iconLeft:this.iconRight, style:{cursor:'pointer', margin:'2px'}});
        el.createChild({tag: 'br'});
        this.removeIcon = el.createChild({tag:'img', src:this.switchToFrom?this.iconRight:this.iconLeft, style:{cursor:'pointer', margin:'2px'}});
        el.createChild({tag: 'br'});
        if (!this.toSortField) {
            this.downIcon = el.createChild({tag:'img', src:this.iconDown, style:{cursor:'pointer', margin:'2px'}});
            el.createChild({tag: 'br'});
            this.toBottomIcon = el.createChild({tag:'img', src:this.iconBottom, style:{cursor:'pointer', margin:'2px'}});
        }
        if (!this.readOnly) {
            if (!this.toSortField) {
                this.toTopIcon.on('click', this.toTop, this);
                this.upIcon.on('click', this.up, this);
                this.downIcon.on('click', this.down, this);
                this.toBottomIcon.on('click', this.toBottom, this);
            }
            this.addIcon.on('click', this.fromTo, this);
            this.removeIcon.on('click', this.toFrom, this);
        }
        if (!this.drawUpIcon || this.hideNavIcons) { this.upIcon.dom.style.display='none'; }
        if (!this.drawDownIcon || this.hideNavIcons) { this.downIcon.dom.style.display='none'; }
        if (!this.drawLeftIcon || this.hideNavIcons) { this.addIcon.dom.style.display='none'; }
        if (!this.drawRightIcon || this.hideNavIcons) { this.removeIcon.dom.style.display='none'; }
        if (!this.drawTopIcon || this.hideNavIcons) { this.toTopIcon.dom.style.display='none'; }
        if (!this.drawBotIcon || this.hideNavIcons) { this.toBottomIcon.dom.style.display='none'; }

    },
    
    toTop:function(){
        this.gridsHolder.fireEvent('toTop');
    },
    toBottom: function(){
        this.gridsHolder.fireEvent('toBottom');
    },
    up: function(){
        this.gridsHolder.fireEvent('up');
    },
    down: function(){
        this.gridsHolder.fireEvent('down');
    },
    fromTo: function(){
        this.gridsHolder.fireEvent('fromTo');
    },
    toFrom: function(){
        this.gridsHolder.fireEvent('toFrom');
    },

    setGridsHoder: function(gridsHolder){
        this.gridsHolder = gridsHolder;
    }
});
Ext.ux.MultiSelectWin = function(config){
	Ext.apply(this,config);
	Ext.ux.MultiSelectWin.superclass.constructor.call(this, config);
	this.init();
};

Ext.extend(Ext.ux.MultiSelectWin, Ext.util.Observable,{
	
	title : '选择窗口',
	from_legend:'可选',
	to_legend: '已选',
	valueField: 'id',
	displayField: 'name',
    warningTitle: '提示',
    minLength:0,
    maxLength:Number.MAX_VALUE,
    minLengthText:'至少应选择{0}项',
    maxLengthText:'最多只能选择 {0}项',
    /**
     * 图标面板的config
     * @type {}
     */
    iconConfig:{},
	targetItem: null,
    localData:[],
	selectedData: [],
    saveFn: Ext.emptyFn,
	searchFn: Ext.emptyFn,
	baseParams: null,
	fieldName: null,

    toSortField:null,
    fromSortField:null,
    toSortDir:'ASC',
    fromSortDir:'ASC',
    allowDup: false,
    
	switchToFrom:false,
	openHeight:320,
	openWidth:460,
	ms_height:220,
	ms_width:200,


	init: function(){
		this.initDataStore();
		
		this.initComponent();
	},
	
	initDataStore: function(){
		var record = Ext.data.Record.create([
			{
				name: this.valueField,
				type: 'string'
			},{
				name: this.displayField,
				type: 'string'
		}]);
		if (this.localMode == true){
			this.fromStore  = new Ext.data.SimpleStore({
	            fields:[this.valueField, this.displayField]
	        });
		}
		else{
			var baseParams = {
					dir : 'asc',
					start : 0,
					limit : 0
				};

			if (this.baseParams)
				baseParams = this.baseParams;

			this.fromStore  = new Ext.data.Store({
				proxy: new Ext.data.DWRProxy(this.searchFn, true),
				reader: new Ext.data.ListRangeReader({
					totalProperty : 'total',
					id : 'id'
				},record),
				sortInfo:{field:this.displayField,direction:'ASC'},
				baseParams : baseParams
			});
		}
		
        this.selectedData = this.targetItem.getArrayValue();       
		this.toStore = new Ext.data.SimpleStore({
			fields:[this.valueField, this.displayField],
			data: this.selectedData
		});
		
        if(this.allowDup == false){
	        this.fromStore.on('load',function(){
	            this.fromStore.filterBy(function(record){
	                    for (var i=0;i < this.selectedData.length;i++){
	                        if(this.selectedData[i][0] == record.get(this.valueField))
	                            return false;
	                    }
	                    return true;
	                },this);    
	        },this);
        }
		
		if(this.localMode == true)
            this.fromStore.loadData(this.localData);
        else
            this.fromStore.load();
		
	},
	
	reComputeWH: function(){
		this.openHeight = this.openHeight;
		this.openWidth = this.openWidth;
		this.ms_height = this.openHeight - 100;
		this.ms_width = (this.openWidth-60)/2;
	},
    createIconsPanel: function(){
        this.iconsPanel = new Ext.ux.IconPanel(this.iconConfig);
        this.iconsPanel.setGridsHoder(this);        
    },
	initComponent: function(){
       
        if(this.openHeight || this.openWidth){
            this.reComputeWH();
        }
        this.addEvents(
                /**
                 * @event
                 */
                'destroy',

                /**
                 * @event
                 */
                'toTop',

                /**
                 * @event
                 */
                'toBottom',

                /**
                 * @event
                 */
                'up',

                /**
                 * @event
                 */
                'down',

                /**
                 * @event
                 */
                'fromTo',

                /**
                 * @event
                 */
                'toFrom');

        this.on('destroy', this.onDestroy, this);
        this.on('up', this.onUp, this);
        this.on('down', this.onDown, this);
        this.on('toTop', this.onToTop, this);
        this.on('toBottom', this.onToBottom, this);
        this.on('fromTo', this.onFromTo, this);
        this.on('toFrom', this.onToFrom, this);
        
        
        this.fromGrid = new Ext.grid.GridPanel({
            title : '可选',
            hideHeaders:true,
            width : this.ms_width,
            height: this.ms_height,
            autoExpandColumn:'name',
            layout : 'fit',
            sm : new Ext.grid.RowSelectionModel(),
            ds : this.fromStore,
            cm : new Ext.grid.ColumnModel([{
	            header : "header",
	            sortable : true,
	            dataIndex : this.displayField
	        }]),
            viewConfig:{forceFit:true}
        })

        this.fromGrid.on('rowdblclick', this.onFromGriddblclick, this);
        
        this.toGrid = new Ext.grid.GridPanel({
            title : '已选',
            hideHeaders:true,
            width : this.ms_width,
            height: this.ms_height,
            autoExpandColumn:'name',
            layout : 'fit',
            sm : new Ext.grid.RowSelectionModel(),
            ds : this.toStore,
            cm : new Ext.grid.ColumnModel([{
                header : "header",
                sortable : true,
                dataIndex : this.displayField
            }]),
            viewConfig:{forceFit:true}
        })
        
        this.toGrid.on('rowdblclick', this.onToGriddblclick, this);
        
        this.createIconsPanel();
        this.parentPanel = new Ext.Panel({
            layout:"table",
            layoutConfig:{columns:3},
            items: [this.fromGrid,this.iconsPanel,this.toGrid],
            frame: true
        });       

        this.selectorWin = new Ext.Window({
            frame: true,
            resizable:false,
            title : this.title,
            layout:'fit',
            modal: true,
            items : [this.parentPanel],
            width: this.openWidth,
            height: this.openHeight,
            buttonAlign:'center',
            buttons:[{
                text: '确定',
                handler: function(){
                  var records = this.toStore.getRange();
                  if(this.validateValue(records) == false)
                     return;
                  var values = [];
                  var selectedValue = '';
                  var selectedText = '';
                  
                  for (var i=0; i < records.length; i++){
                    var temp = [];
                    var v = records[i].get(this.valueField);
                    var t = records[i].get(this.displayField);
                    temp.push(v);
                    temp.push(t);
                    values.push(temp);
                    
                    if(selectedValue == ''){
                       selectedValue = v;
                       selectedText = t;
                    }
                    else{
                        selectedValue = selectedValue + ',' + v;
                        selectedText = selectedText + ',' + t;
                    }
                  }
                  this.targetItem.setValue(values);
                  var formValues = queryPanel.getFormValues();
                  Ext.apply(formValues,this.baseParams);
                  formValues.selectedValue = selectedValue;
                  formValues.selectedText = selectedText;
                  var fn = this.saveFn.createSequence(function(returnData){});
                  fn(formValues);
                  
                  this.selectorWin.close();
                },
                scope:this
            },{ 
                text:'取消',
                handler: function(){
                    this.selectorWin.close();
                },
                scope: this
            }]
        })
        
        this.selectorWin.show();
    },
    
    validateValue : function(value){
        if (value.length < this.minLength) {
            Ext.Msg.show({
               title: this.warningTitle,
               msg: String.format(this.minLengthText, this.minLength),
               buttons: Ext.Msg.OK,
               icon: Ext.MessageBox.INFO
            });
            return false;
        }
        if (value.length > this.maxLength) {
            Ext.Msg.show({
               title: this.warningTitle,
               msg: String.format(this.maxLengthText, this.maxLength),
               buttons: Ext.Msg.OK,
               icon: Ext.MessageBox.INFO
            });
            return false;
        }
        return true;
    },
    onFromGriddblclick: function(){
        this.fireEvent('fromTo');
    },
    onToGriddblclick: function(){
        this.fireEvent('toFrom');
    },
    onUp:function(){
        var store = this.toStore;
        var sm = this.toGrid.getSelectionModel();
        var data = sm.getSelections();
        
        var selectionsArray = [];
        for (var i=0; i < data.length; i++){
            selectionsArray.push(store.indexOf(data[i]));
        }
        var record = null;
        selectionsArray.sort();
        var newSelectionsArray = [];
        if (selectionsArray.length > 0) {
            for (var i=0; i<selectionsArray.length; i++) {
                record = store.getAt(selectionsArray[i]);
                if ((selectionsArray[i] - 1) >= 0) {
                    store.remove(record);
                    store.insert(selectionsArray[i] - 1, record);
                    newSelectionsArray.push(selectionsArray[i] - 1);
                }
            }
           this.toGrid.getView().refresh();
           sm.selectRows(newSelectionsArray);
        }    
    },
    onDown: function(){
        var store = this.toStore;
        var sm = this.toGrid.getSelectionModel();
        var data = sm.getSelections();
        
        var selectionsArray = [];
        for (var i=0; i < data.length; i++){
            selectionsArray.push(store.indexOf(data[i]));
        }
        var record = null;
        selectionsArray.sort();
        selectionsArray.reverse();
        var newSelectionsArray = [];
        if (selectionsArray.length > 0) {
            for (var i=0; i<selectionsArray.length; i++) {
                record = store.getAt(selectionsArray[i]);
                if ((selectionsArray[i] + 1) < store.getCount()) {
                    store.remove(record);
                    store.insert(selectionsArray[i] + 1, record);
                    newSelectionsArray.push(selectionsArray[i] + 1);
                }
            }
            this.toGrid.getView().refresh();
            sm.selectRows(newSelectionsArray);
        }
    },
    onToTop: function(){
        var store = this.toStore;
        var sm = this.toGrid.getSelectionModel();
        var data = sm.getSelections();
        
        var selectionsArray = [];
        for (var i=0; i < data.length; i++){
            selectionsArray.push(store.indexOf(data[i]));
        }
        var records = [];
        if (selectionsArray.length > 0) {
            selectionsArray.sort();
            for (var i=0; i<selectionsArray.length; i++) {
                record = store.getAt(selectionsArray[i]);
                records.push(record);
            }
            selectionsArray = [];
            for (var i=records.length-1; i>-1; i--) {
                record = records[i];
                store.remove(record);
                store.insert(0, record);
                selectionsArray.push(((records.length - 1) - i));
            }
        }
        this.toGrid.getView().refresh();
        sm.selectRows(selectionsArray);
     },
    onToBottom: function(){
        var store = this.toStore;
        var sm = this.toGrid.getSelectionModel();
        var data = sm.getSelections();
        
        var selectionsArray = [];
        for (var i=0; i < data.length; i++){
            selectionsArray.push(store.indexOf(data[i]));
        }
        var records = [];
        if (selectionsArray.length > 0) {
            selectionsArray.sort();
            for (var i=0; i<selectionsArray.length; i++) {
                record = store.getAt(selectionsArray[i]);
                records.push(record);
            }
            selectionsArray = [];
            for (var i=0; i<records.length; i++) {
                record = records[i];
                store.remove(record);
                store.add(record);
                selectionsArray.push((store.getCount()) - (records.length - i));
            }
        }
        this.toGrid.getView().refresh();
        sm.selectRows(selectionsArray);
    },
    onFromTo: function(){

        var records = this.fromGrid.getSelectionModel().getSelections();
 
        var selectionsArray = [];
        for (var i=0; i < records.length; i++){
            selectionsArray.push(this.fromStore.indexOf(records[i]));
        }
        if (selectionsArray.length > 0) {
            if(!this.allowDup)
                selectionsArray = [];
            for (var i=0; i<records.length; i++) {
                record = records[i];
                if(this.allowDup){
                    var x=new Ext.data.Record();
                    record.id=x.id;
                    delete x;   
                    this.toStore.add([record]);
                }else{
                    this.fromStore.remove(record);
                    this.toStore.add([record]);
                    selectionsArray.push((this.toStore.getCount() - 1));
                }
            }
        }
        this.toGrid.getView().refresh();
        this.fromGrid.getView().refresh();
        if(this.toSortField)
            this.toStore.sort(this.toSortField, this.toSortDir);
        if(this.allowDup)
            this.fromGrid.getSelectionModel().selectRows(selectionsArray);
        else 
            this.toGrid.getSelectionModel().selectRows(selectionsArray);    
    },
    onToFrom: function(){
        var records = this.toGrid.getSelectionModel().getSelections(); 
        var selectionsArray = [];
        if (records.length > 0) {
            
            for (var i=0; i<records.length; i++) {
                record = records[i];
                this.toStore.remove(record);
                if(!this.allowDup){
                    this.fromStore.add([record]);
                    selectionsArray.push((this.fromStore.getCount() - 1));
                }
            }
        }
        this.fromGrid.getView().refresh();
        this.toGrid.getView().refresh();
        if(this.fromSortField)
            this.fromStore.sort(this.fromSortField, this.fromSortDir);
        this.fromGrid.getSelectionModel().selectRows(selectionsArray);    
    },
    
	onDestroy:function(){

        this.toStore = null;
        this.toGrid = null;
        this.fromStore = null;
        this.fromGrid = null;
    }
});
Ext.reg('multiSelectWin',Ext.ux.MultiSelectWin);


截图


  • 大小: 5.1 KB
分享到:
评论

相关推荐

    Extjs MultiselectItemSelector

    首先,`MultiselectItemSelector` 提供了一个用户友好的界面,通常会显示一个可滚动的列表,用户可以通过勾选复选框来选择多个项目。这种组件的交互设计考虑了易用性和效率,使得用户可以快速地在大量数据中进行多选...

    【NLP 66、实践 ⑰ 基于Agent + Prompt优化进行文章优化】

    【NLP 66、实践 ⑰ 基于Agent + Prompt优化进行文章优化】

    梦限大mewtype成员 藤都子RVC模型

    考虑微网新能源经济消纳的共享储能优化配置附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    tokenizers-0.30.0.jar中文文档.zip

    # 【tokenizers-***.jar***文档.zip】 中包含: ***文档:【tokenizers-***-javadoc-API文档-中文(简体)版.zip】 jar包下载地址:【tokenizers-***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【tokenizers-***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【tokenizers-***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【tokenizers-***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: tokenizers-***.jar***文档.zip,java,tokenizers-***.jar,ai.djl.huggingface,tokenizers,***,ai.djl.engine.rust,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,djl,huggingface,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【tokenizers-***.jar***文档.zip】,再解压其中的 【tokenizers-***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件; # Maven依赖: ``` <dependency> <groupId>ai.djl.huggingface</groupId> <artifactId>tokenizers</artifactId> <version>***</version> </dependency> ``` # Gradle依赖: ``` Gradle: implementation group: 'ai.djl.huggingface', name: 'tokenizers', version: '***' Gradle (Short): implementation 'ai.djl.huggingface:tokenizers:***' Gradle (Kotlin): implementation("ai.djl.huggingface:tokenizers:***") ``` # 含有的 Java package(包): ``` ai.djl.engine.rust ai.djl.engine.rust.zoo ai.djl.huggingface.tokenizers ai.djl.huggingface.tokenizers.jni ai.djl.huggingface.translator ai.djl.huggingface.zoo ``` # 含有的 Java class(类): ``` ai.djl.engine.rust.RsEngine ai.djl.engine.rust.RsEngineProvider ai.djl.engine.rust.RsModel ai.djl.engine.rust.RsNDArray ai.djl.engine.rust.RsNDArrayEx ai.djl.engine.rust.RsNDArrayIndexer ai.djl.engine.rust.RsNDManager ai.djl.engine.rust.RsSymbolBlock ai.djl.engine.rust.RustLibrary ai.djl.engine.rust.zoo.RsModelZoo ai.djl.engine.rust.zoo.RsZooProvider ai.djl.huggingface.tokenizers.Encoding ai.djl.huggingface.tokenizers.HuggingFaceTokenizer ai.djl.huggingface.tokenizers.HuggingFaceTokenizer.Builder ai.djl.hu

    人形机器人是当今世界科技领域最具潜力和前景的产业之一 随着科技的不断进步和人工智能技术的快速发展,人形机器人作为未来产业的新赛道和经济增长的新引擎,将深刻变革人类生产生活方式,重塑全球产业发展格局

    人形机器人产业的发展需要人工智能、高端制造、新材料等先进技术的协同创新和突破。

    【状态估计】用于非标量系统估计的最优卡尔曼滤波附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    开关电源的尖峰干扰及其抑制.zip

    开关电源的尖峰干扰及其抑制.zip

    房地产培训 -新进业务员压马路市调培训.ppt

    房地产培训 -新进业务员压马路市调培训.ppt

    MATLAB实现计及电转气协同的含碳捕集与垃圾焚烧虚拟电厂优化调度

    内容概要:本文探讨了基于MATLAB平台的虚拟电厂优化调度方法,特别关注电转气(P2G)协同、碳捕集技术和垃圾焚烧的应用。文中介绍了虚拟电厂的概念及其重要性,详细解释了碳捕集、需求响应和电转气协同调度的关键技术,并展示了如何使用MATLAB和CPLEX求解器进行优化调度的具体步骤。通过定义决策变量、构建目标函数和设定约束条件,最终实现了多目标优化,即经济性最优和碳排放最低。此外,还讨论了一些常见的代码实现技巧和潜在的问题解决方案。 适合人群:从事能源管理和优化调度研究的专业人士,尤其是那些熟悉MATLAB编程和优化算法的人士。 使用场景及目标:适用于希望深入了解虚拟电厂运作机制和技术实现的研究人员和工程师。主要目标是通过优化调度提高能源利用效率,减少碳排放,降低成本。 其他说明:文章提供了详细的代码片段和理论分析,有助于读者更好地理解和复现实验结果。同时,强调了在实际应用中需要注意的一些细节问题,如约束条件的平衡、求解器配置等。

    在网格化数据集上轻松执行 2D 高通、低通、带通或带阻滤波器研究附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    spring-ai-pinecone-store-1.0.0-M7.jar中文-英文对照文档.zip

    # 【spring-ai-pinecone-store-1.0.0-M7.jar中文-英文对照文档.zip】 中包含: 中文-英文对照文档:【spring-ai-pinecone-store-1.0.0-M7-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【spring-ai-pinecone-store-1.0.0-M7.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【spring-ai-pinecone-store-1.0.0-M7.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【spring-ai-pinecone-store-1.0.0-M7.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【spring-ai-pinecone-store-1.0.0-M7-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: spring-ai-pinecone-store-1.0.0-M7.jar中文-英文对照文档.zip,java,spring-ai-pinecone-store-1.0.0-M7.jar,org.springframework.ai,spring-ai-pinecone-store,1.0.0-M7,org.springframework.ai.vectorstore.pinecone,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,springframework,spring,ai,pinecone,store,中文-英文对照API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【spring-ai-pinecone

    基于MATLAB混合整数规划的微网电池储能容量优化配置

    内容概要:本文详细介绍了如何使用MATLAB及其优化工具箱,通过混合整数规划(MILP)方法对微网电池储能系统的容量进行优化配置。主要内容包括定义目标函数(如最小化运行成本),设置约束条件(如充放电功率限制、能量平衡约束),并引入决策变量(如电池容量、充放电功率和状态)。文中提供了具体的MATLAB代码示例,演示了如何将实际问题转化为数学模型并求解。此外,还讨论了一些实用技巧,如避免充放电互斥冲突、考虑电池寿命损耗等。 适用人群:从事微电网设计与运维的技术人员,尤其是那些希望通过优化算法提高系统性能和经济效益的专业人士。 使用场景及目标:适用于需要确定最佳电池储能容量的微电网项目,旨在降低总体运行成本,提高系统的稳定性和可靠性。具体应用场景包括工业园区、商业建筑或其他分布式能源系统。 其他说明:文章强调了模型的实际应用价值,并指出通过精确控制充放电策略可以显著减少不必要的容量闲置,从而节省大量资金。同时提醒读者注意模型的时间粒度选择、电池退化成本等因素的影响。

    langchain4j-ollama-1.0.0-beta1.jar中文文档.zip

    # 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

    光伏离网并网逆变器设计:基于TMS320F28335的数字控制与SPWM技术详解

    内容概要:本文详细介绍了基于TMS320F28335的光伏离网并网逆变器设计方案,涵盖了从硬件架构到软件控制的各个方面。首先,文章阐述了TMS320F28335作为高性能DSP的优势及其初始化配置方法。其次,探讨了逆变器的数字控制策略,如双闭环控制(电压外环和电流内环)的具体实现方式。然后,深入讲解了SPWM(正弦脉宽调制)技术,包括SPWM波的生成方法和相关代码示例。此外,还讨论了硬件保护逻辑、过流检测、死区时间配置等实际应用中的注意事项。最后,提供了调试经验和学习资源建议。 适合人群:从事光伏逆变器设计、嵌入式系统开发的技术人员,尤其是有一定DSP编程基础的研发人员。 使用场景及目标:适用于需要深入了解光伏逆变器设计原理和技术实现的研究人员和工程师。主要目标是掌握基于TMS320F28335的逆变器控制系统设计,包括数字控制策略和SPWM技术的应用。 其他说明:文中提供的代码示例和实践经验有助于读者更好地理解和应用于实际项目中。建议读者结合TI官方提供的学习资料进行进一步学习和实践。

    【医疗影像分析】深度学习技术在医疗影像分析中的应用优势及未来发展方向:自动特征学习、高精度高效处理、多模态数据融合、个性化治疗与预测、实时远程支持

    内容概要:深度学习在医疗影像分析中展现出显著的优势,主要体现在自动特征学习、高准确性和效率、多模态数据融合与综合分析、个性化治疗与预测、减少主观性、处理复杂和高维数据、实时分析与远程医疗支持、数据挖掘与科研突破以及可扩展性与持续优化九个方面。通过卷积神经网络(CNN)、U-Net等模型,深度学习能够自动从影像中提取多层次特征,无需手动干预,在分类、分割任务中表现出色,处理速度远超人工。此外,它还能够整合多源数据,提供全面的诊断依据,实现个性化治疗建议,减少误诊和漏诊,支持实时分析和远程医疗,挖掘病理模式并加速研究,同时具有可扩展性和持续优化的能力。; 适合人群:医疗行业从业者、科研人员、计算机视觉和深度学习领域的研究人员。; 使用场景及目标:①用于医疗影像的自动特征提取和分类,如乳腺癌筛查、皮肤癌诊断等;②整合多模态数据,如CT、MRI等,提高诊断准确性;③提供个性化治疗建议,优化治疗方案;④支持实时分析和远程医疗,尤其适用于偏远地区的急诊场景;⑤挖掘病理模式,加速疾病机制的研究。; 其他说明:深度学习正逐渐成为医疗影像分析的核心诊断伙伴,未来发展方向包括增强可解释性、保护数据隐私和轻量化部署,旨在进一步提升医疗效率和患者护理质量。

    深度学习机器学习子领域关键技术解析:神经网络基础、常见架构及应用场景综述

    内容概要:深度学习是机器学习的一个子领域,通过构建多层次的“深度神经网络”来模拟人脑结构,从而学习和提取数据的复杂特征。文章介绍了深度学习的核心概念,包括神经元、多层感知机、深度神经网络(DNN)、卷积神经网络(CNN)、循环神经网络(RNN)和Transformer等常见网络结构。同时,详细讲解了激活函数、损失函数与优化器的作用。此外,还探讨了深度学习的关键突破,如大数据与算力的支持、正则化技术和迁移学习的应用。文中列举了深度学习在计算机视觉、自然语言处理、语音与音频以及强化学习等领域的应用场景,并指出了其面临的挑战,如数据依赖、计算成本和可解释性问题。最后提供了使用PyTorch和TensorFlow/Keras框架的经典代码示例,涵盖图像分类、文本生成和迁移学习等内容。; 适合人群:对机器学习有一定了解,希望深入学习深度学习理论和技术的研究人员、工程师及学生。; 使用场景及目标:①理解深度学习的基本原理和核心概念;②掌握常见深度学习框架的使用方法,如PyTorch和TensorFlow;③能够根据具体应用场景选择合适的网络结构和算法进行实践。; 其他说明:本文不仅提供了理论知识,还附带了详细的代码示例,便于读者动手实践。建议读者结合理论与实践,逐步深入理解深度学习的各个方面。

    深度学习答辩PPT案例展示

    适用于理工专业的毕业生,毕业答辩时可供参考,叙述详细准确,可以作为自己答辩PPT的参考

    tokenizers-0.22.1.jar中文-英文对照文档.zip

    # 【tokenizers-***.jar***文档.zip】 中包含: ***文档:【tokenizers-***-javadoc-API文档-中文(简体)版.zip】 jar包下载地址:【tokenizers-***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【tokenizers-***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【tokenizers-***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【tokenizers-***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: tokenizers-***.jar***文档.zip,java,tokenizers-***.jar,ai.djl.huggingface,tokenizers,***,ai.djl.engine.rust,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,djl,huggingface,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【tokenizers-***.jar***文档.zip】,再解压其中的 【tokenizers-***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件; # Maven依赖: ``` <dependency> <groupId>ai.djl.huggingface</groupId> <artifactId>tokenizers</artifactId> <version>***</version> </dependency> ``` # Gradle依赖: ``` Gradle: implementation group: 'ai.djl.huggingface', name: 'tokenizers', version: '***' Gradle (Short): implementation 'ai.djl.huggingface:tokenizers:***' Gradle (Kotlin): implementation("ai.djl.huggingface:tokenizers:***") ``` # 含有的 Java package(包): ``` ai.djl.engine.rust ai.djl.engine.rust.zoo ai.djl.huggingface.tokenizers ai.djl.huggingface.tokenizers.jni ai.djl.huggingface.translator ai.djl.huggingface.zoo ``` # 含有的 Java class(类): ``` ai.djl.engine.rust.RsEngine ai.djl.engine.rust.RsEngineProvider ai.djl.engine.rust.RsModel ai.djl.engine.rust.RsNDArray ai.djl.engine.rust.RsNDArrayEx ai.djl.engine.rust.RsNDArrayIndexer ai.djl.engine.rust.RsNDManager ai.djl.engine.rust.RsSymbolBlock ai.djl.engine.rust.RustLibrary ai.djl.engine.rust.zoo.RsModelZoo ai.djl.engine.rust.zoo.RsZooProvider ai.djl.huggingface.tokenizers.Encoding ai.djl.huggingface.tokenizers.HuggingFaceTokenizer ai.djl.huggingface.tokenizers.HuggingFaceTokenizer.Builder ai.djl.hu

    能源领域:基于MATLAB的阶梯式碳交易与供需灵活双响应综合能源系统优化调度

    内容概要:本文详细介绍了考虑阶梯式碳交易与供需灵活双响应的综合能源系统优化调度方法。在供给侧,引入了有机朗肯循环(ORC)实现热电联产机组的灵活响应;在需求侧,提出电、热、气负荷之间的可替代性,以提高能源利用效率。构建了以最小化碳排放成本、购能成本、弃风成本和需求响应成本为目标的优化调度模型,并采用MATLAB和CPLEX进行了模型构建和求解。文中提供了具体的代码示例,展示了如何处理热电耦合、负荷替代和阶梯式碳交易等问题。 适合人群:从事能源系统优化、电力系统调度、碳交易等相关领域的研究人员和技术人员。 使用场景及目标:适用于需要优化能源系统调度、降低成本并减少碳排放的实际应用场景。目标是帮助读者理解和掌握如何通过先进的技术和算法实现更加灵活和高效的能源调度。 其他说明:文章提供了完整的代码实现和服务支持,包括12种典型场景的数据集和预设模型,方便读者快速上手实践。

Global site tag (gtag.js) - Google Analytics