sssssssssss

  1. var panel =  new  Panel({  
  2.     title: 'My Accordion' ,  
  3.     layout: 'accordion' ,   //在这个面板中所使用的布局样式   
  4.     layoutConfig: {  
  5.         animate: true       //布局指定的配置项写在这里   
  6.     }  
  7.     // 其他Panel的选项   
  8. }); 
  9. *************************************************************************

Ext.onReady(function(){
Ext.QuickTips.init();
//第一句的目的是为需要的元件提供提示信息功能,form的主要提示信息就是客户端验证的错误信息了。
Ext.form.Field.prototype.msgTarget = 'under';
//第二句的目的就是设置控件的错误信息显示位置,主要可选的位置有:
var tdate = new Ext.form.DateField({
fieldLabel: '日期',
emptyText: '请选择日期',
format: 'Y-m-d',
disabledDays: [0, 7]
});
var txt = new Ext.form.TextField({
fieldLabel: '请输入姓名',
allowBlank: false,
emptyText: '空',
maxLength: 50,
minLength: 10,
bodyStyle: 'padding-left:5px',
anchor: '90%'//给错误提示留下10的空间,
});
var htmlEdt=new Ext.form.HtmlEditor({
fieldLabel:'在线编辑器',
enableAlignments:true,
enableColors:true,
enableFont:true,
enableFontSize:true,
enableFormat:true,
enableLinks:true,
enableLists:true,
enableSourceEdit:true
});
var txt2 = new Ext.form.TextField({
fieldLabel: '请输入姓名',
allowBlank: false,
emptyText: '空',
maxLength: 50,
minLength: 10,
bodyStyle: 'padding-left:5px',
anchor: '90%'
//给错误提示留下10的空间
});
var frm1 = new Ext.form.FormPanel({
labelAlign: 'right',
labelWidth: 100,//注意修改标题的宽度
title: 'form1',
frame: true,
width: 700,
url: 'sender/data.aspx',
items: [{
layout: 'column',//正点的地方来了表示下一曾items都是按列"Column"排序
items: [{
columnWidth: .5,
layout: 'form',//第一列里面内容就是form排序了,从上到下
items: [txt2]
},
{
columnWidth: .5,
layout: 'form',//第二列里面内容就是form排序了,从上到下
items: [txt, tdate]
}]
}, htmlEdt]
});
frm1.render("frm");
});

 

 

**********************************************************************

 

     Ext.layout.TableLayout对应面板布局layout配置项的名称为table。

       这种比较允许你非常容易的渲染内容到HTML表格中,可以指定列数(columns),跨行(rowspan),跨列(colspan),可以创建出复杂的表格布局。

        必须使用layoutConfig属性来指定属于此布局的配置,table布局仅有唯一的布局配置项columns,而包含在其中的子面板会具有rowspan和colspan两个配置项!

   下面是表格布局的一个简单的示例

<script type="text/javascript">
 Ext.onReady(function(){
  Ext.BLANK_IMAGE_URL = '../../extjs2.0/resources/images/default/s.gif';
  var panel = new Ext.Panel({
   title:'Ext.layout.TableLayout布局示例',
   layout : 'table',
   layoutConfig : {
    columns : 4 //设置表格布局默认列数为4列
   },
   frame:true,//渲染面板
   height : 150,
   applyTo :'panel',
   defaults : {//设置默认属性
    bodyStyle:'background-color:#FFFFFF;',//设置面板体的背景色
    frame : true,
    height : 50
   },
   items: [
    {
     title:'子面板一',
     colspan : 3   //设置跨列
    },
    {
     title:'子面板二',
     rowspan : 2,  //设置跨行
     height : 100
    },
    {title:'子面板三'},
    {title:'子面板四'},
    {title:'子面板五'}
   ]
  })
 });
</script>

 

 

*********************************************************************************

