private void numericChar_ValueChanged(object sender, EventArgs e) { sNFTR.PAMC pamc = maps[(int)numericSection.Value]; pamc.first_char = (ushort)numericFirstChar.Value; pamc.last_char = (ushort)numericLastChar.Value; maps[(int)numericSection.Value] = pamc; }
private void MapInfo() { sNFTR.PAMC map = maps[(int)numericSection.Value]; numericFirstChar.Value = map.first_char; numericLastChar.Value = map.last_char; numericType.Value = map.type_section; dataGridMapInfo.Rows.Clear(); switch (map.type_section) { case 0: sNFTR.PAMC.Type0 type0 = (sNFTR.PAMC.Type0)map.info; dataGridMapInfo.Rows.Add(type0.fist_char_code.ToString(), "0"); break; case 1: sNFTR.PAMC.Type1 type1 = (sNFTR.PAMC.Type1)map.info; for (int i = 0; i < type1.char_code.Length; i++) { dataGridMapInfo.Rows.Add(type1.char_code[i].ToString(), i.ToString()); } break; case 2: sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)map.info; for (int i = 0; i < type2.num_chars; i++) { dataGridMapInfo.Rows.Add(type2.charInfo[i].chars.ToString(), type2.charInfo[i].chars_code.ToString()); } break; } }
private void Recalculate_Size() { for (int i = 0; i < maps.Count; i++) { sNFTR.PAMC map = maps[i]; uint size = 0x14; switch (map.type_section) { case 0: size += 4; break; case 1: sNFTR.PAMC.Type1 type1 = (sNFTR.PAMC.Type1)map.info; size += (uint)type1.char_code.Length * 2; if (type1.char_code.Length % 2 > 0) { size += 2; } break; case 2: sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)map.info; size += 4; size += (uint)type2.charInfo.Length * 4; break; } map.block_size = size; maps[i] = map; } }
private void btnChangeMap_Click(object sender, EventArgs e) { MapChar map = new MapChar(font.pamc, pluginHost.Get_Language()); map.ShowDialog(); if (map.DialogResult != DialogResult.OK) { return; } font.pamc = map.Maps; for (int i = 0; i < font.pamc.Count; i++) { if (font.pamc[i].info is sNFTR.PAMC.Type2) { sNFTR.PAMC sec = font.pamc[i]; List <sNFTR.PAMC.Type2.CharInfo> infos = new List <sNFTR.PAMC.Type2.CharInfo>(); sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)sec.info; infos.AddRange(type2.charInfo); infos.Sort(Sort_Font); type2.charInfo = infos.ToArray(); sec.info = type2; font.pamc[i] = sec; } } charTile.Clear(); Fill_CharTile(); txtBox_TextChanged(txtBox, null); }
private void btnAddSect_Click(object sender, EventArgs e) { sNFTR.PAMC map = new sNFTR.PAMC(); map.type = new char[] { 'P', 'A', 'M', 'C' }; map.first_char = 0x0000; map.last_char = 0xFFFF; map.type_section = 2; numericType.ReadOnly = false; sNFTR.PAMC.Type2 type2 = new sNFTR.PAMC.Type2(); type2.num_chars = 0; type2.charInfo = new sNFTR.PAMC.Type2.CharInfo[0]; map.info = type2; maps.Add(map); lblTotalSec.Text = "of " + (maps.Count - 1).ToString(); numericSection.Maximum = maps.Count - 1; numericSection.Value = maps.Count - 1; }
public static sNFTR Read(sFile cfile, string lang) { sNFTR font = new sNFTR(); font.id = cfile.id; font.name = cfile.name; BinaryReader br = new BinaryReader(File.OpenRead(cfile.path)); // Read the standard header font.header.type = br.ReadChars(4); font.header.endianess = br.ReadUInt16(); font.header.unknown = br.ReadUInt16(); font.header.file_size = br.ReadUInt32(); font.header.block_size = br.ReadUInt16(); font.header.num_blocks = br.ReadUInt16(); // Font INFo section font.fnif.type = br.ReadChars(4); font.fnif.block_size = br.ReadUInt32(); font.fnif.unknown1 = br.ReadByte(); font.fnif.height = br.ReadByte(); font.fnif.nullCharIndex = br.ReadUInt16(); font.fnif.unknown4 = br.ReadByte(); font.fnif.width = br.ReadByte(); font.fnif.width_bis = br.ReadByte(); font.fnif.encoding = br.ReadByte(); font.fnif.offset_plgc = br.ReadUInt32(); font.fnif.offset_hdwc = br.ReadUInt32(); font.fnif.offset_pamc = br.ReadUInt32(); if (font.fnif.block_size == 0x20) { font.fnif.height_font = br.ReadByte(); font.fnif.widht_font = br.ReadByte(); font.fnif.bearing_y = br.ReadByte(); font.fnif.bearing_x = br.ReadByte(); } // Character Graphics LP br.BaseStream.Position = font.fnif.offset_plgc - 0x08; font.plgc.type = br.ReadChars(4); font.plgc.block_size = br.ReadUInt32(); font.plgc.tile_width = br.ReadByte(); font.plgc.tile_height = br.ReadByte(); font.plgc.tile_length = br.ReadUInt16(); font.plgc.unknown = br.ReadUInt16(); font.plgc.depth = br.ReadByte(); font.plgc.rotateMode = br.ReadByte(); font.plgc.tiles = new Byte[(font.plgc.block_size - 0x10) / font.plgc.tile_length][]; for (int i = 0; i < font.plgc.tiles.Length; i++) { font.plgc.tiles[i] = BytesToBits(br.ReadBytes(font.plgc.tile_length)); if (font.plgc.rotateMode >> 1 == 3) { font.plgc.tiles[i] = Rotate270(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); } else if (font.plgc.rotateMode >> 1 == 1) { font.plgc.tiles[i] = Rotate90(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); } else if (font.plgc.rotateMode >> 1 == 2) { font.plgc.tiles[i] = Rotate180(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); } } if (font.plgc.rotateMode >> 1 % 2 != 0) { byte w = font.plgc.tile_width; font.plgc.tile_width = font.plgc.tile_height; font.plgc.tile_height = w; } // Character Width DH br.BaseStream.Position = font.fnif.offset_hdwc - 0x08; font.hdwc.type = br.ReadChars(4); font.hdwc.block_size = br.ReadUInt32(); font.hdwc.fist_code = br.ReadUInt16(); font.hdwc.last_code = br.ReadUInt16(); font.hdwc.unknown1 = br.ReadUInt32(); font.hdwc.info = new List <sNFTR.HDWC.Info>(); for (int i = 0; i < font.plgc.tiles.Length; i++) { sNFTR.HDWC.Info info = new sNFTR.HDWC.Info(); info.pixel_start = br.ReadSByte(); info.pixel_width = br.ReadByte(); info.pixel_length = br.ReadByte(); font.hdwc.info.Add(info); } // Character MAP br.BaseStream.Position = font.fnif.offset_pamc - 0x08; font.pamc = new List <sNFTR.PAMC>(); uint nextOffset = 0x00; do { sNFTR.PAMC pamc = new sNFTR.PAMC(); pamc.type = br.ReadChars(4); pamc.block_size = br.ReadUInt32(); pamc.first_char = br.ReadUInt16(); pamc.last_char = br.ReadUInt16(); pamc.type_section = br.ReadUInt32(); nextOffset = br.ReadUInt32(); pamc.next_section = nextOffset; switch (pamc.type_section) { case 0: sNFTR.PAMC.Type0 type0 = new sNFTR.PAMC.Type0(); type0.fist_char_code = br.ReadUInt16(); pamc.info = type0; break; case 1: sNFTR.PAMC.Type1 type1 = new sNFTR.PAMC.Type1(); type1.char_code = new ushort[pamc.last_char - pamc.first_char + 1]; for (int i = 0; i < type1.char_code.Length; i++) { type1.char_code[i] = br.ReadUInt16(); } pamc.info = type1; break; case 2: sNFTR.PAMC.Type2 type2 = new sNFTR.PAMC.Type2(); type2.num_chars = br.ReadUInt16(); type2.charInfo = new sNFTR.PAMC.Type2.CharInfo[type2.num_chars]; for (int i = 0; i < type2.num_chars; i++) { type2.charInfo[i].chars_code = br.ReadUInt16(); type2.charInfo[i].chars = br.ReadUInt16(); } pamc.info = type2; break; } font.pamc.Add(pamc); br.BaseStream.Position = nextOffset - 0x08; } while (nextOffset != 0x00 && (nextOffset - 0x08) < br.BaseStream.Length); //WriteInfo(font, lang); font.plgc.rotateMode &= 1; br.Close(); return(font); }
public static void WriteInfo(sNFTR font, string lang) { try { XElement xml = XElement.Load(System.Windows.Forms.Application.StartupPath + Path.DirectorySeparatorChar + "Plugins" + Path.DirectorySeparatorChar + "FontLang.xml"); xml = xml.Element(lang).Element("NFTR"); Console.WriteLine(xml.Element("S00").Value); Console.WriteLine("<pre>"); Console.WriteLine(xml.Element("S01").Value, font.header.num_blocks.ToString()); Console.WriteLine("<b>" + xml.Element("S02").Value + "</b>", new String(font.fnif.type)); Console.WriteLine(xml.Element("S03").Value, font.fnif.block_size.ToString("x")); Console.WriteLine(xml.Element("S04").Value, font.fnif.unknown1.ToString("x")); Console.WriteLine(xml.Element("S1E").Value, font.fnif.height.ToString("x")); Console.WriteLine("Null char index: " + font.fnif.nullCharIndex.ToString()); Console.WriteLine(xml.Element("S20").Value, font.fnif.unknown4.ToString("x")); Console.WriteLine(xml.Element("S21").Value, font.fnif.width.ToString("x")); Console.WriteLine(xml.Element("S22").Value, font.fnif.width_bis.ToString("x")); Console.WriteLine(xml.Element("S23").Value, font.fnif.encoding.ToString("x")); Console.WriteLine(xml.Element("S06").Value, font.fnif.offset_plgc.ToString("x")); Console.WriteLine(xml.Element("S07").Value, font.fnif.offset_hdwc.ToString("x")); Console.WriteLine(xml.Element("S08").Value, font.fnif.offset_pamc.ToString("x")); if (font.fnif.block_size == 0x20) { Console.WriteLine(xml.Element("S24").Value, font.fnif.height_font.ToString("x")); Console.WriteLine(xml.Element("S25").Value, font.fnif.widht_font.ToString("x")); Console.WriteLine(xml.Element("S26").Value, font.fnif.bearing_y.ToString("x")); Console.WriteLine(xml.Element("S09").Value, font.fnif.bearing_x.ToString("x")); } Console.WriteLine("<b>" + xml.Element("S02").Value + "</b>", new String(font.plgc.type)); Console.WriteLine(xml.Element("S03").Value, font.plgc.block_size.ToString("x")); Console.WriteLine(xml.Element("S0A").Value, font.plgc.tile_width.ToString()); Console.WriteLine(xml.Element("S0B").Value, font.plgc.tile_height.ToString()); Console.WriteLine(xml.Element("S0C").Value, font.plgc.tile_length.ToString()); Console.WriteLine(xml.Element("S0D").Value, font.plgc.unknown.ToString("x")); Console.WriteLine(xml.Element("S0E").Value, font.plgc.depth.ToString()); Console.WriteLine(xml.Element("S0F").Value, font.plgc.rotateMode.ToString()); //Console.WriteLine(xml.Element("S10").Value, font.plgc.unknown2.ToString()); Console.WriteLine("<b>" + xml.Element("S02").Value + "</b>", new String(font.hdwc.type)); Console.WriteLine(xml.Element("S03").Value, font.hdwc.block_size.ToString("x")); Console.WriteLine(xml.Element("S11").Value, font.hdwc.fist_code.ToString("x")); Console.WriteLine(xml.Element("S12").Value, font.hdwc.last_code.ToString("x")); Console.WriteLine(xml.Element("S13").Value, font.hdwc.unknown1.ToString("x")); Console.WriteLine("<b>" + xml.Element("S02").Value + "</b>", "PAMC"); for (int i = 0; i < font.pamc.Count; i++) { sNFTR.PAMC pamc = font.pamc[i]; Console.WriteLine("<u>" + xml.Element("S02").Value + "</u>", i.ToString()); Console.WriteLine(" |__" + xml.Element("S03").Value, pamc.block_size.ToString("x")); Console.WriteLine(" |_" + xml.Element("S14").Value, pamc.first_char.ToString("x")); Console.WriteLine(" |_" + xml.Element("S15").Value, pamc.last_char.ToString("x")); Console.WriteLine(" |_" + xml.Element("S16").Value, pamc.type_section.ToString()); switch (pamc.type_section) { case 0: sNFTR.PAMC.Type0 type0 = (sNFTR.PAMC.Type0)pamc.info; Console.WriteLine(" \\_" + xml.Element("S17").Value, 0); Console.WriteLine(" \\_" + xml.Element("S18").Value, type0.fist_char_code.ToString("x")); break; case 1: sNFTR.PAMC.Type1 type1 = (sNFTR.PAMC.Type1)pamc.info; Console.WriteLine(" \\_" + xml.Element("S17").Value, 1); Console.WriteLine(" \\_" + xml.Element("S19").Value, type1.char_code.Length.ToString()); for (int j = 0; j < type1.char_code.Length; j++) { Console.WriteLine(" |_" + xml.Element("S1A").Value, j.ToString(), type1.char_code[j].ToString("x"), Encoding.GetEncoding("shift-jis").GetChars( BitConverter.GetBytes(pamc.first_char + j).Reverse().ToArray()).Reverse().ToArray()[0]); } break; case 2: sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)pamc.info; Console.WriteLine(" \\_" + xml.Element("S17").Value, 2); Console.WriteLine(" \\_" + xml.Element("S1B").Value, type2.num_chars.ToString()); for (int j = 0; j < type2.num_chars; j++) { Console.WriteLine(" |_" + xml.Element("S1C").Value, j.ToString(), type2.charInfo[j].chars_code.ToString("x")); Console.WriteLine(" |_" + xml.Element("S1D").Value, j.ToString(), type2.charInfo[j].chars.ToString()); } break; } } Console.WriteLine("EOF</pre>"); } catch { throw new NotSupportedException("There was an error reading the language file"); } }
public static void Write(sNFTR font, string fileout) { // Calculate de size of each block font.plgc.block_size = (uint)(0x10 + font.plgc.tiles.Length * font.plgc.tile_length); if (font.plgc.block_size % 4 != 0) // Padding { font.plgc.block_size += (4 - (font.plgc.block_size % 4)); } font.hdwc.block_size = (uint)(0x10 + font.hdwc.info.Count * 3); if (font.hdwc.block_size % 4 != 0) // Padding { font.hdwc.block_size += (4 - (font.hdwc.block_size % 4)); } uint pacm_totalSize = 0x00; for (int i = 0; i < font.pamc.Count; i++) { pacm_totalSize += font.pamc[i].block_size; } font.header.file_size = font.header.block_size + font.fnif.block_size + font.plgc.block_size + font.hdwc.block_size + pacm_totalSize; // Calculate the new offset font.fnif.offset_plgc = font.header.block_size + font.fnif.block_size + 0x08; font.fnif.offset_hdwc = (font.fnif.offset_plgc - 0x08) + font.plgc.block_size + 0x08; font.fnif.offset_pamc = (font.fnif.offset_hdwc - 0x08) + font.hdwc.block_size + 0x08; BinaryWriter bw = new BinaryWriter(File.OpenWrite(fileout)); // Write the generic header bw.Write(font.header.type); bw.Write(font.header.endianess); bw.Write(font.header.unknown); bw.Write(font.header.file_size); bw.Write(font.header.block_size); bw.Write(font.header.num_blocks); // Write the FINF section bw.Write(font.fnif.type); bw.Write(font.fnif.block_size); bw.Write(font.fnif.unknown1); bw.Write(font.fnif.height); bw.Write(font.fnif.nullCharIndex); bw.Write(font.fnif.unknown4); bw.Write(font.fnif.width); bw.Write(font.fnif.width_bis); bw.Write(font.fnif.encoding); bw.Write(font.fnif.offset_plgc); bw.Write(font.fnif.offset_hdwc); bw.Write(font.fnif.offset_pamc); if (font.fnif.block_size == 0x20) { bw.Write(font.fnif.height_font); bw.Write(font.fnif.widht_font); bw.Write(font.fnif.bearing_y); bw.Write(font.fnif.bearing_x); } // Padding int rem = (int)bw.BaseStream.Position % 4; if (rem != 0) { for (; rem < 4; rem++) { bw.Write((byte)0x00); } } // Write the PLGC section bw.Write(font.plgc.type); bw.Write(font.plgc.block_size); bw.Write(font.plgc.tile_width); bw.Write(font.plgc.tile_height); bw.Write(font.plgc.tile_length); bw.Write(font.plgc.unknown); bw.Write(font.plgc.depth); bw.Write(font.plgc.rotateMode); for (int i = 0; i < font.plgc.tiles.Length; i++) { bw.Write(BitsToBytes(font.plgc.tiles[i])); } // Padding rem = (int)bw.BaseStream.Position % 4; if (rem != 0) { for (; rem < 4; rem++) { bw.Write((byte)0x00); } } // Write HDWC section bw.Write(font.hdwc.type); bw.Write(font.hdwc.block_size); bw.Write(font.hdwc.fist_code); bw.Write(font.hdwc.last_code); bw.Write(font.hdwc.unknown1); for (int i = 0; i < font.hdwc.info.Count; i++) { bw.Write(font.hdwc.info[i].pixel_start); bw.Write(font.hdwc.info[i].pixel_width); bw.Write(font.hdwc.info[i].pixel_length); } // Padding rem = (int)bw.BaseStream.Position % 4; if (rem != 0) { for (; rem < 4; rem++) { bw.Write((byte)0x00); } } // Sorts of CMAPs by type sNFTR.PAMC[] cmaps = new sNFTR.PAMC[font.pamc.Count]; uint[] types = new uint[font.pamc.Count]; for (int i = 0; i < cmaps.Length; i++) { cmaps[i] = font.pamc[i]; types[i] = font.pamc[i].type_section; } Array.Sort(types, cmaps); font.pamc = new List <sNFTR.PAMC>(cmaps); // Write the PAMC section for (int i = 0; i < font.pamc.Count; i++) { long currPos = bw.BaseStream.Position; uint next_section = (uint)(currPos + font.pamc[i].block_size) + 0x08; if (i + 1 == font.pamc.Count) { next_section = 0; } bw.Write(font.pamc[i].type); bw.Write(font.pamc[i].block_size); bw.Write(font.pamc[i].first_char); bw.Write(font.pamc[i].last_char); bw.Write(font.pamc[i].type_section); bw.Write(next_section); switch (font.pamc[i].type_section) { case 0: sNFTR.PAMC.Type0 type0 = (sNFTR.PAMC.Type0)font.pamc[i].info; bw.Write(type0.fist_char_code); bw.Write((ushort)0x00); break; case 1: sNFTR.PAMC.Type1 type1 = (sNFTR.PAMC.Type1)font.pamc[i].info; for (int j = 0; j < type1.char_code.Length; j++) { bw.Write(type1.char_code[j]); } if (type1.char_code.Length % 2 > 0) { bw.Write((ushort)0x00); } break; case 2: sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)font.pamc[i].info; bw.Write(type2.num_chars); for (int j = 0; j < type2.num_chars; j++) { bw.Write(type2.charInfo[j].chars_code); bw.Write(type2.charInfo[j].chars); } bw.Write((ushort)0x00); break; } } bw.Flush(); bw.Close(); }
public static sNFTR Read(sFile cfile, string lang) { sNFTR font = new sNFTR(); font.id = cfile.id; font.name = cfile.name; BinaryReader br = new BinaryReader(File.OpenRead(cfile.path)); // Read the standard header font.header.type = br.ReadChars(4); font.header.endianess = br.ReadUInt16(); font.header.unknown = br.ReadUInt16(); font.header.file_size = br.ReadUInt32(); font.header.block_size = br.ReadUInt16(); font.header.num_blocks = br.ReadUInt16(); // Font INFo section font.fnif.type = br.ReadChars(4); font.fnif.block_size = br.ReadUInt32(); font.fnif.unknown1 = br.ReadByte(); font.fnif.height = br.ReadByte(); font.fnif.nullCharIndex = br.ReadUInt16(); font.fnif.unknown4 = br.ReadByte(); font.fnif.width = br.ReadByte(); font.fnif.width_bis = br.ReadByte(); font.fnif.encoding = br.ReadByte(); font.fnif.offset_plgc = br.ReadUInt32(); font.fnif.offset_hdwc = br.ReadUInt32(); font.fnif.offset_pamc = br.ReadUInt32(); if (font.fnif.block_size == 0x20) { font.fnif.height_font = br.ReadByte(); font.fnif.widht_font = br.ReadByte(); font.fnif.bearing_y = br.ReadByte(); font.fnif.bearing_x = br.ReadByte(); } // Character Graphics LP br.BaseStream.Position = font.fnif.offset_plgc - 0x08; font.plgc.type = br.ReadChars(4); font.plgc.block_size = br.ReadUInt32(); font.plgc.tile_width = br.ReadByte(); font.plgc.tile_height = br.ReadByte(); font.plgc.tile_length = br.ReadUInt16(); font.plgc.unknown = br.ReadUInt16(); font.plgc.depth = br.ReadByte(); font.plgc.rotateMode = br.ReadByte(); font.plgc.tiles = new Byte[(font.plgc.block_size - 0x10) / font.plgc.tile_length][]; for (int i = 0; i < font.plgc.tiles.Length; i++) { font.plgc.tiles[i] = BytesToBits(br.ReadBytes(font.plgc.tile_length)); if (font.plgc.rotateMode == 2) font.plgc.tiles[i] = Rotate270(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); else if (font.plgc.rotateMode == 1) font.plgc.tiles[i] = Rotate90(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); else if (font.plgc.rotateMode == 3) font.plgc.tiles[i] = Rotate180(font.plgc.tiles[i], font.plgc.tile_width, font.plgc.tile_height, font.plgc.depth); } // Character Width DH br.BaseStream.Position = font.fnif.offset_hdwc - 0x08; font.hdwc.type = br.ReadChars(4); font.hdwc.block_size = br.ReadUInt32(); font.hdwc.fist_code = br.ReadUInt16(); font.hdwc.last_code = br.ReadUInt16(); font.hdwc.unknown1 = br.ReadUInt32(); font.hdwc.info = new List<sNFTR.HDWC.Info>(); for (int i = 0; i < font.plgc.tiles.Length; i++) { sNFTR.HDWC.Info info = new sNFTR.HDWC.Info(); info.pixel_start = br.ReadByte(); info.pixel_width = br.ReadByte(); info.pixel_length = br.ReadByte(); font.hdwc.info.Add(info); } // Character MAP br.BaseStream.Position = font.fnif.offset_pamc - 0x08; font.pamc = new List<sNFTR.PAMC>(); uint nextOffset = 0x00; do { sNFTR.PAMC pamc = new sNFTR.PAMC(); pamc.type = br.ReadChars(4); pamc.block_size = br.ReadUInt32(); pamc.first_char = br.ReadUInt16(); pamc.last_char = br.ReadUInt16(); pamc.type_section = br.ReadUInt32(); nextOffset = br.ReadUInt32(); pamc.next_section = nextOffset; switch (pamc.type_section) { case 0: sNFTR.PAMC.Type0 type0 = new sNFTR.PAMC.Type0(); type0.fist_char_code = br.ReadUInt16(); pamc.info = type0; break; case 1: sNFTR.PAMC.Type1 type1 = new sNFTR.PAMC.Type1(); type1.char_code = new ushort[(pamc.block_size - 0x14 - 0x02) / 2]; for (int i = 0; i < type1.char_code.Length; i++) type1.char_code[i] = br.ReadUInt16(); pamc.info = type1; break; case 2: sNFTR.PAMC.Type2 type2 = new sNFTR.PAMC.Type2(); type2.num_chars = br.ReadUInt16(); type2.charInfo = new sNFTR.PAMC.Type2.CharInfo[type2.num_chars]; for (int i = 0; i < type2.num_chars; i++) { type2.charInfo[i].chars_code = br.ReadUInt16(); type2.charInfo[i].chars = br.ReadUInt16(); } pamc.info = type2; break; } font.pamc.Add(pamc); br.BaseStream.Position = nextOffset - 0x08; } while (nextOffset != 0x00 && (nextOffset - 0x08) < br.BaseStream.Length); //WriteInfo(font, lang); font.plgc.rotateMode = 0; br.Close(); return font; }
private void numericType_ValueChanged(object sender, EventArgs e) { sNFTR.PAMC map = maps[(int)numericSection.Value]; map.type_section = (uint)numericType.Value; maps[(int)numericSection.Value] = map; }
private void dataGridMapInfo_CellEndEdit(object sender, DataGridViewCellEventArgs e) { sNFTR.PAMC map = maps[(int)numericSection.Value]; if (map.type_section == 2) { sNFTR.PAMC.Type2 type2 = (sNFTR.PAMC.Type2)map.info; if (e.ColumnIndex == 0) { if ((e.RowIndex + 1) > type2.charInfo.Length) { List <sNFTR.PAMC.Type2.CharInfo> values = new List <sNFTR.PAMC.Type2.CharInfo>(); sNFTR.PAMC.Type2.CharInfo info = new sNFTR.PAMC.Type2.CharInfo(); info.chars = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[0].Value); info.chars_code = 0; values.AddRange(type2.charInfo); values.Add(info); type2.charInfo = values.ToArray(); type2.num_chars++; } else if (dataGridMapInfo.RowCount < type2.charInfo.Length) { List <sNFTR.PAMC.Type2.CharInfo> values = new List <sNFTR.PAMC.Type2.CharInfo>(); values.AddRange(type2.charInfo); values.RemoveAt(e.RowIndex); type2.charInfo = values.ToArray(); type2.num_chars--; } else { type2.charInfo[e.RowIndex].chars = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[0].Value); } } else if (e.ColumnIndex == 1) { if ((e.RowIndex + 1) > type2.charInfo.Length) { List <sNFTR.PAMC.Type2.CharInfo> values = new List <sNFTR.PAMC.Type2.CharInfo>(); sNFTR.PAMC.Type2.CharInfo info = new sNFTR.PAMC.Type2.CharInfo(); info.chars_code = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[1].Value); info.chars = 0; values.AddRange(type2.charInfo); values.Add(info); type2.charInfo = values.ToArray(); type2.num_chars++; } else if (dataGridMapInfo.RowCount < type2.charInfo.Length) { List <sNFTR.PAMC.Type2.CharInfo> values = new List <sNFTR.PAMC.Type2.CharInfo>(); values.AddRange(type2.charInfo); values.RemoveAt(e.RowIndex); type2.charInfo = values.ToArray(); type2.num_chars--; } else { type2.charInfo[e.RowIndex].chars_code = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[1].Value); } } map.info = type2; } else if (map.type_section == 1) { sNFTR.PAMC.Type1 type1 = (sNFTR.PAMC.Type1)map.info; if (e.ColumnIndex == 0) { if ((e.RowIndex + 1) > type1.char_code.Length) { List <ushort> values = new List <ushort>(); values.AddRange(type1.char_code); values.Add(Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[0].Value)); type1.char_code = values.ToArray(); } else if (dataGridMapInfo.RowCount < type1.char_code.Length) { List <ushort> values = new List <ushort>(); values.AddRange(type1.char_code); values.RemoveAt(e.RowIndex); type1.char_code = values.ToArray(); } else { type1.char_code[e.RowIndex] = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[0].Value); } } map.info = type1; } else { sNFTR.PAMC.Type0 type0 = (sNFTR.PAMC.Type0)map.info; if (e.ColumnIndex == 0 && e.RowIndex == 0 && dataGridMapInfo.RowCount > 0) { type0.fist_char_code = Convert.ToUInt16(dataGridMapInfo.Rows[e.RowIndex].Cells[0].Value); } map.info = type0; } maps[(int)numericSection.Value] = map; }