Ext.onReady(function(){
Ext.QuickTips.init();
//第一句的目的是为需要的元件提供提示信息功能,form的主要提示信息就是客户端验证的错误信息了。
Ext.form.Field.prototype.msgTarget = 'under';
//第二句的目的就是设置控件的错误信息显示位置,主要可选的位置有:
var tdate = new Ext.form.DateField({
fieldLabel: '日期',
emptyText: '请选择日期',
format: 'Y-m-d',
disabledDays: [0, 7]
});
var txt = new Ext.form.TextField({
fieldLabel: '请输入姓名',
allowBlank: false,
emptyText: '空',
maxLength: 50,
minLength: 10,
bodyStyle: 'padding-left:5px',
anchor: '90%'//给错误提示留下10的空间,
});
var htmlEdt=new Ext.form.HtmlEditor({
fieldLabel:'在线编辑器',
enableAlignments:true,
enableColors:true,
enableFont:true,
enableFontSize:true,
enableFormat:true,
enableLinks:true,
enableLists:true,
enableSourceEdit:true
});
var txt2 = new Ext.form.TextField({
fieldLabel: '请输入姓名',
allowBlank: false,
emptyText: '空',
maxLength: 50,
minLength: 10,
bodyStyle: 'padding-left:5px',
anchor: '90%'
//给错误提示留下10的空间
});
var frm1 = new Ext.form.FormPanel({
labelAlign: 'right',
labelWidth: 100,//注意修改标题的宽度
title: 'form1',
frame: true,
width: 700,
url: 'sender/data.aspx',
items: [{
layout: 'column',//正点的地方来了表示下一曾items都是按列"Column"排序
items: [{
columnWidth: .5,
layout: 'form',//第一列里面内容就是form排序了,从上到下
items: [txt2]
},
{
columnWidth: .5,
layout: 'form',//第二列里面内容就是form排序了,从上到下
items: [txt, tdate]
}]
}, htmlEdt]
});
frm1.render("frm");
});

****************************************************************************

var  simpleForm  =  new  Ext.FormPanel( {
    labelAlign: 
' left ' ,
    title: 
' 表单例子 ' ,
    buttonAlign:
' right ' ,
    bodyStyle:
' padding:5px ' ,
    width: 
600 ,
    frame:
true ,
    labelWidth:
80 ,
    items: [
{
        layout:
' column ' ,    // 定义该元素为布局为列布局方式
        border: false ,
        labelSeparator:
' ' ,
        items:[
{
            columnWidth:.
5 ,   // 该列占用的宽度,标识为50%
            layout:  ' form ' ,
            border:
false ,
            items: [
{                      // 这里可以为多个Item,表现出来是该列的多行
                cls :  ' key ' ,
                xtype:
' textfield ' ,
                fieldLabel: 
' 用户名 ' ,
                name: 
' name ' ,
                anchor:
' 90% '
            }
]
        }
, {
            columnWidth:.
5 ,
            layout: 
' form ' ,
            border:
false ,
            items: [
{
                cls : 
' key ' ,
                xtype:
' textfield ' ,
                inputType:
' password ' ,
                fieldLabel: 
' 口令 ' ,
                name: 
' passwd ' ,
                anchor:
' 90% '
            }
]
        }
]
    }
]
}
)

if (stream1.retrieve(encodedPacket)) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "iiiiiiiiii!"); char *inputBuf = mppDecoder->getInputBuffer(inputIndex); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "uuuuuuuuuuu:%s",*inputBuf); size_t dataSize = encodedPacket.total() * encodedPacket.elemSize(); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ffffffffff!"); if (!inputBuf || !encodedPacket.data) { __LOG_PRINT(ANDROID_LOG_ERROR, "rtsp", "NULL pointer detected!"); } memcpy(inputBuf, encodedPacket.data, dataSize); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "aaaaaaaaa!"); mppDecoder->queueInputBuffer(inputIndex, 0, dataSize, 0); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "sssssssssss!"); }我这里会出现段错误,这里uuuuuuuuuuu:(null) ,帮我优化这个问题,这是完整代码void *open_media(void *argv){ __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx"); ThreadData *data = static_cast<ThreadData *>(argv); RKMpp* mppDecoder = data->mppDecoder.get(); const char *rurl = data->url; std::string cstr = std::string(data->cameraId); int cameraId = std::stoi(cstr); std::string istr = std::string(data->indexStr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx %s", istr.c_str()); int index = std::stoi(istr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media %d %s %i", cameraId, rurl, index); int retries = 0; while (retries < MAX_RETRIES) { cv::VideoCapture stream1(rurl, cv::CAP_FFMPEG); if (!stream1.isOpened()) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "Cannot open RTSP stream!"); std::cerr << "无法打开 RTSP 流,尝试第 " << retries + 1 << " 次重连..." << std::endl; retries++; std::this_thread::sleep_for(std::chrono::seconds(RETRY_INTERVAL)); continue; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "oooooooooooo!"); cv::Mat encodedPacket; // 假设存储编码数据(如 H.264 包) while (true) { // 从流中读取编码数据包(需验证 OpenCV 是否支持直接读包) if (!stream1.grab()) { // 处理断流重连 break; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "kkkkkkkkkk!"); // 获取 MPP 输入缓冲区 int inputIndex = mppDecoder->dequeueInputBuffer(500000); if (inputIndex < 0) continue; __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ppppppppppp!"); // 读取编码数 if (stream1.retrieve(encodedPacket)) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "iiiiiiiiii!"); char *inputBuf = mppDecoder->getInputBuffer(inputIndex); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "uuuuuuuuuuu:%s",*inputBuf); size_t dataSize = encodedPacket.total() * encodedPacket.elemSize(); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ffffffffff!"); if (!inputBuf || !encodedPacket.data) { __LOG_PRINT(ANDROID_LOG_ERROR, "rtsp", "NULL pointer detected!"); } memcpy(inputBuf, encodedPacket.data, dataSize); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "aaaaaaaaa!"); mppDecoder->queueInputBuffer(inputIndex, 0, dataSize, 0); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "sssssssssss!"); } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "jjjjjjjjjjjj!"); // 获取解码后的帧 int outputIndex = mppDecoder->dequeueOutputBuffer(100000); // if (outputIndex >= 0) { // char *decodedFrame = mppDecoder.getFrame(); // screenShot(num, cameraId, index, decodedFrame); // 修改后的截图函数 // } } } }
最新发布
03-26
memcpy(inputBuf, encodedPacket.data, dataSize);还是一到这里就出段错误啊void *open_media(void *argv){ __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx"); ThreadData *data = static_cast<ThreadData *>(argv); RKMpp* mppDecoder = data->mppDecoder.get(); const char *rurl = data->url; std::string cstr = std::string(data->cameraId); int cameraId = std::stoi(cstr); std::string istr = std::string(data->indexStr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx %s", istr.c_str()); int index = std::stoi(istr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media %d %s %i", cameraId, rurl, index); int retries = 0; while (retries < MAX_RETRIES) { cv::VideoCapture stream1(rurl, cv::CAP_FFMPEG); if (!stream1.isOpened()) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "Cannot open RTSP stream!"); std::cerr << "无法打开 RTSP 流,尝试第 " << retries + 1 << " 次重连..." << std::endl; retries++; std::this_thread::sleep_for(std::chrono::seconds(RETRY_INTERVAL)); continue; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "oooooooooooo!"); cv::Mat encodedPacket; // 假设存储编码数据(如 H.264 包) while (true) { // 从流中读取编码数据包(需验证 OpenCV 是否支持直接读包) if (!stream1.grab()) { // 处理断流重连 break; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "kkkkkkkkkk!"); // 获取 MPP 输入缓冲区 int inputIndex = mppDecoder->dequeueInputBuffer(500000); if (inputIndex < 0) continue; __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ppppppppppp!"); // 读取编码数据到缓冲区 if (stream1.retrieve(encodedPacket)) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "iiiiiiiiii!"); char *inputBuf = mppDecoder->getInputBuffer(inputIndex); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "uuuuuuuuuuu!"); size_t dataSize = encodedPacket.total() * encodedPacket.elemSize(); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ffffffffff!"); memcpy(inputBuf, encodedPacket.data, dataSize); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "aaaaaaaaa!"); mppDecoder->queueInputBuffer(inputIndex, 0, dataSize, 0); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "sssssssssss!"); } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "jjjjjjjjjjjj!"); // 获取解码后的帧 int outputIndex = mppDecoder->dequeueOutputBuffer(100000); // if (outputIndex >= 0) { // char *decodedFrame = mppDecoder.getFrame(); // screenShot(num, cameraId, index, decodedFrame); // 修改后的截图函数 // } } } }
03-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值